12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 |
- 1、 public void configEngine(Engine me) 方法中添加如下两行代码
- me.setBaseTemplatePath("webapp");
- me.setToClassPathSourceFactory();
- 注意:上面两行配置代码要放在最前面,因为 addSharedFunction(...)
- 这类配置对上面配置有依赖关系
- 当你的 webapp 资源目录本来就放在 src/main/resources 之下时,可以去掉 pom.xml 中的
- maven-resources-plugin 插件,该插件就是在打包的时候将 src/main/webapp 下面的资源
- 复制到 target/classes 下面去,好让其打到 jar 包之中去
- 所以,如果项目确定当成 fatjar 来开发的话,建议将 src/main/webapp 整体挪到
- src/main/resources 之下。这样就从开发到打包不用做额外的动作,避免了出错的可能
-
- 有部分同学习惯于使用 static 代替 webapp,将上述涉及 webapp 的地方改成 static 即可
- 2、在 undertow.txt 配置文件中添加如下配置:
- undertow.resourcePath=src/main/webapp, classpath:webapp
- 3、将本文件夹下的 pom.xml 替换掉项目中原有的 pom.xml 文件
- 这两个文件的差别在于前者打 fatjar 包用到的是
- maven-resources-plugin、maven-shade-plugin 这两个插件
- 而后者用到的是 maven-assembly-plugin 插件
- 4、 打包运行
- mvn clean package
- java -jar jfinal-club.jar
- 5、 隐藏功能
- 在打好的 jar 包的目录中添加 config 目录并添加配置文件可以被项目加载,注意,这里的
- 配置文件名与 jar 包中的配置文件名不能相同,可以参考 JFinalClubConfig 中的用法:
- PropKit.use("jfinal-club-config-dev.txt").appendIfExists("jfinal-club-config-pro.txt");
- 也就是说在开发的时候使用 dev 配置,在生产环境手动创建一个 pro 配置,由于该配置文件
- 在 jar 包中不存在,所以会被加载,该配置文件中的配置会覆盖掉 dev 配置文件中的值
- 简单来说这就是 jfinal 的 Prop 工具的一个用法而已
- 在打好的 jar 包目录中添加将项目中的 webapp 复制过来,便于对外部 css、js、html 等资源
- 进行修改,更重要的是支持有文件上传功能的 web 项目
- 以上两个隐藏功能,需要在项目启动之前添加好目录与文件。简单来说这两个目录不存在时
- 使用 jar 包中的资源,否则就使用它。注意 config 目录中与 jar 包中的同名配置不会被加载
- 6、退出程序
- 如果启动时没带与字符 ‘&’ 结尾,则 Ctrl + C 即可退出否则使用下面的方法:
- 找到程序 pid: ps aux | grep java
- 杀掉进程: kill pid
- 注意使用 kill -9 pid 杀进程时,JFinalConfig.onStop() 不会被回调
- 可以参考 "非 fatjar" 项目的运行、停止脚本来写一个用于 fatjar 的脚本
- 小结:以上配置并不是仅仅适用于打包部署,开发阶段也使用这些配置,不用改来改去
|