在学习activiti时,对于activiti-ui下的acitviti-app打包方式并不是很理解。花了5分钟思考了下,还是准备较为深入的理解maven在多模块打包时的一些问题
下午就要拆线了,还是蛮期待伤病归来,强拉20个引体向上的,哈哈
2019年4月27日 雨
每个测试都会由一个对应的分支,方便查看
maven中多模块肯定逃不开继承与聚合,模块的继承与聚合一般而言都是一起出现的,但是这两个功能其实是完全可以分离使用的。由于当今IDE的智能,一般会在建立子模块的时候帮我们自动处理继承与聚合,所以我们只要了解过这点就行了。
maven中,继承处理的是版本集中统一管理版本,比如test的以来不能传递,所以必然导致各个模块的test范围的依赖版本不一致。而聚合是为了基于某种规则进行集中打包。
多模块可以应用与springboot工程、将多个依赖打成一个war包的工程、将多个依赖打成一个jar包等很多灵活的工程场景。
假设现在有一个曲江高新区的项目,我们准备将这个项目分为
建立好的多模块工程如下
可以将分支切换到”01.多模块打包顺序”
当我们通过root工程进行打包的时候
结果是喜闻乐见的。
可以看到分别将两个工程对用的jar包全构建成功了。而且自动帮我们处理了打包时的依赖顺序问题
可以看到打包时会先对root工程进行构建,毕竟我们就是通过root工程进行打包的嘛。
但是我们在通过子工程直接进行打包时会产生这样的错误
我们可以知道打包的会后会寻找坐标依赖,会先从本地仓库进行寻找,我们的本地仓库中并没有qujiang-service.jar这个jar包,所以maven报出无法解析依赖这样的错误。
结论:无法通过聚合工程的子工程打包所有的项目。
emmm…直接就打成功了!
可以看到,当前war工程中pom文件依赖的别的工程会直接被打入war包中的lib目录中自己在war包工程中写的java文件会被打入到classes中如下
此时如果通过root工程进行打包的话,也能获得相应的成功结果,如我们所见
并没有经理什么完整的配置
先说个注意点吧,谁要打成可执行的jar包,就在那个pom文件中引入打成可执行jar包的依赖,别的工程不要引入。