maven 配置项目一直提示程序包不存在以及scope的坑

时间:2022-04-14 15:19:50

今天 ,打包项目的时候,一直提示

maven 配置项目一直提示程序包不存在以及scope的坑

 wtf?之前一直行的呀,一直都没问题的,今天难道这么倒霉?

于是我去检查maven依赖,没毛病啊,资源库和项目都有啊

1.我检查过,maven依赖里面是有这个包的,资源库和项目都有
maven 配置项目一直提示程序包不存在以及scope的坑


2.项目/.setting 配置也检查过,没有更改过。


3.这些都有检查过,有都有添加maven 依赖的,jdk1.7,1.8试过都不行。

maven 配置项目一直提示程序包不存在以及scope的坑


然后我上去查查*,翻了很说是jdk啊,spring扫描的问题,于是我又改了一下

4.一开始我怀疑是版本问题不兼容问题,可是我都试过都升为最新版和对应的版本都不行。

5.spring 扫描,我扫描了整个项目,还是不行。

面如死灰之际,我请教了一下主管,主管一看有junit,就马上问:“看看pom.xml 里面的scope是什么?”

我:scope?什么鬼,能吃吗?

我一看,很正常啊,没毛病啊。我还得意洋洋的说,我还是复制mvn资源库的,绝对没打错。

主管:。。。。。。。。。。。

maven 配置项目一直提示程序包不存在以及scope的坑



原来,scope是用于配置打包的jar包配置,有几个可选参数

compile,test,system,provided等,默认是compile,所以,一般不配置scope也是可以在项目编译打包的时候把jar包打进去的。

compile

默认就是compile,什么都不配置也就是意味着compile。compile表示被依赖项目需要参与当前项目的编译,当然后续的测试,运行周期也参与其中,是一个比较强的依赖。打包的时候通常需要包含进去。

test

scope为test表示依赖项目仅仅参与测试相关的工作,包括测试代码的编译,执行。比较典型的如junit。

runntime

runntime表示被依赖项目无需参与项目的编译,不过后期的测试和运行周期需要其参与。与compile相比,跳过编译而已,说实话在终端的项目(非开源,企业内部系统)中,和compile区别不是很大。比较常见的如JSR×××的实现,对应的API jar是compile的,具体实现是runtime的,compile只需要知道接口就足够了。oracle jdbc驱动架包就是一个很好的例子,一般scope为runntime。另外runntime的依赖通常和optional搭配使用,optional为true。我可以用A实现,也可以用B实现。

provided

provided意味着打包的时候可以不用包进去,别的设施(Web Container)会提供。事实上该依赖理论上可以参与编译,测试,运行等周期。相当于compile,但是在打包阶段做了exclude的动作。

system

从参与度来说,也provided相同,不过被依赖项不会从maven仓库抓,而是从本地文件系统拿,一定需要配合systemPath属性使用

参考链接:http://blog.csdn.net/kimylrong/article/details/50353161