一、創建專案
1.File->new->project;

2.選擇“Spring Initializr”,點擊next;(jdk1.8默認即可)

3.完善專案資訊
組名可不做修改,專案名可做修改;最終建的專案名為:test,src->main->java下包名會是:com->example->test;點擊next;

4.Web下勾選Spring Web Start
,(網上創建springboot專案多是勾選Web選項,而較高版本的Springboot沒有此選項,勾選Spring Web Start即可,2.1.8版本是Spring Web);Template Englines勾選Thymeleaf;SQL勾選:MySQL Driver,JDBC API 和 MyBatis Framework三項;點擊next;

5.選擇專案路徑,點擊finish;打開新的視窗;

6.剛創建好的專案目錄結構

7.點擊右側的Maven,點擊設定(扳手圖示)進行專案Maven倉庫的配置;

8.配置maven
(1)選擇本地Maven路徑;(2)勾選組態檔后邊的選項,然后修改為本地Maven的組態檔,它會根據組態檔直接找到本地倉庫位置;

9.配置完后,如果沒有自動導包,可以點擊左上角重新導包按鈕,或者呢個下載按鈕,選擇下載所有源檔案和檔案

10.在templates檔案下新建index.html頁面,作為啟動的初始頁面;

11.在com.example.test下新建controller檔案夾
在controller檔案夾下建一個簡單的helloController類;(Controller類要添加@Controller注解,專案啟動時,SpringBoot會自動掃描加載Controller)

package com.example.news.controller;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
@Controller
public class IndexController {
//這里我是用登錄頁面來作為主頁
@RequestMapping("/")
public String index() {
return "/login";
}
}
12.在resources檔案夾下application中先配置DataSource基本資訊
application檔案有兩種檔案格式,一種是以.properties為后綴,一種是以.yml為后綴的,兩種配置方式略有差別,詳情可參考這個網址:https://blog.csdn.net/qq_29648651/article/details/78503853;在這我是用.yml后綴的檔案格式,右鍵application檔案選擇Refact,選擇Rename,將后綴改為yml;

