27.SPRINGBOOT 整合 THYMELEAF 做增删改查 CRUD和分页
运行 Application.java ,然后访问地址:
 
 
http://127.0.0.1:8080/thymeleaf/listCategory
 步骤 3 : 
表结构和数据
| 1 2 3 4 5 6 7 | create database how2java;use how2java;CREATE TABLE category_ (  id int(11) NOT NULL AUTO_INCREMENT,  name varchar(30),  PRIMARY KEY (id)) DEFAULT CHARSET=UTF8; | 
 步骤 5 : 
application.properties
增加数据库相关配置
 
#数据库
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/how2java?characterEncoding=UTF-8
spring.datasource.username=root
spring.datasource.password=admin
spring.datasource.driver-class-name=com.mysql.jdbc.Driver
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 | #thymeleaf 配置spring.thymeleaf.mode=HTML5spring.thymeleaf.encoding=UTF-8spring.thymeleaf.content-type=text/html#缓存设置为false, 这样修改之后马上生效,便于调试spring.thymeleaf.cache=false#上下文server.context-path=/thymeleaf#数据库spring.datasource.url=jdbc:mysql://127.0.0.1:3306/how2java?characterEncoding=UTF-8spring.datasource.username=rootspring.datasource.password=adminspring.datasource.driver-class-name=com.mysql.jdbc.Driver | 
 步骤 6 : 
pom.xml
修改pom.xml, 增加 jdbc,mybatis, pageHelper 的jar包
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 | <?xmlversion="1.0"encoding="UTF-8"?><projectxmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"    xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">    <modelVersion>4.0.0</modelVersion>  <groupId>com.how2java</groupId>  <artifactId>thymeleaf</artifactId>  <version>0.0.1-SNAPSHOT</version>  <name>thymeleaf</name>  <description>thymeleaf</description>  <packaging>war</packaging>      <parent>        <groupId>org.springframework.boot</groupId>        <artifactId>spring-boot-starter-parent</artifactId>        <version>1.5.9.RELEASE</version>    </parent>    <dependencies>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-web</artifactId>        </dependency>        <dependency>          <groupId>org.springframework.boot</groupId>          <artifactId>spring-boot-starter-thymeleaf</artifactId>        </dependency>        <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-starter-tomcat</artifactId>                    </dependency>        <dependency>              <groupId>junit</groupId>              <artifactId>junit</artifactId>              <version>3.8.1</version>              <scope>test</scope>        </dependency>        <!-- servlet依赖. -->        <dependency>              <groupId>javax.servlet</groupId>              <artifactId>javax.servlet-api</artifactId>                      </dependency>              <dependency>                     <groupId>javax.servlet</groupId>                     <artifactId>jstl</artifactId>              </dependency>        <!-- tomcat的支持.-->        <dependency>               <groupId>org.apache.tomcat.embed</groupId>               <artifactId>tomcat-embed-jasper</artifactId>                       </dependency>            <dependency>            <groupId>org.springframework.boot</groupId>            <artifactId>spring-boot-devtools</artifactId>            <optional>true</optional> <!-- 这个需要为 true 热部署才有效 -->        </dependency>           <!-- mybatis -->        <dependency>            <groupId>org.mybatis.spring.boot</groupId>            <artifactId>mybatis-spring-boot-starter</artifactId>            <version>1.1.1</version>        </dependency>        <!-- mysql -->        <dependency>            <groupId>mysql</groupId>            <artifactId>mysql-connector-java</artifactId>            <version>5.1.21</version>        </dependency>            <!-- pageHelper -->        <dependency>            <groupId>com.github.pagehelper</groupId>            <artifactId>pagehelper</artifactId>            <version>4.1.6</version>        </dependency>    </dependencies>    <properties>        <java.version>1.8</java.version>    </properties>    <build>        <plugins>            <plugin>                <groupId>org.springframework.boot</groupId>                <artifactId>spring-boot-maven-plugin</artifactId>            </plugin>        </plugins>    </build></project> | 
 步骤 7 : 
Category
增加实体类
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | packagecom.how2java.springboot.pojo; publicclassCategory {      privateintid;          privateString name;    publicintgetId() {        returnid;    }    publicvoidsetId(intid) {        this.id = id;    }    publicString getName() {        returnname;    }    publicvoidsetName(String name) {        this.name = name;    }      } | 
 步骤 8 : 
CategoryMapper
增加Mapper类
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 | packagecom.how2java.springboot.mapper; importjava.util.List; importorg.apache.ibatis.annotations.Delete;importorg.apache.ibatis.annotations.Insert;importorg.apache.ibatis.annotations.Mapper;importorg.apache.ibatis.annotations.Select;importorg.apache.ibatis.annotations.Update; importcom.how2java.springboot.pojo.Category; @MapperpublicinterfaceCategoryMapper {     @Select("select * from category_ ")    List<Category> findAll();         @Insert(" insert into category_ ( name ) values (#{name}) ")    publicintsave(Category category);         @Delete(" delete from category_ where id= #{id} ")    publicvoiddelete(intid);             @Select("select * from category_ where id= #{id} ")    publicCategory get(intid);           @Update("update category_ set name=#{name} where id=#{id} ")    publicintupdate(Category category); } | 
 步骤 9 : 
