最近SpringBoot做为微服务来讲挺火的,写这个也就是把学到的技术记下来,记录一下本身踩过的坑和一些建议。html
↓ jdk我是用1.8的,其余的都按照默认的来java
↓ 这里主要是修改你的项目名称和包名,你随便改改就知道规则了,这里反正就建一个demo,就不改了mysql
↓ 这里是选择你要整合的框架,到时候直接给你在maven的pom.xml里配好,若是不提早选好的话,到时候还要本身去配,麻烦,我这里的话就选好最基本的web和替代jsp的thymeleaf以及涉及到持久层和数据库的MySQL和MyBatisweb
↓ 而后就OK了spring
若是你本地没有提早准备好Maven库,就在pom.xml上右键Maven,Reimport一下sql
↓ 这个DemoApplication类就是咱们的SpringBoot项目的启动类,application.properties就是配置文件数据库
↓ 这里的配置文件能够是application.properties或者application.yml文件,我以为application.yml在视觉上更友好一点,因此我选择新建application.yml文件,原先的application.properties删除或者保留都没什么影响,其实application.yml在底层也是会被解析成application.properties的浏览器
注意:这里的数据源必定要配上,由于没有数据源配置的话SpringBoot会启动报错,由于咱们以前选了数据库方面的依赖,因此启动的时候会默认去链接数据库mybatis
mybatis: typeAliasesPackage: com.example.demo.entity #mapperLocations指的路径是src/main/resources mapperLocations: classpath:mapper/*.xml spring: #数据源 datasource: url: jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8 username: root password: 123456 driver-class-name: com.mysql.jdbc.Driver
package com.example.demo.dao; import org.springframework.stereotype.Repository; import java.util.Map; @Repository public interface UserDao { Map<String, Object> getUsers(); }
↓ 这个xml的位置创建在src/resource/mapper/下面,就和你以前在application.yml配置文件里配置的位置同样app
注意:这里这个dtd的头文件必定要加,否则启动会报错。
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.example.demo.dao.UserDao" > <select id="getUsers" resultType="java.util.Map" > SELECT * FROM TB_USER </select> </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); } }
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; @Controller public class TestController { @Autowired private UserDao userDao; @RequestMapping("/hi") public String hi(HttpServletRequest request) { /* 刚才的配置文件里没有配置Thymeleaf,由于SpringBoot默认是去src/main/resopurces/templates里找页面的, 至关于WEB-INF下面,也是要通过类转发的。 */ Map<String, Object> userMap = userDao.getUsers(); request.setAttribute("hi", userMap.get("NICKNAME")); return "hi"; } }
↓ 在src/main/resource/templates/下面新建hi.html文件(关于这个目录在上面Controller类中已经解释过了)
图里的动态模版用法和jsp差很少。
<!DOCTYPE html> <html xmlns:th="http://www.themeleaf.org"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <span th:text="${hi}"></span> </body> </html>
↓ 接下来,咱们启动SpringBoot项目,这里习惯用debug模式启动,其实run和debug对于本次启动来讲都同样
↓ 在浏览器中输入在Controller类中配置好的路径访问方法,访问成功,已经查询出数据库中的数据,并用Thymeleaf模版引擎展示在页面上了
↓ 数据库中的该数据
完!