表示当前pom文件从spring-boot-starter-parent继承下来,在spring-boot-starter-parent中提供了很多默认配置,可以简化我们的开发。
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.4.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
<java.version>1.8</java.version>
<resource.delimiter>@</resource.delimiter>
<maven.compiler.source>${java.version}</maven.compiler.source>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<maven.compiler.target>${java.version}</maven.compiler.target>
</properties>
<properties>
<activemq.version>5.15.9</activemq.version>
<antlr2.version>2.7.7</antlr2.version>
<appengine-sdk.version>1.9.73</appengine-sdk.version>
<artemis.version>2.6.4</artemis.version>
...
</properties>
这样比如使用starter-web的时候就不需要指定版本号
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<version>2.1.4.RELEASE</version>
</dependency>
这时候将依赖管理的问题放到dependencyManagement中。
官网说明文档见:13.2.2 Using Spring Boot without the Parent POM
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>2.1.4.RELEASE</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
使用mvn package打包的plugin。
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
官网见:13.5 Starters
Starters are a set of convenient dependency descriptors that you can include in your application. You get a one-stop shop for all the Spring and related technologies that you need without having to hunt through sample code and copy-paste loads of dependency descriptors. For example, if you want to get started using Spring and JPA for database access, include the spring-boot-starter-data-jpa dependency in your project.
spring-boot-starter-*
thirdpartyproject-spring-boot-starter
查看其diagram,可以排除某个依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
<exclusions>
<exclusion>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
</exclusion>
</exclusions>
</dependency>
官网见:18. Using the @SpringBootApplication Annotation
等同于@EnableAutoConfiguration,@ComponentScan和@Configuration
官网见:23. SpringApplication
server.port=9090
application.yml
public class Person {
private String name;
private int age;
private Date birthday;
private String[] hobbies;
private IDCard idCard;
...
}
public class IDCard {
private int id;
private String number;
}
person:
name: Jack
age: 17
birthday: 1997/06/01
hobbies: [code,sing,share]
idCard:
id: 1
number: 111
@Component
@ConfigurationProperties(prefix="person")
@Autowired
private Person person;
如果Person类上报错,在Pom文件中加入如下依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-configuration-processor</artifactId>
</dependency>
官网见:90.2 Reload Templates without Restarting the Container
resources目录下有一个templates文件夹,可以将动态资源放到其中
<!--thymeleaf的jar包-->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
<html xmlns:th="http://www.thymeleaf.org">
<head>
</head>
<body>
<span style="color:red; font-size:30pt" th:text="${str}"></span>
</body>
@Controller
@RequestMapping("/gupao")
public class GupaoController {
@RequestMapping("/hello")
public String hello(Model model){
String str="hello spring boot";
//想要动态的显示在网页当中
model.addAttribute("str",str);
//接下来的页面是能够动态显示传过来的数据
return "test";
}
}
在resources目录下有一个static文件夹,可以将静态资源放到其中,浏览器可以直接访问。
"classpath:/META-INF/resources/"
"classpath:/resources/"
"classpath:/static/"
"classpath:/public/"
WebMvcAutoConfiguration--->WebMvcAutoConfigurationAdapter.addResourceHandlers(xxx)--->
this.resourceProperties.getStaticLocations()
return this.staticLocations;
private String[] staticLocations = CLASSPATH_RESOURCE_LOCATIONS;
private static final String[] CLASSPATH_RESOURCE_LOCATIONS = {
"classpath:/META-INF/resources/", "classpath:/resources/",
"classpath:/static/", "classpath:/public/" };
观察
@ConfigurationProperties(prefix = "spring.resources", ignoreUnknownFields = false)
public class ResourceProperties {
配置application.properties
spring.resources.static-locations=classpath:/gupao/
通过Spring Boot Web项目api接口的方式,整合MyBatis实现crud的操作。
重温一下web项目创建的过程。
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>1.3.1</version>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-thymeleaf</artifactId>
</dependency>
db_gupao_springboot--->t_user
public class User {
private int id;
private String username;
private String password;
private String number;
...
}
@Repository
@Mapper
public interface UserMapper {
User find(String username);
List<User> list();
int insert(User user);
int delete(int id);
int update(User user);
}
@Service
public class UserService {
@Autowired
public UserMapper userMapper;
public User findByUsername(String username){
return userMapper.find(username);
}
public List<User> listUser(){
return userMapper.list();
}
public int insertUser(User user){
return userMapper.insert(user);
}
public int updateUser(User user){
return userMapper.update(user);
}
public int delete(int id){
return userMapper.delete(id);
}
}
@RestController
@RequestMapping(value="/user",method = {RequestMethod.GET,RequestMethod.POST})
public class UserController {
@Autowired
private UserService userService;
@RequestMapping("/listone")
@ResponseBody
public User listOne(String username){
return userService.findByUsername(username);
}
@RequestMapping("/listall")
@ResponseBody
public List<User> listAll(){
return userService.listUser();
}
@RequestMapping(value="/add",method= RequestMethod.POST)
@ResponseBody
public String add(User user){
int result=userService.insertUser(user);
if(result>=1) {
return "添加成功";
}else{
return "添加失败";
}
}
@RequestMapping(value="/update",method= RequestMethod.POST)
@ResponseBody
public String update(User user){
int result=userService.updateUser(user);
if(result>=1) {
return "修改成功";
}else{
return "修改失败";
}
}
@RequestMapping(value="/delete",method= RequestMethod.GET)
@ResponseBody
public String delete(int id){
int result=userService.delete(id);
if(result>=1) {
return "删除成功";
}else{
return "删除失败";
}
}
}
<?xml version = "1.0" encoding = "UTF-8"?>
<!DOCTYPE mapper PUBLIC
"-//mybatis.org//DTD com.example.Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.csdn.springbootmybatis.dao.UserMapper">
<resultMap id="result" type="com.gupao.springbootmybatis.domain.User">
<result property="username" column="username"/>
<result property="password" column="password"/>
<result property="number" column="number"/>
</resultMap>
<select id="find" resultMap="result">
SELECT * FROM t_user where username=#{username}
</select>
<select id="list" resultMap="result">
SELECT * FROM t_user
</select>
<insert id="insert" parameterType="com.gupao.springbootmybatis.domain.User"
keyProperty="id" useGeneratedKeys="true">
INSERT INTO t_user
(
id,username,password,number
)
VALUES (
#{id},
#{username, jdbcType=VARCHAR},
#{password, jdbcType=VARCHAR},
#{number}
)
</insert>
<delete id="delete" parameterType="int">
delete from t_user where id=#{id}
</delete>
<update id="update" parameterType="com.gupao.springbootmybatis.domain.User">
update t_user set user.username=#{username},user.password=#{password},user.number=#{number} where user.id=#{id}
</update>
</mapper>
#数据源
spring:
datasource:
url: jdbc:mysql://127.0.0.1:3306/boot?useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC
username: root
password: 123456
driver-class-name: com.mysql.cj.jdbc.Driver
#mybatis托管mapper文件
mybatis:
mapper-locations: classpath:mapper/*.xml
http://localhost:8888/user/listone?username=Jack
http://localhost:8888/user/listall
http://localhost:8888/user/add?id=3&username=AAA&password=111111&number=300
http://localhost:8888/user/update?id=3&username=BBB
http://localhost:8888/user/delete?id=3
mvn -Dmaven.test.skip -U clean install
java -jar xxx.jar
<groupId>com.csdn</groupId>
<artifactId>springboot-demo2</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
https://www.youtube.com/watch?v=lhkwLtDIMHI&feature=youtu.be
BUILD ANYTHING WITH SPRING BOOT
Spring Boot is the starting point for building all Spring-based applications. Spring Boot is designed to get you up and running as quickly as possible, with minimal upfront configuration of Spring.
| | | | - | Get started in seconds using Spring Initializr | | - | Build anything: REST API, WebSocket, web, streaming, tasks, and more | | - | Simplified security | | - | Rich support for SQL and NoSQL | | - | Embedded runtime support: Tomcat, Jetty, and Undertow | | - | Developer productivity tools such as LiveReload and Auto Restart | | - | Curated dependencies that just work | | - | Production-ready features such as tracing, metrics, and health status | | - | Works in your favorite IDE: Spring Tool Suite, IntelliJ IDEA, and NetBeans |
group:com.example
artifact:bootiful
dependencies:Reactive Web,Reactive MongoDB,Lombok,Actuator,Security
Spring Data integrates seamlessly with SQL and NoSQL persistence stores. Spring Data supports reactive data access,too!
@Component
class DataWriter implements ApplicationRunner {
private final CustomerRepository customerRepository;
DataWriter(CustomerRepository customerRepository) {
this.customerRepository = customerRepository;
}
@Override
public void run(ApplicationArguments args) throws Exception {
Flux.just("Jack", "Rechal", "Richard", "Jobs")
.flatMap(name -> customerRepository.save(new Customer(null, name)))
.subscribe(System.out::println);
}
}
interface CustomerRepository extends ReactiveMongoRepository<Customer, String> {
}
@Document
@NoArgsConstructor
@Data
class Customer {
private String id,name;
public Customer(String id, String name) {
this.id = id;
this.name = name;
}
}
On the web,nobody knows you're a reactive microservice.
@SpringBootApplication
public class BootifulApplication {
@Bean
RouterFunction<ServerResponse> routes(CustomerRepository cr){
return RouterFunctions.route(GET("/customers"),serverRequest -> ok().body(cr.findAll(),Customer.class));
}
public static void main(String[] args) {
SpringApplication.run(BootifulApplication.class, args);
}
}
How's your app's health?Who better to articulate that then the application itself?
Spring Boot featurese strong opinions,loosely held. It's easy to change any of them with properties or pluggable implementations
management.endpoint.health.show-details=always
management.endpoints.web.exposure.exclude=*
@Bean
HealthIndicator healthIndicator(){
return () -> Health.status("I <3 Production").build();
}
访问:curl http://localhost:8080/actuator/health | jq
Effortlessly plugin authentication and authorization in a traditional or reactive application with Spring Security
@Bean
MapReactiveUserDetailsService users(){
return new MapReactiveUserDetailsService(User.withDefaultPasswordEncoder().username("user").password("pw").roles("USER").build());
}
访问:curl -vu user:pw http://localhost:8080/customers | jq
Let's provision a MongoDB instance,configure our application's route and MongoDB binding,and then push our application to production with Cloud Foundry.
命令切换到bootiful根目录下
cf services
定位到my-mongodb文件夹
image
image
image
image