在IDEA中使用SpringBoot整合MyBatis和Thymeleaf

        最近SpringBoot做爲微服務來講挺火的,寫這個也就是把學到的技術記下來,記錄一下本身踩過的坑和一些建議。html

        

在IDEA中建立SpringBoot項目

↓ jdk我是用1.8的,其餘的都按照默認的來java

↓ 這裏主要是修改你的項目名稱和包名,你隨便改改就知道規則了,這裏反正就建一個demo,就不改了mysql

↓ 這裏是選擇你要整合的框架,到時候直接給你在maven的pom.xml裏配好,若是不提早選好的話,到時候還要本身去配,麻煩,我這裏的話就選好最基本的web和替代jsp的thymeleaf以及涉及到持久層和數據庫的MySQL和MyBatisweb

↓ 而後就OK了spring

 

加載Maven依賴(已有Maven庫則跳過)

若是你本地沒有提早準備好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

 

寫代碼

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配置文件裏配置的位置同樣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>

加入掃描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模版引擎展示在頁面上了

↓ 數據庫中的該數據

完!

相關文章
相關標籤/搜索