博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SpringBoot整合Jsp和Thymeleaf (附工程)
阅读量:6091 次
发布时间:2019-06-20

本文共 10455 字,大约阅读时间需要 34 分钟。

前言

本篇文章主要讲述SpringBoot整合Jsp以及SpringBoot整合Thymeleaf,实现一个简单的用户增删改查示例工程。事先说明,有三个项目,两个是单独整合的,一个是将它们整合在一起的。如需其中一个,只需看相应部分的介绍即可。若需工程源代码,可以直接跳到底部,通过链接下载工程代码。

SpringBoot整合Jsp

开发准备

环境要求

JDK: 1.7或以上
SQL: MySql

这里我们需要在mysql中建立一张用户表,用于存储用户的信息。

数据库脚本如下:

CREATE TABLE `t_user` (  `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '自增id',  `name` varchar(10) DEFAULT NULL COMMENT '姓名',  `age` int(2) DEFAULT NULL COMMENT '年龄',  `password` varchar(24) NOT NULL COMMENT '密码',  PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=17 DEFAULT CHARSET=utf8

新建好表之后,我们再来创建工程。

我们的这个工程是通过maven创建一个普通的web工程。
创建好工程之后,我们需要下载相应的jar包,然后再来进行相关的开发。
这些jar包我们在pom.xml文件中添加springBoot和Jsp相关的jar即可。
相关的注释以及写在其中了,这里就不在过多讲述了。
Maven依赖如下:

org.springframework.boot
spring-boot-starter-web
org.springframework.boot
spring-boot-devtools
true
org.springframework.boot
spring-boot-starter-test
test
org.springframework.boot
spring-boot-starter-data-jpa
org.mybatis.spring.boot
mybatis-spring-boot-starter
${mybatis-spring-boot}
mysql
mysql-connector-java
com.alibaba
fastjson
${fastjson}
javax.servlet
jstl
javax.servlet
javax.servlet-api
provided
org.apache.tomcat.embed
tomcat-embed-jasper
provided

相关的Jar包下载完毕之后,我们再来确认项目的工程结构。

首先是后台相关包说明:

src/main/javacom.pancm.web - Controller 层com.pancm.dao - 数据操作层 DAOcom.pancm.pojo- 实体类com.pancm.service - 业务逻辑层Application - 应用启动类src/main/resourcesapplication.properties - 应用配置文件,应用启动会自动读取配置

前端的相关文件存放说明:

src/main/webappWEB-INF - web.xml web相关的核心配置WEB-INF/jsp - JSP文件的存放路径

整体工程结构图:

这里写图片描述

工程结构确认之后,我们再来添加相应的配置。

只需在application.properties 添加相应的配置即可。
数据源的配置和之前的差不多,需要注意的是Jsp的相关配置。
由于springBoot默认的支持的模版是Thymeleaf,所以这里我们需要进行相应的更改。

配置如下:

## 编码banner.charset=UTF-8server.tomcat.uri-encoding=UTF-8spring.http.encoding.charset=UTF-8spring.http.encoding.enabled=truespring.http.encoding.force=truespring.messages.encoding=UTF-8## 端口server.port=8088## 数据源spring.datasource.url=jdbc:mysql://localhost:3306/springBoot?useUnicode=true&characterEncoding=utf8spring.datasource.username=rootspring.datasource.password=123456spring.datasource.driver-class-name=com.mysql.jdbc.Driver## JSP配置# 页面默认前缀spring.mvc.view.prefix=/WEB-INF/jsp/# 响应页面默认后缀spring.mvc.view.suffix=.jsp

代码编写

其实这里的代码和之前文章讲述的基本一致,唯一有点区别的是,这里我是用JPA实现对数据库进行操作的(也就是顺便说下JPA这个框架的使用)。

首先是实体类,这里因为用了JPA,所以和之前的有点不同,添加了一些注解。

Entity:表示这是个实体类。
Table:该实体类映射的数据表名。
Column:指定该字段的属性,nullable 表示是否非空,unique 表示是否是唯一。

那么实体类的代码如下:

@Entity@Table(name = "t_user")public class User {     /** 编号 */     @Id     @GeneratedValue     private Long id;     /** 姓名 */     @Column(nullable = false, unique = true)     private String name;     /** 密码*/     @Column(nullable = false)     private String password;     /** 年龄 */     @Column(nullable = false)     private Integer age;    //getter和setter略}

由于用的是JPA,dao层这块只需继承JpaRepository该类即可,需要指定实体类和主键类型。

dao层代码如下:

@Mapperpublic interface UserDao extends JpaRepository
{}

业务层这块和之前一样调用即可,虽然用的是JPA,但是方法也是很简单的,新增和修改就用save,删除就是delete,findOne就是通过ID查找,findAll就是查询所有等等。

services代码如下:

@Servicepublic class UserServiceImpl implements UserService {    @Autowired    private UserDao userDao;    @Override    public boolean addUser(User user) {        boolean flag=false;        try{            userDao.save(user);            flag=true;        }catch(Exception e){            System.out.println("新增失败!");            e.printStackTrace();        }        return flag;    }    @Override    public boolean updateUser(User user) {        boolean flag=false;        try{            userDao.save(user);            flag=true;        }catch(Exception e){            System.out.println("修改失败!");            e.printStackTrace();        }        return flag;    }    @Override    public boolean deleteUser(Long id) {        boolean flag=false;        try{            userDao.delete(id);            flag=true;        }catch(Exception e){            System.out.println("删除失败!");            e.printStackTrace();        }        return flag;    }    @Override    public User findUserById(Long id) {        return userDao.findOne(id);    }    @Override    public List
findAll() { return userDao.findAll(); }}

到了控制层这块,这里提供还是提供接口给Jsp进行调用,不过这里类的注解就不能用之前的RestController这个注解,这个注解以json的格式返回数据,但是我们有时返回的时候需要跳转界面,所以应该使用Controller这个注解。如果想在某个方法中返回的数据格式是json的话,在该方法上加上ResponseBody这个注解即可。

控制层代码如下:

@Controllerpublic class UserRestController {        @Autowired        private UserService userService;        @RequestMapping("/hello")        public String hello() {            return "hello";        }        @RequestMapping("/")        public String index() {            return "redirect:/list";        }        @RequestMapping("/list")        public String list(Model model) {            System.out.println("查询所有");            List
users=userService.findAll(); model.addAttribute("users", users); return "user/list"; } @RequestMapping("/toAdd") public String toAdd() { return "user/userAdd"; } @RequestMapping("/add") public String add(User user) { userService.addUser(user); return "redirect:/list"; } @RequestMapping("/toEdit") public String toEdit(Model model,Long id) { User user=userService.findUserById(id); model.addAttribute("user", user); return "user/userEdit"; } @RequestMapping("/edit") public String edit(User user) { userService.updateUser(user); return "redirect:/list"; } @RequestMapping("/toDelete") public String delete(Long id) { userService.deleteUser(id); return "redirect:/list"; }}

功能测试

后端代码介绍就到这里了,至于前端JSP的代码就不在多说了(主要原因是界面写得太丑了...),我们直接启动项目,查看效果。

启动项目,在浏览器上输入:
主界面:
这里写图片描述

添加一条数据之后的界面:

这里写图片描述

这里写图片描述

其它的修改和删除也能实现,这里就在一一不贴图了。

springBoot整合 Jsp到这就结束了。

SringBoot整合Thymeleaf

该工程参考:

Thymeleaf介绍

Thymeleaf是个模板引擎,可以用于Web与非Web应用,它可以XML/XHTML/HTML5, JavaScript, CSS ,甚至文本文件。

Thymeleaf的使用

Thymeleaf这块个人使用不太熟练,这个也不是本篇文章主要讲述的内容,详细的可以查看官方文档。

开发准备

基本和上面的SringBoot整合Jsp差不多,这里就不再赘述了。

由于SpringBoot默认的模版引擎就是Thymeleaf,所以Maven 依赖这块只需要在原先的springBoot项目添加Thymeleaf的依赖就行。

org.springframework.boot
spring-boot-starter-thymeleaf

application.properties 配置这块,可以和之前的项目基本一致,需要注意的也只有spring.thymeleaf.cache配置,为false的时候是关闭Thymeleaf的缓存,更改界面之后会自动重启然后生效。

SringBoot整合Thymeleaf和SringBoot整合Jsp有个比较大的不同是,Thymeleaf的资源文件是放在src/main/resources目录下,Jsp的是放在src/main/webapp目录下。其中resources目录下的的static目录用于放置静态内容,比如css、js、jpg图片等。templates目录用于放置项目使用的页面模板,也就是.html文件。

它的项目结构图如下:

这里写图片描述

代码基本和SringBoot整合Jsp一致,这里就不在赘述了。

功能测试

启动该项目,在浏览器输入:

主界面:
这里写图片描述

修改用户数据之后的:

这里写图片描述

这里写图片描述

其它的功能也是可以实现的,这里就不再过多贴图了。

springBoot整合 Thymeleaf到这就结束了。

SpringBoot整合Jsp和Thymeleaf

注:这个是后来新加的一个项目。

SpringBoot单独整合JspThymeleaf都还好,没出现什么问题。但是在一起之后,就有了改变,因为SpringBoot默认的模板引擎是Thymeleaf,加上JSP之后,JSP的模板引擎并不会生效。但是如果想用JSP模板,此时的禁用到Thymeleaf,虽然可以通过多态更改配置实现,但是感觉太过麻烦了。于是研究了一下,找到了共存的方法。

和前面来两个项目区别如下:

  1. 之前的JspThymeleaf配置都是在application.properties

    文件中,这里我将它们的配置改到代码中获取。

    2.之前Thymeleaf相关文件是放在 src/main/resources 目录下,这里移动到WEB-INF目录下,和之前的jsp文件夹同级。

3.增加一个控制层,严格区分访问JspThymeleaf的路径。访问Jsp的路径前缀加上jsp,访问Thymeleaf前缀加上templates

那么新增的配置代码如下:

@Configuration@EnableWebMvc@ComponentScanpublic class WebConfig extends WebMvcConfigurerAdapter {       @Bean       public ViewResolver viewResolver() {           InternalResourceViewResolver resolver = new InternalResourceViewResolver();           resolver.setPrefix("/WEB-INF/");           resolver.setSuffix(".jsp");           resolver.setViewNames("jsp/*");           resolver.setOrder(2);           return resolver;       }       @Bean       public ITemplateResolver templateResolver() {           SpringResourceTemplateResolver templateResolver = new SpringResourceTemplateResolver();           templateResolver.setTemplateMode("HTML5");           templateResolver.setPrefix("/WEB-INF/");           templateResolver.setSuffix(".html");           templateResolver.setCharacterEncoding("utf-8");           templateResolver.setCacheable(false);           return templateResolver;       }       @Bean       public SpringTemplateEngine templateEngine() {           SpringTemplateEngine templateEngine = new SpringTemplateEngine();           templateEngine.setTemplateResolver(templateResolver());           return templateEngine;       }       @Bean       public ThymeleafViewResolver viewResolverThymeLeaf() {           ThymeleafViewResolver viewResolver = new ThymeleafViewResolver();           viewResolver.setTemplateEngine(templateEngine());           viewResolver.setCharacterEncoding("utf-8");           viewResolver.setViewNames(new String[]{"thymeleaf/*"});           viewResolver.setOrder(1);           return viewResolver;       }       @Override       public void configureDefaultServletHandling(DefaultServletHandlerConfigurer configurer) {           configurer.enable();       }       @Override       public void addResourceHandlers(ResourceHandlerRegistry registry) {           super.addResourceHandlers(registry);       }}

项目的结构图如下:

这里写图片描述

功能测试

在浏览器输入:

查看Thymeleaf模板的界面
这里写图片描述

在浏览器输入:

查看JSP模板的界面
这里写图片描述

可以看到已经成功整合了

其它

关于SpringBoot整合Jsp和Thymeleaf 到这里就结束了。

SpringBoot整合Jsp的项目工程地址:
SpringBoot整合Thymeleaf的项目工程地址:
SpringBoot整合Jsp和Thymeleaf的项目工程地址:

原创不易,如果感觉不错,希望给个推荐!您的支持是我写作的最大动力!

版权声明:
作者:虚无境
博客园出处:
CSDN出处:    
个人博客出处:

转载于:https://blog.51cto.com/12965378/2325684

你可能感兴趣的文章
cocos2d-js Shader系列4:Shader、GLProgram在jsb(native、手机)和html5之间的兼容问题。cocos2d-js框架各种坑。...
查看>>
jQuery 人脸识别插件,支持图片和视频
查看>>
今天学习的构造函数与字符串的详解
查看>>
JVM:从实际案例聊聊Java应用的GC优化
查看>>
让Team Foundation Server/TFS自动记住用户名密码解决方案
查看>>
3dmax 2012 贴图通道与uv通道,烘焙场景
查看>>
关于Git的暂存区这个概念的理解.
查看>>
/dev/shm和swap差别与联系
查看>>
[翻译svg教程]svg中矩形元素 rect
查看>>
【百度地图API】如何给自定义覆盖物添加事件
查看>>
linux—select具体解释
查看>>
《大公司病》阅读笔记
查看>>
grep命令參数及使用方法
查看>>
都能看懂的嵌入式linux/android alsa_aplay alsa_amixer命令行使用方法
查看>>
maven手动安装jar到本地仓库
查看>>
Android ActionBar中的下拉菜单
查看>>
浅谈JSON.stringify 函数与toJosn函数和Json.parse函数
查看>>
UML之部署图(Deployment Diagram)
查看>>
【转】Eclipse中查看jar包中的源码
查看>>
数据库索引的作用和优点缺点
查看>>