CategoryController
增加控制类
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 | packagecom.how2java.springboot.web;importjava.util.List;importorg.springframework.beans.factory.annotation.Autowired;importorg.springframework.stereotype.Controller;importorg.springframework.ui.Model;importorg.springframework.web.bind.annotation.RequestMapping;importorg.springframework.web.bind.annotation.RequestParam;importcom.github.pagehelper.PageHelper;importcom.github.pagehelper.PageInfo;importcom.how2java.springboot.mapper.CategoryMapper;importcom.how2java.springboot.pojo.Category;   @ControllerpublicclassCategoryController {    @AutowiredCategoryMapper categoryMapper;          @RequestMapping("/addCategory")    publicString listCategory(Category c) throwsException {        categoryMapper.save(c);        return"redirect:listCategory";    }    @RequestMapping("/deleteCategory")    publicString deleteCategory(Category c) throwsException {        categoryMapper.delete(c.getId());        return"redirect:listCategory";    }    @RequestMapping("/updateCategory")    publicString updateCategory(Category c) throwsException {        categoryMapper.update(c);        return"redirect:listCategory";    }    @RequestMapping("/editCategory")    publicString listCategory(intid,Model m) throwsException {        Category c= categoryMapper.get(id);        m.addAttribute("c", c);        return"editCategory";    }         @RequestMapping("/listCategory")    publicString listCategory(Model m,@RequestParam(value = "start", defaultValue = "0") intstart,@RequestParam(value = "size", defaultValue = "5") intsize) throwsException {        PageHelper.startPage(start,size,"id desc");        List<Category> cs=categoryMapper.findAll();        PageInfo<Category> page = newPageInfo<>(cs);        m.addAttribute("page", page);               return"listCategory";    }     } | 
 步骤 10 : 
PageHelperConfig
配置 PageHealper
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | packagecom.how2java.springboot.config; importjava.util.Properties; importorg.springframework.context.annotation.Bean;importorg.springframework.context.annotation.Configuration; importcom.github.pagehelper.PageHelper; @ConfigurationpublicclassPageHelperConfig {     @Bean    publicPageHelper pageHelper() {        PageHelper pageHelper = newPageHelper();        Properties p = newProperties();        p.setProperty("offsetAsPageNum", "true");        p.setProperty("rowBoundsWithCount", "true");        p.setProperty("reasonable", "true");        pageHelper.setProperties(p);        returnpageHelper;    }} | 
 步骤 11 : 
listCategory.html
增加和查询的页面 listCategory.html
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 | <!DOCTYPE HTML><htmlxmlns:th="http://www.thymeleaf.org"><head>    <title>hello</title>    <metahttp-equiv="Content-Type"content="text/html; charset=UTF-8"/></head><body><divstyle="width:500px;margin:20px auto;text-align: center">    <tablealign='center'border='1'cellspacing='0'>        <tr>            <td>id</td>            <td>name</td>            <td>编辑</td>            <td>删除</td>        </tr>        <trth:each="c:${page.list}">            <tdth:text="${c.id}"></td>            <tdth:text="${c.name}"></td>            <td><ath:href="@{/editCategory(id=${c.id})}">编辑</a></td>            <td><ath:href="@{/deleteCategory(id=${c.id})}">删除</a></td>        </tr>    </table>    <br/>    <div>            <ath:href="@{/listCategory(start=0)}">[首  页]</a>            <ath:href="@{/listCategory(start=${page.pageNum-1})}">[上一页]</a>            <ath:href="@{/listCategory(start=${page.pageNum+1})}">[下一页]</a>            <ath:href="@{/listCategory(start=${page.pages})}">[末  页]</a>    </div>    <br/>       <formaction="addCategory"method="post">          name: <inputname="name"/> <br/>    <buttontype="submit">提交</button>          </form></div></body></html> | 
 步骤 12 : 
editCategory.html
修改页面
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 | <!DOCTYPE HTML><htmlxmlns:th="http://www.thymeleaf.org"><head>    <title>hello</title>    <metahttp-equiv="Content-Type"content="text/html; charset=UTF-8"/></head><body><divstyle="margin:0px auto; width:500px">      <formaction="updateCategory"method="post">          name: <inputname="name"th:value="${c.name}"/> <br/>          <inputname="id"type="hidden"th:value="${c.id}"/>    <buttontype="submit">提交</button>          </form></div></body></html>  | 
 步骤 13 : 
重启测试
重新运行 Application.java 然后访问地址:
 
http://127.0.0.1:8080/thymeleaf/listCategory
下载地址:  http://download.how2j.cn/1779/thymeleaf.rar
 
                    
                     
                    
                 
                    
                 
                
            
         
 
         浙公网安备 33010602011771号
浙公网安备 33010602011771号