最近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/*.xml
spring:
#数据源
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;
@Repository
public interface UserDao {
Map<String, Object> getUsers();
}
mapper映射的xml
↓ 这个xml的位置建立在src/resource/mapper/下面,就和你之前在application.yml配置文件里配置的位置一样
注意:这里这个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>
加入扫描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;
@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";
}
}
视图层(Thymeleaf)
↓ 在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模版引擎展现在页面上了
↓ 数据库中的该数据
完!