这些项目正在用Maven,Spring MVC和Sitemesh进行重写.
模型层代码很容易使用JAR共享.但是我不知道在类似的应用程序之间共享常见的Web层代码(JSP和控制器)的任何好方法.
这里有一些背景.这些应用程式是网路商店.一个是用户可以登录,搜索产品,添加到购物车和退房的普通商店(think amazon.com).另一个基本上是一样的,只是一个punchout网站.产品浏览和购物车部分是相同的.然而,登录和结帐是完全不同的.
我过于简单,但足以说明问题.产品浏览和购物车部分中的Web层代码中有很大一部分应该能够在两者之间共享.
我不认为可以简单地将相同的WAR文件与基于环境变量的“模式”或来自不同数据库的设置一起运行.其中一个区别是完全不同的Spring Security配置.最好将其他站点的登录和检出控制器从组件扫描中离开,否则任何人都无法通过URL操作过渡到错误的控制器.
我最初开始使用Maven Profiles和过滤来保存两个不同的配置集(web.xml,spring配置等)在同一个WAR项目中.基于哪个Maven配置文件被选择,所生成的WAR是用不同的配置集构建的(为了清楚起见,使用不同的名称).这违反了一个人生产一件神器的Maven校长.
有没有更好的方法来做到这一点? Maven WAR Overlays如何?我看到人们谈论使用叠加层来共享像CSS,JS,图像,甚至一些常见的JSP这样的常见资源.但是我没有看到有人提到这样分享类控制器.
我可以将Controller类推送到JAR,但从逻辑上看,它们应该保留在各自的JSP中. JSP也不能被推到JAR(对吗?).
我也考虑将它作为一个包含多个WAR文件的EAR,一个是常见购物体验的WAR,另一个WAR用于适当的登录和结帐.我相信会话可以在同一个EAR中的两个WAR之间共享,但我不知道它是否与Spring的会话范围bean很好.我听说他们没有真正存储在会话中.我还需要弄清楚用于页眉/页脚的Sitemesh装饰器应该怎么做.相同的Sitemesh配置及其资源需要复制到两个WAR中,对吗?所以最后,购物WAR工件在每种情况下仍然会有所不同.
我必须相信其他人之前已经处理过了.我以为错了吗?这种事情有没有共同的解决方案?
解决方法
<plugin> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-dependency-plugin</artifactId> <version>2.4</version> <executions> <execution> <id>unpack</id> <phase>package</phase> <goals> <goal>unpack</goal> </goals> <configuration> <artifactItems> <artifactItem> <groupId>com.example</groupId> <artifactId>webapp-common</artifactId> <version>1.0-SNAPSHOT</version> <outputDirectory>[target jsp directory]</outputDirectory> <includes>**/*.jsp</includes> </artifactItem> </artifactItems> </configuration> </execution> </executions> </plugin>