yml代碼:
server:
port: 8081
servlet:
context-path: /
spring:
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://localhost:3306/examSystem?serverTimezone=Asia/Shanghai&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&useSSL=false&allowPublicKeyRetrieval=true
username: root
password: 123456
jackson:
date-format: yyyy-MM-dd HH:mm:ss
time-zone: GMT+8
serialization:
write-dates-as-timestamps: false
mybatis-plus:
configuration:
map-underscore-to-camel-case: true
auto-mapping-behavior: full
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
# mybatis-plus存放xml檔案的目錄
mapper-locations: classpath*:mybatis/*.xml
global-config:
# 邏輯洗掉配置
db-config:
# 洗掉前
logic-not-delete-value: 1
# 洗掉后
logic-delete-value: 0
13. 對專案啟動類做修改
package com.example.news;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
@MapperScan("com.example.news.mapper")
public class NewsApplication {
//在啟動的注解下面添加mapper掃描注解
public static void main(String[] args) {
SpringApplication.run(NewsApplication.class, args);
}
}
14.連接資料庫
在進行下一步撰寫時,我們先來鏈接一下資料庫;點擊右側的Database,點“加號”,新建資料庫鏈接;


15.填寫資料庫相關資訊,點擊Test Connection;

16.如果鏈接失敗可能是驅動的問題,點擊左上角的小扳手,進入資料庫設定界面

19.SpringBoot專案分層:
(1)DAO層:包括XxxMapper.java(資料庫訪問介面類),XxxMapper.xml(資料庫鏈接實作);(這個命名,有人喜歡用Dao命名,有人喜歡用Mapper,看個人習慣了吧)
(2)Bean層:也叫model層,模型層,entity層,物體層,就是資料庫表的映射物體類,存放POJO物件;
(3)Service層:也叫服務層,業務層,包括XxxService.java(業務介面類),XxxServiceImpl.java(業務實作類);(可以在service檔案夾下新建impl檔案放業務實作類,也可以把業務實作類單獨放一個檔案夾下,更清晰)
(4)Web層:就是Controller層,實作與web前端的互動,
依照上面四層,創建目錄結構如下:

pom.xml檔案:
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.4.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.example</groupId>
<artifactId>news</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>news</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</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-web</artifactId>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.1.3</version>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<optional>true</optional>
</dependency>
<!-- mybatis plus 代碼生成器 -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.2.0</version>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>3.2.0</version>
</dependency>
<dependency>
<groupId>org.freemarker</groupId>
<artifactId>freemarker</artifactId>
<version>2.3.28</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.47</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions><!-- 去掉springboot默認配置 -->
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency> <!-- 引入log4j2依賴 -->
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-log4j2</artifactId>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
20.撰寫自動生成代碼的類
package com.example.news.config;
import com.baomidou.mybatisplus.core.exceptions.MybatisPlusException;
import com.baomidou.mybatisplus.core.toolkit.StringUtils;
import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.config.*;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;
import java.util.Scanner;
/**
* 自動生成mybatisplus的相關代碼
*/
public class GeneratorCodeConfig {
public static String scanner(String tip) {
Scanner scanner = new Scanner(System.in);
StringBuilder help = new StringBuilder();
help.append("請輸入" + tip + ":");
System.out.println(help.toString());
if (scanner.hasNext()) {
String ipt = scanner.next();
if (StringUtils.isNotEmpty(ipt)) {
return ipt;
}
}
throw new MybatisPlusException("請輸入正確的" + tip + "!");
}
public static void main(String[] args) {
// 代碼生成器
AutoGenerator mpg = new AutoGenerator();
// 全域配置
GlobalConfig gc = new GlobalConfig();
String projectPath = System.getProperty("user.dir");
gc.setOutputDir(projectPath + "/src/main/java");
gc.setAuthor("astupidcoder");
gc.setOpen(false);
//物體屬性 Swagger2 注解
gc.setSwagger2(false);
mpg.setGlobalConfig(gc);
// 資料源配置
DataSourceConfig dsc = new DataSourceConfig();
dsc.setUrl("jdbc:mysql://49.232.18.90:3306/examSystem?serverTimezone=UTC&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&useSSL=false&allowPublicKeyRetrieval=true");
dsc.setDriverName("com.mysql.jdbc.Driver");
dsc.setUsername("root");
dsc.setPassword("wxw123456789");
mpg.setDataSource(dsc);
// 包配置
PackageConfig pc = new PackageConfig();
// pc.setModuleName(scanner("模塊名"));
pc.setParent("com.example.news");
pc.setEntity("model.auto");
pc.setMapper("mapper.auto");
pc.setService("service");
pc.setServiceImpl("service.impl");
mpg.setPackageInfo(pc);
// 自定義配置
// InjectionConfig cfg = new InjectionConfig() {
// @Override
// public void initMap() {
// // to do nothing
// }
// };
// 如果模板引擎是 freemarker
// String templatePath = "/templates/mapper.xml.ftl";
// 如果模板引擎是 velocity
// String templatePath = "/templates/mapper.xml.vm";
// 自定義輸出配置
// List<FileOutConfig> focList = new ArrayList<>();
// 自定義配置會被優先輸出
// focList.add(new FileOutConfig(templatePath) {
// @Override
// public String outputFile(TableInfo tableInfo) {
// // 自定義輸出檔案名 , 如果你 Entity 設定了前后綴、此處注意 xml 的名稱會跟著發生變化!!
// return projectPath + "/src/main/resources/mapper/" + pc.getModuleName()
// + "/" + tableInfo.getEntityName() + "Mapper" + StringPool.DOT_XML;
// }
// });
/*
cfg.setFileCreate(new IFileCreate() {
@Override
public boolean isCreate(ConfigBuilder configBuilder, FileType fileType, String filePath) {
// 判斷自定義檔案夾是否需要創建
checkDir("呼叫默認方法創建的目錄");
return false;
}
});
*/
// cfg.setFileOutConfigList(focList);
// mpg.setCfg(cfg);
// 配置模板
TemplateConfig templateConfig = new TemplateConfig();
// 配置自定義輸出模板
//指定自定義模板路徑,注意不要帶上.ftl/.vm, 會根據使用的模板引擎自動識別
// templateConfig.setEntity("templates/entity2.java");
// templateConfig.setService();
// templateConfig.setController();
templateConfig.setXml(null);
mpg.setTemplate(templateConfig);
// 策略配置
StrategyConfig strategy = new StrategyConfig();
strategy.setNaming(NamingStrategy.underline_to_camel);
strategy.setColumnNaming(NamingStrategy.underline_to_camel);
strategy.setSuperEntityClass("com.baomidou.mybatisplus.extension.activerecord.Model");
strategy.setEntityLombokModel(true);
strategy.setRestControllerStyle(true);
strategy.setEntityLombokModel(true);
// 公共父類
// strategy.setSuperControllerClass("com.baomidou.ant.common.BaseController");
// 寫于父類中的公共欄位
// strategy.setSuperEntityColumns("id");
strategy.setInclude(scanner("表名,多個英文逗號分割").split(","));
strategy.setControllerMappingHyphenStyle(true);
strategy.setTablePrefix(pc.getModuleName() + "_");
mpg.setStrategy(strategy);
mpg.setTemplateEngine(new FreemarkerTemplateEngine());
mpg.execute();
}
}
21. 打通整個流程
用剛剛撰寫的類運行會自動生成controller、service、mapper、model的java檔案
(1)撰寫物體類
package com.example.news.model.auto;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.extension.activerecord.Model;
import com.baomidou.mybatisplus.annotation.TableId;
import java.time.LocalDateTime;
import lombok.Data;
import lombok.EqualsAndHashCode;
import lombok.experimental.Accessors;
/**
* <p>
*
* </p>
*
* @author astupidcoder
* @since 2020-10-01
*/
@Data
@EqualsAndHashCode(callSuper = true)
@Accessors(chain = true)
public class TUser extends Model {
private static final long serialVersionUID = 1L;
@TableId(value = "id", type = IdType.AUTO)
private Long id;
/**
* 創建時間
*/
private LocalDateTime createTime;
/**
* 更新時間
*/
private LocalDateTime updateTime;
/**
* 洗掉狀態,默認為0:未洗掉 1:已洗掉
*/
private Integer deleteStatus;
/**
* 洗掉時間
*/
private LocalDateTime deleteTime;
/**
* 賬戶
*/
private String account;
/**
* 密碼
*/
private String pwd;
/**
* 賬戶型別 默認是0 0是管理員 1:教師 2:學生
*/
private Integer accountType;
}
(2)controller類
package com.example.news.controller;
import com.example.news.service.ITUserService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.RestController;
/**
* <p>
* 前端控制器
* </p>
*
* @author astupidcoder
* @since 2020-10-01
*/
@RestController
@RequestMapping("/user")
public class TUserController {
@Autowired
private ITUserService userService;
@RequestMapping("/login")
public String login(@RequestParam("username")String username,@RequestParam("password")String password){
if(userService.checkLogin(username,password)){
return "/success";
}else {
return "/error";
}
}
}
(3)service介面和實作類
package com.example.news.service;
import com.example.news.model.auto.TUser;
import com.baomidou.mybatisplus.extension.service.IService;
/**
* <p>
* 服務類
* </p>
*
* @author astupidcoder
* @since 2020-10-01
*/
public interface ITUserService extends IService<TUser> {
boolean checkLogin(String username, String password);
}
package com.example.news.service.impl;
import com.example.news.model.auto.TUser;
import com.example.news.mapper.TUserMapper;
import com.example.news.service.ITUserService;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
/**
* <p>
* 服務實作類
* </p>
*
* @author astupidcoder
* @since 2020-10-01
*/
@Service
public class TUserServiceImpl extends ServiceImpl<TUserMapper, TUser> implements ITUserService {
@Autowired
private TUserMapper userMapper;
@Override
public boolean checkLogin(String username, String password) {
TUser tUser = userMapper.getUserByUsername(username);
if(tUser==null || tUser.getPwd() == null){
return false;
}
if(tUser.getPwd().equals(password)){
return true;
}
return false;
}
}
(4)mapper介面
package com.example.news.mapper;
import com.example.news.model.auto.TUser;
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import org.apache.ibatis.annotations.Mapper;
/**
* <p>
* Mapper 介面
* </p>
*
* @author astupidcoder
* @since 2020-10-01
*/
public interface TUserMapper extends BaseMapper<TUser> {
TUser getUserByUsername(String username);
}
(5)撰寫xml檔案
<?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.news.mapper.TUserMapper">
<select id="getUserByUsername" parameterType="String" resultType="com.example.news.model.auto.TUser">
SELECT * FROM t_user WHERE account = #{username}
</select>
</mapper>
然后撰寫好前端代碼之后啟動springBoot的啟動類就OK啦,最后附上整個專案的結構圖

轉載請註明出處,本文鏈接:https://www.uj5u.com/qita/151191.html
標籤:其他
上一篇:String、StringBuilder和StringBuffer三者區別
下一篇:白琳大佬帶帶我0002選擇排序
