From d0cdb76b6d2d093a641f0d0b19fa73f7e569f071 Mon Sep 17 00:00:00 2001 From: "Yangkai.Shen" <237497819@qq.com> Date: Tue, 9 Oct 2018 16:34:19 +0800 Subject: [PATCH] =?UTF-8?q?:sparkles:=20spring-boot-template-freemarker=20?= =?UTF-8?q?=E5=AE=8C=E6=88=90?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- spring-boot-template-freemarker/.gitignore | 25 +++ spring-boot-template-freemarker/README.md | 183 ++++++++++++++++++ spring-boot-template-freemarker/pom.xml | 67 +++++++ ...ringBootTemplateFreemarkerApplication.java | 25 +++ .../controller/IndexController.java | 43 ++++ .../freemarker/controller/UserController.java | 45 +++++ .../template/freemarker/model/User.java | 22 +++ .../src/main/resources/application.yml | 4 + .../main/resources/templates/common/head.ftl | 7 + .../src/main/resources/templates/index.ftl | 9 + .../src/main/resources/templates/login.ftl | 13 ++ ...ootTemplateFreemarkerApplicationTests.java | 16 ++ 12 files changed, 459 insertions(+) create mode 100644 spring-boot-template-freemarker/.gitignore create mode 100644 spring-boot-template-freemarker/README.md create mode 100644 spring-boot-template-freemarker/pom.xml create mode 100644 spring-boot-template-freemarker/src/main/java/com/xkcoding/template/freemarker/SpringBootTemplateFreemarkerApplication.java create mode 100644 spring-boot-template-freemarker/src/main/java/com/xkcoding/template/freemarker/controller/IndexController.java create mode 100644 spring-boot-template-freemarker/src/main/java/com/xkcoding/template/freemarker/controller/UserController.java create mode 100644 spring-boot-template-freemarker/src/main/java/com/xkcoding/template/freemarker/model/User.java create mode 100644 spring-boot-template-freemarker/src/main/resources/application.yml create mode 100644 spring-boot-template-freemarker/src/main/resources/templates/common/head.ftl create mode 100644 spring-boot-template-freemarker/src/main/resources/templates/index.ftl create mode 100644 spring-boot-template-freemarker/src/main/resources/templates/login.ftl create mode 100644 spring-boot-template-freemarker/src/test/java/com/xkcoding/template/freemarker/SpringBootTemplateFreemarkerApplicationTests.java diff --git a/spring-boot-template-freemarker/.gitignore b/spring-boot-template-freemarker/.gitignore new file mode 100644 index 0000000..82eca33 --- /dev/null +++ b/spring-boot-template-freemarker/.gitignore @@ -0,0 +1,25 @@ +/target/ +!.mvn/wrapper/maven-wrapper.jar + +### STS ### +.apt_generated +.classpath +.factorypath +.project +.settings +.springBeans +.sts4-cache + +### IntelliJ IDEA ### +.idea +*.iws +*.iml +*.ipr + +### NetBeans ### +/nbproject/private/ +/build/ +/nbbuild/ +/dist/ +/nbdist/ +/.nb-gradle/ \ No newline at end of file diff --git a/spring-boot-template-freemarker/README.md b/spring-boot-template-freemarker/README.md new file mode 100644 index 0000000..e6b77ae --- /dev/null +++ b/spring-boot-template-freemarker/README.md @@ -0,0 +1,183 @@ +# spring-boot-template-freemarker + +> 本 demo 主要演示了 Spring Boot 项目如何集成 freemarker 模板引擎 + +## pom.xml + +```xml + + + 4.0.0 + + com.xkcoding + spring-boot-template-freemarker + 0.0.1-SNAPSHOT + jar + + spring-boot-template-freemarker + Demo project for Spring Boot + + + org.springframework.boot + spring-boot-starter-parent + 2.0.5.RELEASE + + + + + UTF-8 + UTF-8 + 1.8 + 4.1.15 + + + + + org.springframework.boot + spring-boot-starter-freemarker + + + + org.springframework.boot + spring-boot-starter-web + + + + org.springframework.boot + spring-boot-starter-test + test + + + + org.projectlombok + lombok + + + + cn.hutool + hutool-all + ${hutool.version} + + + + + spring-boot-template-freemarker + + + org.springframework.boot + spring-boot-maven-plugin + + + + + +``` + +## IndexController.java + +```java +/** + *

+ * 主页 + *

