业务需求
产品中需要加入个性化的功能(代码包括前端和后端)。
一般的想法是:后端代码打包成jar包,整合到产品中;前端html相关代码放到一个文件夹,把这个前端代码的文件夹放入到产品的静态资源目录下。
这种做法没问题,缺点就是后期升级部署时,如果个性化功能的后端和前端代码都做了修改,那么就得同时去更新后端和前端的代码。麻烦......
所以 ,如果升级部署能把个性化的功能都打成一个包,后期只单单维护这个包的话,就简洁明了,维护上方便很多。
解决方法
这么一来,问题就出现了:对于后端代码来说,打成jar包整合到产品项目上是没问题的。但是对于前端资源文件,如果打入到 jar包,如何访问呢?
带着这个问题,网上查了一下,发现 servlet3.0有一个特性:
在servlet3.0协议规范中,包含在jar文件 /META-INFO/resources/ 路径下的资源是可以直接访问的。这句话的意思是 只要你把资源文件放到jar包中的 /META-INFO/resources目录下,启动项目时,这个目录下的资源文件是可以直接访问的。
这里可能会有这几个疑问:
【1】问:/META-INF/resources 目录要在哪里创建?
答:在 src/main/resources资源目录下创建,如下图:
【2】问:怎么知道项目用的是不是 servlet3.0 ?
答:如果是war项目,可以查看一下项目的web.xml文件,查看跟节点 web-app 里指定的版本是多少,如下图,指定的servlet版本是2.5:
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5">
</web-app>
如果是springboot项目,内嵌的tomcat基本都是tomcat 8+的版本,对应的servlet版本号也是 servlet 3.0+版本。
实现访问
实际项目中,个性化项目结构如下图:
根据之前的描述,我们知道 /META-INFO/resources 会被视为根目录 。
当我们把这份个性化代码打包成jar,整合到产品项目上后;假设项目名称为 XXX , 端口为8080 。 要访问test.html ,对应的访问url为:http://ip:8080/XXX/html/cpc/test.html。在该目录下的其他资源文件也类似这样去直接访问。
通过这种方式,把个性化功能整合成一个jar包,便于后期的管理维护。在实际项目中,如果有这种需求需要添加一些额外的功能,不妨可以使用这种方式。