1、创建标准的 maven 项目

eclipse 主菜单选择 new,再选择 project

maven-new-project.png

在弹出的窗口中选择 Maven Project,点击 next 按钮进入下一步

maven-create-project.png

在接下来的窗口中勾选 Use default Wrokspace location 点击 next 进入下一步

maven-default-workspace.png

在接下来的窗口中的 Filter 栏输入 “webapp”,选择 org.apache.maven.archetypes maven-archetype-webapp 1.0,点击 next 进入下一步

maven-webapp.png

在接下来的窗口中输入 Group Id 以及 Artifact Id,点击 finish 完成项目的创建

maven-finish.png

创建创建完成后,最终的目录结构如下

maven-project-struct.png

注意:在某些低版本的 eclipse 中,项目创建完成后,在 main 目录下面会缺少 “java” 这个目录,只需要在资源管理器里面手动创建该目录即可

2、添加 jfinal-undertow 与 jfinal 依赖

打开 pom.xml 文件,在其中添加如下依赖

  1. <dependency>
  2. <groupId>com.jfinal</groupId>
  3. <artifactId>jfinal-undertow</artifactId>
  4. <version>3.0</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>com.jfinal</groupId>
  8. <artifactId>jfinal</artifactId>
  9. <version>5.0.0</version>
  10. </dependency>

如果需要 WebSocket 支持,再添加一个依赖,不开发 WebSocket 无需理会

  1. <dependency>
  2. <groupId>io.undertow</groupId>
  3. <artifactId>undertow-websockets-jsr</artifactId>
  4. <version>2.2.17.Final</version>
  5. </dependency>

3、添加 java 文件

在项目 src/main/java 目录下创建demo包,并在 demo 包下创建 DemoConfig 文件

  1. package demo;
  2. import com.jfinal.config.*;
  3. import com.jfinal.template.Engine;
  4. import com.jfinal.server.undertow.UndertowServer;
  5. public class DemoConfig extends JFinalConfig {
  6. /**
  7. * 注意:用于启动的 main 方法可以在任意 java 类中创建,在此仅为方便演示
  8. * 才将 main 方法放在了 DemoConfig 中
  9. *
  10. * 开发项目时,建议新建一个 App.java 或者 Start.java 这样的专用
  11. * 启动入口类放置用于启动的 main 方法
  12. */
  13. public static void main(String[] args) {
  14. UndertowServer.start(DemoConfig.class, 80, true);
  15. }
  16. public void configConstant(Constants me) {
  17. me.setDevMode(true);
  18. }
  19. public void configRoute(Routes me) {
  20. // jfinal 4.9.03 版新增了路由扫描功能,不必手动添加路由
  21. // me.add("/hello", HelloController.class);
  22. // 使用路由扫描,参数 "demo." 表示只扫描 demo 包及其子包下的路由
  23. me.scan("demo.");
  24. }
  25. public void configEngine(Engine me) {}
  26. public void configPlugin(Plugins me) {}
  27. public void configInterceptor(Interceptors me) {}
  28. public void configHandler(Handlers me) {}
  29. }

在 demo 包下创建 HelloController 类文件, 内容如下:

  1. package demo;
  2. import com.jfinal.core.Controller;
  3. @Path("/hello")
  4. public class HelloController extends Controller {
  5. public void index() {
  6. renderText("Hello JFinal World.");
  7. }
  8. }

jfinal 4.9.03 新增了路由扫描功能,详情请见:https://jfinal.com/doc/2-3

4、启动项目

在 DemoConfig 类文件上点击鼠标右键,选择 Debug As,再选择 Java Applidation 即可运行

maven-run.png

5、开启浏览器看效果

打开浏览器在地址栏中输入: http://localhost/hello,输出内容为Hello JFinal World证明项目框架搭建完成

完整 demo示例 可在JFinal官方网站首页右侧下载:http://www.jfinal.com

注意:jfinal-undertow 默认不支持 JSP,强烈建议使用 jfinal 默认的模板引擎 enjoy,谁用谁爽翻。

如果一定要使用 JSP,可以参考文档 1.5 章节最后面的《JSP支持问题》:https://jfinal.com/doc/1-5,或者使用 jetty-server 作为开发环境:https://jfinal.com/doc/1-6