java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > maven配置项目一直提示程序包不存在及scope的坑

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

作者:顺便挣钱W先生

这篇文章主要介绍了关于maven配置项目一直提示程序包不存在以及scope的坑,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

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表示被依赖项目需要参与当前项目的编译,当然后续的测试,运行周期也参与其中,是一个比较强的依赖。

打包的时候通常需要包含进去。

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

比较典型的如junit。

runntime表示被依赖项目无需参与项目的编译,不过后期的测试和运行周期需要其参与。

与compile相比,跳过编译而已,说实话在终端的项目(非开源,企业内部系统)中,和compile区别不是很大。

比较常见的如JSR×××的实现,对应的API jar是compile的,具体实现是runtime的,compile只需要知道接口就足够了。

oracle jdbc驱动架包就是一个很好的例子,一般scope为runntime。

另外runntime的依赖通常和optional搭配使用,optional为true。

我可以用A实现,也可以用B实现。

provided意味着打包的时候可以不用包进去,别的设施(Web Container)会提供。

事实上该依赖理论上可以参与编译,测试,运行等周期。

相当于compile,但是在打包阶段做了exclude的动作。

从参与度来说,也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>

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文