+ * + * @package: com.xkcoding.template.freemarker.controller + * @description: 主页 + * @author: yangkai.shen + * @date: Created in 2018/10/9 3:07 PM + * @copyright: Copyright (c) 2018 + * @version: V1.0 + * @modified: yangkai.shen + */ +@Controller +@Slf4j +public class IndexController { + + @GetMapping(value = {"", "/"}) + public ModelAndView index(HttpServletRequest request) { + ModelAndView mv = new ModelAndView(); + + User user = (User) request.getSession().getAttribute("user"); + if (ObjectUtil.isNull(user)) { + mv.setViewName("redirect:/user/login"); + } else { + mv.setViewName("index"); + mv.addObject(user); + } + + return mv; + } +} +``` + +## UserController.java + +```java +/** + *

+ * 用户页面 + *

+ * + * @package: com.xkcoding.template.freemarker.controller + * @description: 用户页面 + * @author: yangkai.shen + * @date: Created in 2018/10/9 3:11 PM + * @copyright: Copyright (c) 2018 + * @version: V1.0 + * @modified: yangkai.shen + */ +@Controller +@RequestMapping("/user") +@Slf4j +public class UserController { + @PostMapping("/login") + public ModelAndView login(User user, HttpServletRequest request) { + ModelAndView mv = new ModelAndView(); + + mv.addObject(user); + mv.setViewName("redirect:/"); + + request.getSession().setAttribute("user", user); + return mv; + } + + @GetMapping("/login") + public ModelAndView login() { + return new ModelAndView("login"); + } +} +``` + +## index.ftl + +```jsp + + +<#include "./common/head.ftl"> + +
+ 欢迎登录,${user.name}! +
+ + +``` + +## login.ftl + +```jsp + + +<#include "./common/head.ftl"> + +
+
+ 用户名 + 密码 + +
+
+ + +``` + diff --git a/spring-boot-template-freemarker/pom.xml b/spring-boot-template-freemarker/pom.xml new file mode 100644 index 0000000..735c279 --- /dev/null +++ b/spring-boot-template-freemarker/pom.xml @@ -0,0 +1,67 @@ + + + 4.0.0 + + com.xkcoding + spring-boot-template-freemarker + 0.0.1-SNAPSHOT + jar + + spring-boot-template-freemarker + Demo project for Spring Boot + + + org.springframework.boot + spring-boot-starter-parent + 2.0.5.RELEASE + + + + + UTF-8 + UTF-8 + 1.8 + 4.1.15 + + + + + org.springframework.boot + spring-boot-starter-freemarker + + + + org.springframework.boot + spring-boot-starter-web + + + + org.springframework.boot + spring-boot-starter-test + test + + + + org.projectlombok + lombok + + + + cn.hutool + hutool-all + ${hutool.version} + + + + + spring-boot-template-freemarker + + + org.springframework.boot + spring-boot-maven-plugin + + + + + diff --git a/spring-boot-template-freemarker/src/main/java/com/xkcoding/template/freemarker/SpringBootTemplateFreemarkerApplication.java b/spring-boot-template-freemarker/src/main/java/com/xkcoding/template/freemarker/SpringBootTemplateFreemarkerApplication.java new file mode 100644 index 0000000..9c9870d --- /dev/null +++ b/spring-boot-template-freemarker/src/main/java/com/xkcoding/template/freemarker/SpringBootTemplateFreemarkerApplication.java @@ -0,0 +1,25 @@ +package com.xkcoding.template.freemarker; + +import org.springframework.boot.SpringApplication; +import org.springframework.boot.autoconfigure.SpringBootApplication; + +/** + *

+ * 启动类 + *

+ * + * @package: com.xkcoding.template.freemarker + * @description: 启动类 + * @author: yangkai.shen + * @date: Created in 2018/10/9 3:17 PM + * @copyright: Copyright (c) 2018 + * @version: V1.0 + * @modified: yangkai.shen + */ +@SpringBootApplication +public class SpringBootTemplateFreemarkerApplication { + + public static void main(String[] args) { + SpringApplication.run(SpringBootTemplateFreemarkerApplication.class, args); + } +} diff --git a/spring-boot-template-freemarker/src/main/java/com/xkcoding/template/freemarker/controller/IndexController.java b/spring-boot-template-freemarker/src/main/java/com/xkcoding/template/freemarker/controller/IndexController.java new file mode 100644 index 0000000..ce4939f --- /dev/null +++ b/spring-boot-template-freemarker/src/main/java/com/xkcoding/template/freemarker/controller/IndexController.java @@ -0,0 +1,43 @@ +package com.xkcoding.template.freemarker.controller; + +import cn.hutool.core.util.ObjectUtil; +import com.xkcoding.template.freemarker.model.User; +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Controller; +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.servlet.ModelAndView; + +import javax.servlet.http.HttpServletRequest; + +/** + *

+ * 主页 + *

+ * + * @package: com.xkcoding.template.freemarker.controller + * @description: 主页 + * @author: yangkai.shen + * @date: Created in 2018/10/9 3:07 PM + * @copyright: Copyright (c) 2018 + * @version: V1.0 + * @modified: yangkai.shen + */ +@Controller +@Slf4j +public class IndexController { + + @GetMapping(value = {"", "/"}) + public ModelAndView index(HttpServletRequest request) { + ModelAndView mv = new ModelAndView(); + + User user = (User) request.getSession().getAttribute("user"); + if (ObjectUtil.isNull(user)) { + mv.setViewName("redirect:/user/login"); + } else { + mv.setViewName("index"); + mv.addObject(user); + } + + return mv; + } +} diff --git a/spring-boot-template-freemarker/src/main/java/com/xkcoding/template/freemarker/controller/UserController.java b/spring-boot-template-freemarker/src/main/java/com/xkcoding/template/freemarker/controller/UserController.java new file mode 100644 index 0000000..73ffed1 --- /dev/null +++ b/spring-boot-template-freemarker/src/main/java/com/xkcoding/template/freemarker/controller/UserController.java @@ -0,0 +1,45 @@ +package com.xkcoding.template.freemarker.controller; + +import com.xkcoding.template.freemarker.model.User; +import lombok.extern.slf4j.Slf4j; +import org.springframework.stereotype.Controller; +import org.springframework.web.bind.annotation.GetMapping; +import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.RequestMapping; +import org.springframework.web.servlet.ModelAndView; + +import javax.servlet.http.HttpServletRequest; + +/** + *

+ * 用户页面 + *

+ * + * @package: com.xkcoding.template.freemarker.controller + * @description: 用户页面 + * @author: yangkai.shen + * @date: Created in 2018/10/9 3:11 PM + * @copyright: Copyright (c) 2018 + * @version: V1.0 + * @modified: yangkai.shen + */ +@Controller +@RequestMapping("/user") +@Slf4j +public class UserController { + @PostMapping("/login") + public ModelAndView login(User user, HttpServletRequest request) { + ModelAndView mv = new ModelAndView(); + + mv.addObject(user); + mv.setViewName("redirect:/"); + + request.getSession().setAttribute("user", user); + return mv; + } + + @GetMapping("/login") + public ModelAndView login() { + return new ModelAndView("login"); + } +} diff --git a/spring-boot-template-freemarker/src/main/java/com/xkcoding/template/freemarker/model/User.java b/spring-boot-template-freemarker/src/main/java/com/xkcoding/template/freemarker/model/User.java new file mode 100644 index 0000000..d03e420 --- /dev/null +++ b/spring-boot-template-freemarker/src/main/java/com/xkcoding/template/freemarker/model/User.java @@ -0,0 +1,22 @@ +package com.xkcoding.template.freemarker.model; + +import lombok.Data; + +/** + *

+ * 用户 model + *

+ * + * @package: com.xkcoding.template.freemarker.model + * @description: 用户 model + * @author: yangkai.shen + * @date: Created in 2018/10/9 3:06 PM + * @copyright: Copyright (c) 2018 + * @version: V1.0 + * @modified: yangkai.shen + */ +@Data +public class User { + private String name; + private String password; +} diff --git a/spring-boot-template-freemarker/src/main/resources/application.yml b/spring-boot-template-freemarker/src/main/resources/application.yml new file mode 100644 index 0000000..a02fbde --- /dev/null +++ b/spring-boot-template-freemarker/src/main/resources/application.yml @@ -0,0 +1,4 @@ +server: + port: 8080 + servlet: + context-path: /demo \ No newline at end of file diff --git a/spring-boot-template-freemarker/src/main/resources/templates/common/head.ftl b/spring-boot-template-freemarker/src/main/resources/templates/common/head.ftl new file mode 100644 index 0000000..0378c4f --- /dev/null +++ b/spring-boot-template-freemarker/src/main/resources/templates/common/head.ftl @@ -0,0 +1,7 @@ + + + + + spring-boot-template-freemarker + \ No newline at end of file diff --git a/spring-boot-template-freemarker/src/main/resources/templates/index.ftl b/spring-boot-template-freemarker/src/main/resources/templates/index.ftl new file mode 100644 index 0000000..a9a03bd --- /dev/null +++ b/spring-boot-template-freemarker/src/main/resources/templates/index.ftl @@ -0,0 +1,9 @@ + + +<#include "./common/head.ftl"> + +
+ 欢迎登录,${user.name}! +
+ + \ No newline at end of file diff --git a/spring-boot-template-freemarker/src/main/resources/templates/login.ftl b/spring-boot-template-freemarker/src/main/resources/templates/login.ftl new file mode 100644 index 0000000..c019094 --- /dev/null +++ b/spring-boot-template-freemarker/src/main/resources/templates/login.ftl @@ -0,0 +1,13 @@ + + +<#include "./common/head.ftl"> + +
+
+ 用户名 + 密码 + +
+
+ + \ No newline at end of file diff --git a/spring-boot-template-freemarker/src/test/java/com/xkcoding/template/freemarker/SpringBootTemplateFreemarkerApplicationTests.java b/spring-boot-template-freemarker/src/test/java/com/xkcoding/template/freemarker/SpringBootTemplateFreemarkerApplicationTests.java new file mode 100644 index 0000000..76d15f2 --- /dev/null +++ b/spring-boot-template-freemarker/src/test/java/com/xkcoding/template/freemarker/SpringBootTemplateFreemarkerApplicationTests.java @@ -0,0 +1,16 @@ +package com.xkcoding.template.freemarker; + +import org.junit.Test; +import org.junit.runner.RunWith; +import org.springframework.boot.test.context.SpringBootTest; +import org.springframework.test.context.junit4.SpringRunner; + +@RunWith(SpringRunner.class) +@SpringBootTest +public class SpringBootTemplateFreemarkerApplicationTests { + + @Test + public void contextLoads() { + } + +}