Maven-POM中的各类scope的行为总结
- compile:默认的scope。任何定义在compile scope下的依赖将会在全部的class paths下可用。maven工程会将其打包到最终的artifact中。若是你构建一个WAR类型的artifact,那么在compile scope下引用的JAR文件将会被集成到WAR文件内。
- provided:这个scope假定对应的依赖会由运行这个应用的JDK或者容器来提供。最好的例子就是servlet API。任何在provided scope下定义的依赖在构建时的类路径里是可用的,可是不会被打包到最终的artifact中。若是是一个WAR的文件,servlet API在构建时的类路径里是可用的,可是并不会被打包到WAR文件中。
- runtime:在runtime scope下定义的依赖只会在运行期可用,而在构建期的类路径下不可用。这些依赖将会被打包到最终的artifact中。好比你有一个基于web的应用须要在运行时访问MySQL数据库。你的代码没有任何MySQL数据库驱动的硬依赖。你的代码仅仅是基于JDBC API来编写,在构建期并不须要MySQL数据库驱动。然而,在运行期,就须要相应的驱动来操做MySQL数据库了。所以,这个驱动应该被打包到最终的artifact中。
- test:只用于测试变异的依赖(好比JUnit),execution必须定义在test scope下。这些依赖不会被打包到最终的artifact中。
- system:于provided scope很像。惟一的区别在于,在system scope中,你须要告诉Maven如何去找到这个依赖。若是你要引用的依赖在Maven仓库中不存在时,就能够用这个scope。不推荐使用system依赖。
- import:从其它的pom文件中导入依赖设置。
欢迎关注本站公众号,获取更多信息