博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
在IDEA中使用SpringBoot整合MyBatis和Thymeleaf
阅读量:6815 次
发布时间:2019-06-26

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

hot3.png

        最近SpringBoot作为微服务来说挺火的,写这个也就是把学到的技术记下来,记录一下自己踩过的坑和一些建议。

        

在IDEA中创建SpringBoot项目

↓ jdk我是用1.8的,其他的都按照默认的来

↓ 这里主要是修改你的项目名称和包名,你随便改改就知道规则了,这里反正就建一个demo,就不改了

↓ 这里是选择你要整合的框架,到时候直接给你在maven的pom.xml里配好,如果不提前选好的话,到时候还要自己去配,麻烦,我这里的话就选好最基本的web和替代jsp的thymeleaf以及涉及到持久层和数据库的MySQL和MyBatis

↓ 然后就OK了

 

加载Maven依赖(已有Maven库则跳过)

如果你本地没有提前准备好Maven库,就在pom.xml上右键Maven,Reimport一下

 

项目目录结构

↓ 这个DemoApplication类就是我们的SpringBoot项目的启动类,application.properties就是配置文件

 

编辑配置文件

↓ 这里的配置文件可以是application.properties或者application.yml文件,我觉得application.yml在视觉上更友好一点,所以我选择新建application.yml文件,原先的application.properties删除或者保留都没什么影响,其实application.yml在底层也是会被解析成application.properties的

注意:这里的数据源一定要配上,因为没有数据源配置的话SpringBoot会启动报错,因为我们之前选了数据库方面的依赖,所以启动的时候会默认去连接数据库

mybatis:  typeAliasesPackage: com.example.demo.entity  #mapperLocations指的路径是src/main/resources  mapperLocations: classpath:mapper/*.xmlspring:  #数据源  datasource:    url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8    username: root    password: 123456    driver-class-name: com.mysql.jdbc.Driver

 

写代码

mapper接口

package com.example.demo.dao;import org.springframework.stereotype.Repository;import java.util.Map;@Repositorypublic interface UserDao {    Map
getUsers();}

mapper映射的xml

↓ 这个xml的位置建立在src/resource/mapper/下面,就和你之前在application.yml配置文件里配置的位置一样

 注意:这里这个dtd的头文件一定要加,不然启动会报错。

加入扫描mapper接口的注解

↓ 在启动类中加入@MapperScan,相当于mapper自动注入,或者也可以在每个mapper接口上加@Mapper注解,但这样比较麻烦

package com.example.demo;import org.mybatis.spring.annotation.MapperScan;import org.springframework.boot.SpringApplication;import org.springframework.boot.autoconfigure.SpringBootApplication;@SpringBootApplication@MapperScan("com.example.demo.dao")// 扫描mapper接口public class DemoApplication {	public static void main(String[] args) {		SpringApplication.run(DemoApplication.class, args);	}}

Controller类

package com.example.demo.controller;import com.example.demo.dao.UserDao;import org.springframework.beans.factory.annotation.Autowired;import org.springframework.stereotype.Controller;import org.springframework.web.bind.annotation.RequestMapping;import javax.servlet.http.HttpServletRequest;import java.util.Map;@Controllerpublic class TestController {    @Autowired    private UserDao userDao;    @RequestMapping("/hi")    public String hi(HttpServletRequest request) {        /*            刚才的配置文件里没有配置Thymeleaf,因为SpringBoot默认是去src/main/resopurces/templates里找页面的,            相当于WEB-INF下面,也是要经过类转发的。        */        Map
userMap = userDao.getUsers(); request.setAttribute("hi", userMap.get("NICKNAME")); return "hi"; }}

 

视图层(Thymeleaf)

↓ 在src/main/resource/templates/下面新建hi.html文件(关于这个目录在上面Controller类中已经解释过了)

图里的动态模版用法和jsp差不多。

    
Title

 

运行项目

↓ 接下来,我们启动SpringBoot项目,这里习惯用debug模式启动,其实run和debug对于本次启动来说都一样

↓ 在浏览器中输入在Controller类中配置好的路径访问方法,访问成功,已经查询出数据库中的数据,并用Thymeleaf模版引擎展现在页面上了

↓ 数据库中的该数据

完!

转载于:https://my.oschina.net/NamiZone/blog/3014898

你可能感兴趣的文章
【Silverlight】Bing Maps学习系列(四):使用图钉层(Pushpin layer)及地图图层(MapLayer)...
查看>>
统一沟通-技巧-12-Lync-CX600-3000-5000-配置-internet
查看>>
Linux双机热备解决方案之Heartbeat
查看>>
angerfire宋杨的桌面秀
查看>>
Javascript模板引擎handlebars使用实例及技巧
查看>>
GoldenGate测试(七)
查看>>
动态访问DetailsView内的控件
查看>>
[珠玑之椟]位向量/位图的定义和应用
查看>>
数据对齐
查看>>
linux设置 让oracle10g自启动
查看>>
用JQuery给图片添加鼠标移入移出事件
查看>>
ALTER TABLE & ALTER TYPES
查看>>
Hadoop-调优剖析
查看>>
Mac前端抓包小工具Charles4.0下载
查看>>
用AHP层次分析法挑选最佳结婚对象
查看>>
Subversion安装手记
查看>>
Linux 获取设备树源文件(DTS)里描述的资源【转】
查看>>
Effective C++ 阅读笔记(二)public继承与继承中的函数覆盖
查看>>
什么是UV?
查看>>
Docker 容器测试全探索
查看>>