关于maven配置项目一直提示程序包不存在以及scope的坑
作者:顺便挣钱W先生
maven配置项目一直提示程序包不存在及scope的坑
今天 ,打包项目的时候,一直提示
wtf?之前一直行的呀,一直都没问题的,今天难道这么倒霉?
于是我去检查maven依赖,没毛病啊,资源库和项目都有啊
1.我检查过,maven依赖里面是有这个包的,资源库和项目都有
2.项目/.setting 配置也检查过,没有更改过。
3.这些都有检查过,有都有添加maven 依赖的,jdk1.7,1.8试过都不行。
然后我上去查查stackoverflow,翻了很说是jdk啊,spring扫描的问题,于是我又改了一下
4.一开始我怀疑是版本问题不兼容问题,可是我都试过都升为最新版和对应的版本都不行。
5.spring 扫描,我扫描了整个项目,还是不行。
面如死灰之际,我请教了一下主管,主管一看有junit,就马上问:“看看pom.xml 里面的scope是什么?”
我:scope?什么鬼,能吃吗?
我一看,很正常啊,没毛病啊。我还得意洋洋的说,我还是复制mvn资源库的,绝对没打错。
主管:。。。。。。。。。。。
原来,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属性使用。
解决方式
test的框架参与编译,但是生成的jar包不放到上线的war包里面。
<dependency> <groupId>junit</groupId> <artifactId>junit</artifactId> <version>4.9</version> <scope>test</scope> </dependency> <dependency> <groupId>org.springframework</groupId> <artifactId>spring-test</artifactId> <version> 3.2.4.RELEASE </version> <scope>provided</scope> </dependency>
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。