一、创建项目
1、选择Spring Initializr
2、为了提高项目构建效率,可以尝试修改阿里脚手架,地址如下:
https://start.aliyun.com
3、点击下一步
4、选择Web与spring Web,然后点击完成开始项目构建
5、项目构建完成如图所示
二、导入依赖
1、按照上面的步骤完成的打开pom.xml文件的配置依赖,如图在图中位置加入依赖库
2、 需要依赖的一些库
<!--springboot+mybatis的依赖-->
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.1.1</version>
</dependency>
<!--MySQL数据库驱动-->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<!--druid数据库连接池依赖-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid-spring-boot-starter</artifactId>
<version>1.2.8</version>
</dependency>
<!--Lombok依赖(可以配置也可以不用配置具体看自己)-->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
<!--fastjson-->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.78</version>
</dependency>
3、SpringBoot项目需要提供一个接口去拿到数据所有在这里我们需要能连接数据库的配置
三、配置Application
1、使用aplication.properties或者新建一个application.yml文件都可以
配置项目需要修改的端口号、datasource、mybatis。
server:
#设置端口号
port: 8081 #默认端口是8080
spring:
datasource:
#数据库用户名
username: root
#数据库用户密码
password: 123456
#serverTimezone=UTC 解决市区的报错 一般mysql是8.0以上的是必须配置这个
#userUnicode=true&characterEncoding=utf-8 指定字符编码、解码格式
url: jdbc:mysql://localhost:3306/metest?serverTimezone=UTC&userUnicode=true&characterEncoding=utf-8
#设置驱动类
driver-class-name: com.mysql.cj.jdbc.Driver
#设置数据源
type: com.alibaba.druid.pool.DruidDataSource
#Spring Boot 默认是不注入这些属性值的,需要自己绑定
#druid 数据源专有配置
initialSize: 5
minIdle: 5
maxActive: 20
maxWait: 60000
timeBetweenEvictionRunsMillis: 60000
minEvictableIdleTimeMillis: 300000
validationQuery: SELECT 1 FROM DUAL
testWhileIdle: true
testOnBorrow: false
testOnReturn: false
poolPreparedStatements: true
#配置监控统计拦截的filters,stat:监控统计、log4j:日志记录、wall:防御sql注入
#如果允许时报错 java.lang.ClassNotFoundException: org.apache.log4j.Priority
#则导入 log4j 依赖即可,Maven 地址:https://mvnrepository.com/artifact/log4j/log4j
filters: stat,wall,log4j
maxPoolPreparedStatementPerConnectionSize: 20
useGlobalDataSourceStat: true
connectionProperties: druid.stat.mergeSql=true;druid.stat.slowSqlMillis=500
# 配置mybatis
mybatis:
#指定pojo扫描包位置让mybatis自动扫描到指定义的pojo包下
type-aliases-package: com.me.test.pojo
#指定位置扫描Mapper接口对应的XML文件 classpath:xml文件位置
mapper-locations: classpath:mapper/*.xml
四、创建需要的mapper、service、cotroller层
五、创建数据库
spl语句代码
CREATE DATABASE /*!32312 IF NOT EXISTS*/`metest` /*!40100 DEFAULT CHARACTER SET utf8 */;
USE `metest`;
/*Table structure for table `userinfo` */
DROP TABLE IF EXISTS `userinfo`;
CREATE TABLE `userinfo` (
`id` int(10) NOT NULL AUTO_INCREMENT,
`username` varchar(30) NOT NULL,
`password` varchar(30) NOT NULL,
`authority` varchar(30) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
/*Data for the table `userinfo` */
insert into `userinfo`(`id`,`username`,`password`,`authority`) values (1,'root','123456','admin'),(2,'me','123456','admin');
执行完成后(也可以直接使用数据库可视化工具创建数据与数据库表)
一般来说pojo类、mapper接口、service接口名字都是按照数据库中表的名字来创建的
六、创建pojo类
package com.me.test.pojo;
import lombok.AllArgsConstructor;
import lombok.Data;
import lombok.NoArgsConstructor;
//使用@Data自动生成需要的get、set
@Data
//使用@AllArgsConstructor自动生成有参构造
@AllArgsConstructor
//使用@NoArgsConstructor自动生成无参构造
@NoArgsConstructor
public class UserInfo {
private Integer id;
private String username;
private String password;
private String authority;
}
七、创建mapper接口
package com.me.test.mapper;
import com.me.test.pojo.UserInfo;
import org.apache.ibatis.annotations.Mapper;
import org.springframework.stereotype.Repository;
import java.util.List;
@Repository
@Mapper
public interface UserInfoMapper {
/**
* 增加一条数据
* @param userInfo 数据
*/
void add(UserInfo userInfo);
/**
* 删除一条数据
* @param id 被删除数据的id
*/
void delete(Integer id);
/**
* 修改一条数据
* @param userInfo 修改的数据
*/
void update(UserInfo userInfo);
/**
* 根据id去查询一条数据
* @param id 查询的id
*/
UserInfo queryById(Integer id);
/**
* 查询全部数据
* @return
*/
List<UserInfo> queryAll();
}
八、创建对于mapper接口的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.me.test.mapper.UserInfoMapper">
<insert id="add" parameterType="UserInfo">
insert into metest.userinfo (username, password, authority)
values (#{username},#{password},#{authority});
</insert>
<delete id="delete" parameterType="Integer">
delete from metest.userinfo where id = #{id};
</delete>
<update id="update" parameterType="UserInfo">
update metest.userinfo set username=#{username},password=#{password},authority=#{authority}
where id=#{id};
</update>
<select id="queryById" parameterType="Integer" resultType="UserInfo">
select * from metest.userinfo where id=#{id};
</select>
<select id="queryAll" resultType="UserInfo">
select * from metest.userinfo;
</select>
</mapper>
九、创建service层
UserInfoService代码(其实其中的方法也就是Maper接口中拷贝来的)
public interface UserInfoService {
/**
* 增加一条数据
* @param userInfo 数据
*/
void add(UserInfo userInfo);
/**
* 删除一条数据
* @param id 被删除数据的id
*/
void delete(Integer id);
/**
* 修改一条数据
* @param userInfo 修改的数据
*/
void update(UserInfo userInfo);
/**
* 根据id去查询一条数据
* @param id 查询的id
*/
UserInfo queryById(Integer id);
/**
* 查询全部数据
* @return
*/
List<UserInfo> queryAll();
}
UserInfoServiceImpl代码(主要是做业务逻辑的)
有需要添加的功能可以直接在这一层添加修改
@Service
public class UserInfoServiceImpl implements UserInfoService {
@Autowired
private UserInfoMapper userInfoMapper;
@Override
public void add(UserInfo userInfo) {
userInfoMapper.add(userInfo);
}
@Override
public void delete(Integer id) {
userInfoMapper.delete(id);
}
@Override
public void update(UserInfo userInfo) {
userInfoMapper.update(userInfo);
}
@Override
public UserInfo queryById(Integer id) {
return userInfoMapper.queryById(id);
}
@Override
public List<UserInfo> queryAll() {
return userInfoMapper.queryAll();
}
}
十、创建controller层
我使用了RestFull风格去实现路径的请求
package com.me.test.cotroller;
import com.alibaba.fastjson.JSON;
import com.me.test.pojo.UserInfo;
import com.me.test.service.UserInfoService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.*;
import java.util.ArrayList;
import java.util.List;
//@Controller 控制层需要的注解
//@RestController 使用这个也是可以的,但是使用后他里面所有请求返回的都是字符串!
//一般只需要作为接口放回JSON格式数据的话推荐使用@RestController
//@Controller这个是可以与Thymeleaf模板引擎使用时可以返回一个页面的
@Controller
//@RequestMapping指定路径名
//@RequestMapping("/test")用这个来指定路径也是可以的
@RequestMapping(value = "/test")
public class UserInfoController {
//获取到UserInfoService
@Autowired
private UserInfoService userInfoService;
//Get请求
@GetMapping
//@ResponseBody 注释后表示放回的是字符串
@ResponseBody
public String queryAll(){
List<UserInfo> userInfoList = userInfoService.queryAll();
return JSON.toJSONString(userInfoList);
}
//使用了RestFull风格
@GetMapping("/{id}")
@ResponseBody
public String query(@PathVariable(value = "id")Integer id){
UserInfo userInfo = userInfoService.queryById(id);
List<UserInfo> userInfoList = new ArrayList<>();
userInfoList.add(userInfo);
return JSON.toJSONString(userInfoList);
}
//post请求
//@RequestBody 表示接收请求是JSON格式的数据
@PostMapping
@ResponseBody
public String add(@RequestBody UserInfo userInfo){
userInfoService.add(userInfo);
return "添加OK";
}
//Delete请求
@DeleteMapping(value = "/{id}")
@ResponseBody
public String delete(@PathVariable("id")Integer id){
userInfoService.delete(id);
return "删除成功";
}
//Put请求
@PutMapping("/{id}")
@ResponseBody
public String update(@PathVariable("id")Integer id,
@RequestBody UserInfo userInfo){
userInfo.setId(id);
userInfoService.update(userInfo);
return "修改成功";
}
}