Spring Boot的设计目的是来简化新Spring应用的初始搭建以及开发过程,大大减少了代码量,通过这篇文章你可以清楚的看到。这是一个基于Spring Boot的简单demo,希望读者可以通过这篇文章大概能看懂这一个简单的框架搭建。后续我会陆续更新,微服务架构(Spring Boot、Spring Cloud)、分布式架构(Dobbo+Zookeeper)以及源码解析等相关的文章,感兴趣的话可以关注一下。
POM是项目对象模型(Project Object Model)的简称,它是Maven项目中的文件,使用XML表示,名称叫做pom.xml。作用类似ant的build.xml文件,功能更强大。该文件用于管理:源代码、配置文件、开发者的信息和角色、问题追踪系统、组织信息、项目授权、项目的url、项目的依赖关系等等。
<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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0modelVersion>
<groupId>com.boot.demogroupId>
<artifactId>bootdemoartifactId>
<version>0.0.1-SNAPSHOTversion>
<name>bootdemoname>
<description>Demo project for Spring Bootdescription>
<parent>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-starter-parentartifactId>
<version>2.0.6.RELEASEversion>
parent>
<properties>
<project.build.sourceEncoding>UTF-8project.build.sourceEncoding>
<project.reporting.outputEncoding>UTF-8project.reporting.outputEncoding>
<java.version>1.8java.version>
properties>
<dependencies>
<dependency>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-starter-webartifactId>
dependency>
<dependency>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-starter-testartifactId>
<scope>testscope>
dependency>
<dependency>
<groupId>org.mybatis.spring.bootgroupId>
<artifactId>mybatis-spring-boot-starterartifactId>
<version>1.3.2version>
dependency>
<dependency>
<groupId>tk.mybatisgroupId>
<artifactId>mapper-spring-boot-starterartifactId>
<version>2.0.4version>
dependency>
<dependency>
<groupId>mysqlgroupId>
<artifactId>mysql-connector-javaartifactId>
<version>8.0.13version>
dependency>
<dependency>
<groupId>org.projectlombokgroupId>
<artifactId>lombokartifactId>
<version>1.16.20version>
<scope>providedscope>
dependency>
<dependency>
<groupId>org.apache.tomcat.embedgroupId>
<artifactId>tomcat-embed-jasperartifactId>
dependency>
<dependency>
<groupId>javax.servletgroupId>
<artifactId>jstlartifactId>
dependency>
dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-maven-pluginartifactId>
plugin>
plugins>
build>
project>
Spring Boot配置文件有两种:application.yml和application.properties,作用是一样的,不过因为yml文件是树状结构,写起来有更好的层次感,更易于理解,所以很多人都选择了yml文件。
#配置数据源
spring:
datasource:
url: jdbc:mysql://localhost:3306/testdb?characterEncoding=utf8
username: root
password: root
driver-class-name: com.mysql.jdbc.Driver
mvc:
view:
prefix: /WEB-INF/
suffix: .jsp
#配置mybatis
mybatis:
typeAliasesPackage: com.boot.demo.bootdemo.domain
mapper-locations: classpath:mapper/*.xml
#配置mapper
mapper:
not-empty: false
identity: MYSQL
#配置Tomcat,配置80,可在浏览器访问项目时不用加端口号(默认端口8080)
server:
port: 80
Lombok能通过注解的方式,在编译时自动为属性生成构造器、getter/setter、equals、hashcode、toString方法。出现的神奇就是在源码中没有getter和setter方法,但是在编译生成的字节码文件中有getter和setter方法。这样就省去了手动重建这些代码的麻烦,使代码看起来更简洁些。
@Data
@Table(name = "user")
public class User {
@Id
@KeySql(useGeneratedKeys = true)
private Long id;
private String name;
private Date createDate;
}
Tkmybatis是在mybatis框架的基础上提供了很多工具,让开发更加高效。这个插件里面封装好了我们需要用到的很多sql语句,不过这个插件是通过我们去调用它封装的各种方法来实现sql语句的效果。对于单表查询不需要写SQL语句,这样就不用像mybatis那样每次写一个接口就要写一条sql语句。这样大大减少了我们的工作量。
public interface MyMapper<T> extends BaseMapper<T>, MySqlMapper<T> {
}
通用mapper可以极大的方便开发人员进行ORM,提供极其方便的单表增删改查。什么是通用mapper,一句话简单说,它就是个辅助mybatis极简单表开发的组件。它不是为了替代mybatis,而是让mybatis的开发更方便。例如:第三种方式。
@Mapper
public interface UserMapper extends MyMapper<User> {
//第一种方式,注解sql,方便,但维护性略差
@Select("select * from user")
List<User> selectAll();
//第二种方式,xml方式,易维护
int save(User user);
//第三种方式:通用mapper,本身提供了很多现成的增删改查sql,方法不在文件中体现;例如:int deleteByPrimaryKey()
}
<mapper namespace="com.boot.demo.bootdemo.mapper.UserMapper">
<insert id="save" parameterType="User" >
insert into user (id, name, create_date)
values (#{id}, #{name}, #{createDate})
insert>
mapper>
@Resource的作用相当于@Autowired,只不过@Autowired按byType自动注入,而@Resource默认按 byName自动注入罢了。@Resource有两个属性是比较重要的,分是name和type,Spring将@Resource注解的name属性解析为bean的名字,而type属性则解析为bean的类型。所以如果使用name属性,则使用byName的自动注入策略,而使用type属性时则使用byType自动注入策略。如果既不指定name也不指定type属性,这时将通过反射机制使用byName自动注入策略。
@Service
public class UserService {
@Resource
private UserMapper userMapper;
//第一种方式对应的Service
public List<User> listAll() {
return userMapper.selectAll();
}
//第二种方式对应的Service
public int saveUser(User user) {
return userMapper.save(user);
}
//第三种方式对应的Service,通用mapper,直接调用现成的增删改查sql
public int delUser(Long id) {
return userMapper.deleteByPrimaryKey(id);
}
}
@RestController注解相当于@ResponseBody + @Controller合在一起的作用。如果要返回json内容,就用@RestController,如果要返回到指定页面,就用@Controller。
@Controller
public class UserController {
@Resource
private UserService userService;
//第一种方式对应的Controller
@GetMapping(value = "/listUser")
@ResponseBody
public List<User> listAll() {
return userService.listAll();
}
//第二种方式对应的Controller
@PostMapping(value = "/saveUser")
@ResponseBody
public String saveUser(HttpServletRequest request) {
User user = new User();
user.setName(request.getParameter("username"));
user.setCreateDate(new Date());
return userService.saveUser(user)==1?"SUCCESS":"FAIL";
}
//第三种方式对应的Controller
@GetMapping(value = "/delUser")
@ResponseBody
public String delUser(HttpServletRequest request) {
Long id = Long.parseLong(request.getParameter("id"));
return userService.delUser(id)==1?"SUCCESS":"FAIL";
}
//跳转到主页
@GetMapping(value = "index")
public String index(){
return "index";
}
//跳转到登录页面
@GetMapping(value = "login")
public String login(){
return "login";
}
}
很简易的界面,大家可以好好写一下,相信你们比我写的界面好看多了,哈哈。
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>主页title>
head>
<body>
<form action="saveUser" method="post">
姓名:<input type="text" name="username"/>
<input type="submit" value="添加"/>
form>
body>
html>
@SpringBootApplication注解实际上是SpringBoot提供的一个复合注解。@SpringBootApplication = (默认属性)@Configuration + @EnableAutoConfiguration + @ComponentScan。(注意,@MapperScan要用的依赖包是tk.mybatis.spring.annotation.MapperScan,而不是 org.mybatis.spring.annotation.MapperScan,这是一个大坑!)。
package com.boot.demo.bootdemo;
import tk.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
@MapperScan("com.boot.demo.bootdemo.mapper")
public class BootdemoApplication {
public static void main(String[] args) {
SpringApplication.run(BootdemoApplication.class, args);
}
}
浏览器打开主页,http://localhost/index。
到此,从前端请求后端服务通了!有没有发现Spring Boot框架大大减少了代码量,感兴趣的话可以去学习下。
想要demo源码的可以留下邮箱地址。或者自行下载(Github地址)。