一、項目創建
打開開發工具idea,按下圖截圖方式創建項目。
直接下一步
修改相關信息
這裏可以直接下一步不用選,後面直接修改pom.xml 文件即可。
項目創建完成,修改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.1.3.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>cn.mvapi</groupId>
<artifactId>xiaobao</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>xiaobao</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
<mybatis-plus.version>3.1.0</mybatis-plus.version>
<dynamic-datasource.version>2.5.4</dynamic-datasource.version>
<commons.fileupload.version>1.3.3</commons.fileupload.version>
<commons.io.version>2.5</commons.io.version>
<shiro.version>1.5.1</shiro.version>
<kaptcha.version>0.0.9</kaptcha.version>
<hutool.version>4.4.5</hutool.version>
<mybatis-plus-generator.version>3.1.0</mybatis-plus-generator.version>
<fastjson.version>1.2.31</fastjson.version>
<commons.version>3.8.1</commons.version>
</properties>
<dependencies>
<!--包括Tomcat和spring-webmvc。-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!--支持面向方面的編程即AOP,包括spring-aop和AspectJ。-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
<!--爲項目添加Redis依賴-->
<!-- <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-redis</artifactId>
</dependency>-->
<!--模板引擎-->
<!-- <dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-freemarker</artifactId>
</dependency>-->
<!--spring默認使用yml中的配置,但有時候要用傳統的xml或properties配置,就需要使用spring-boot-configuration-processor-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
<optional>true</optional>
</dependency>
<!--添加熱部署-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
<!-- 支持常規的測試依賴,包括JUnit、Hamcrest、Mockito以及spring-test模塊。-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<!--支持JDBC數據庫。-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<!--mybatisplus-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-extension</artifactId>
<version>${mybatis-plus.version}</version>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>${mybatis-plus.version}</version>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>dynamic-datasource-spring-boot-starter</artifactId>
<version>${dynamic-datasource.version}</version>
</dependency>
<!--mysql驅動-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>${mysql.version}</version>
</dependency>
<!-- 文件上傳組件-->
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>${commons.fileupload.version}</version>
</dependency>
<dependency>
<groupId>commons-io</groupId>
<artifactId>commons-io</artifactId>
<version>${commons.io.version}</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<!--工具-->
<dependency>
<groupId>cn.hutool</groupId>
<artifactId>hutool-all</artifactId>
<version>${hutool.version}</version>
</dependency>
<dependency>
<groupId>org.apache.shiro</groupId>
<artifactId>shiro-core</artifactId>
<version>${shiro.version}</version>
</dependency>
<dependency>
<groupId>org.apache.shiro</groupId>
<artifactId>shiro-spring</artifactId>
<version>${shiro.version}</version>
</dependency>
<!-- 圖形驗證碼生成工具-->
<dependency>
<groupId>com.github.axet</groupId>
<artifactId>kaptcha</artifactId>
<version>${kaptcha.version}</version>
</dependency>
<!--自動生成 getters, setters, equals, hashCode and toString, and more!-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<scope>provided</scope>
</dependency>
<!--代碼生成-->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-generator</artifactId>
<version>${mybatis-plus-generator.version}</version>
</dependency>
<!--模板引擎 代碼生成用-->
<dependency>
<groupId>org.freemarker</groupId>
<artifactId>freemarker</artifactId>
<version>${freemarker.version}</version>
</dependency>
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>${fastjson.version}</version>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
<version>${commons.version}</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
二、項目配置
編輯配置文件application.yml
spring:
profiles:
active: dev #對應loc表示本地,dev表示生產或者測試表的配置
新增application-dev.yml
# 項目相關配置
xiaobao:
# 名稱
name: spring boot
# 版本
version: 1.0.0
# 版權年份
copyrightYear: 2020
server: #配置服務
port: 8081 #配置服務端口
spring:
devtools:
restart:
enabled: true #熱部署啓用
datasource:
dynamic:
primary: master
datasource:
master:
username: root
password: 1234
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3306/githubspringboot?characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=GMT%2B8&nullCatalogMeansCurrent=true
slave_1:
username: root
password: 1234
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://127.0.0.1:3306/xiaobaoplus?characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=GMT%2B8&nullCatalogMeansCurrent=true
新增application-loc.yml,配置同上,也可以不要。
三、代碼生成配置
創建文件
Mybatis-Plus.properties
#此處爲本項目src所在路徑(代碼生成器輸出路徑)
OutputDir=D:\\mygithub\\springboot\\generator\\src\\main\\java
#mapper.xml的生成位置
OutputDirXml=D:\\mygithub\\springboot\\generator\\src\\main\\resources
#數據庫表名(此處切不可爲空,如果爲空,則默認讀取數據庫的所有表名)
#=sys_role
tableName=
#裝代碼的文件夾名
## F:\\xuan\\xiaobaoplus\\src\\main\\java\\cn\\mvapi\\xiaobaoplus\\xiaobaoplus\\test
className=
#設置作者
author=xiaobao
#自定義包路徑
#F:\\xuan\\xiaobaoplus\\src\\main\\java\\cn\\mvapi\\xiaobaoplus\\xiaobaoplus\\test
parent=cn.mvapi.xiaobao.common.system
#數據庫地址
url=jdbc:mysql://localhost:3306/githubspringboot?characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=false&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=GMT%2B8&nullCatalogMeansCurrent=true&tinyInt1isBit=false
userName=root
password=1234
創建生成代碼的類 CodeGenerate.java
package cn.mvapi.xiaobao.generator;
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.core.toolkit.StringPool;
import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.InjectionConfig;
import com.baomidou.mybatisplus.generator.config.*;
import com.baomidou.mybatisplus.generator.config.po.TableInfo;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
import com.baomidou.mybatisplus.generator.engine.FreemarkerTemplateEngine;
import java.util.ArrayList;
import java.util.List;
import java.util.ResourceBundle;
/**
* @author a1838
*/
public class CodeGenerate {
public static void main(String[] args) {
//用來獲取Mybatis-Plus.properties文件的配置信息
final ResourceBundle rb = ResourceBundle.getBundle("mybatis-plus");
// 代碼生成器
AutoGenerator mpg = new AutoGenerator();
// 全局配置
GlobalConfig gc = new GlobalConfig();
gc.setOutputDir(rb.getString("OutputDir"));
gc.setOpen(false);
gc.setBaseResultMap(true);
gc.setBaseColumnList(true);
gc.setAuthor(rb.getString("author"));
gc.setMapperName("%sDao");
gc.setXmlName("%sMapper");
gc.setServiceName("%sService");
gc.setServiceImplName("%sServiceImpl");
gc.setControllerName("%sController");
mpg.setGlobalConfig(gc);
// 數據源配置
DataSourceConfig dsc = new DataSourceConfig();
dsc.setDbType(DbType.MYSQL);
dsc.setUrl(rb.getString("url"));
dsc.setDriverName("com.mysql.cj.jdbc.Driver");
dsc.setUsername(rb.getString("userName"));
dsc.setPassword(rb.getString("password"));
mpg.setDataSource(dsc);
// 自定義配置
InjectionConfig cfg = new InjectionConfig() {
@Override
public void initMap() {
// to do nothing
}
};
List<FileOutConfig> focList = new ArrayList<>();
focList.add(new FileOutConfig("/templates/mapper.xml.ftl") {
@Override
public String outputFile(TableInfo tableInfo) {
// 自定義輸入文件名稱
return rb.getString("OutputDirXml") + "/mapper/" + rb.getString("className") + "/" + tableInfo.getEntityName() + StringPool.DOT_XML;
}
});
cfg.setFileOutConfigList(focList);
mpg.setCfg(cfg);
mpg.setTemplate(new TemplateConfig().setXml(null));
// 策略配置
StrategyConfig strategy = new StrategyConfig();
strategy.setNaming(NamingStrategy.underline_to_camel);
strategy.setColumnNaming(NamingStrategy.underline_to_camel);
strategy.setEntityLombokModel(true);
// strategy.setInclude(new String[]{rb.getString("tableName")});
// 包配置
PackageConfig pc = new PackageConfig();
// pc.setModuleName("test");
pc.setParent(rb.getString("parent"));// 自定義包路徑
/* pc.setController("controller."+rb.getString("className"));// 這裏是控制器包名,默認 web
pc.setEntity("model."+rb.getString("className"));
pc.setMapper("dao."+rb.getString("className"));
pc.setXml("mapping."+rb.getString("className"));
pc.setService("service."+rb.getString("className"));
pc.setServiceImpl("service."+rb.getString("className")+".impl");*/
mpg.setPackageInfo(pc);
mpg.setStrategy(strategy);
mpg.setTemplateEngine(new FreemarkerTemplateEngine());
mpg.execute();
}
}
四、啓動上面的類,將生成的代碼拷貝到項目裏面。
在項目啓動類上添加註解,包名填寫自己的
@MapperScan(basePackages = {"cn.mvapi.xiaobao.*"})
package cn.mvapi.xiaobao;
import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@MapperScan(basePackages = {"cn.mvapi.xiaobao.*"})
@SpringBootApplication
public class XiaobaoApplication {
public static void main(String[] args) {
SpringApplication.run(XiaobaoApplication.class, args);
System.out.println("啓動成功!");
}
}
添加一個測試的controller
package cn.mvapi.xiaobao.projecttest;
import cn.mvapi.xiaobao.common.system.entity.SysMenu;
import cn.mvapi.xiaobao.common.system.service.SysMenuService;
import cn.mvapi.xiaobao.common.system.service.impl.SysMenuServiceImpl;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import java.util.List;
@Controller
public class testController {
@Autowired
private SysMenuServiceImpl sysMenuService;
@ResponseBody
@RequestMapping("dbtest")
public List<SysMenu> dbtest(){
return sysMenuService.list();
}
}
訪問測試地址,能訪問到數據代表成功。
下一章:https://blog.csdn.net/qq_41780372/article/details/104926784
github地址:https://github.com/xiaobaos/springboot
碼雲地址:https://gitee.com/xiaobaomeat/springboot
項目優先更新到github上面。
下一章:shiro整合。