SpringBoot实战

SpringBoot精要

 SpringBoot的四个核心

    1.自动配置:针对很多Spring应用程序常见的应用功能,SpringBoot能自动提供相关配置。

      在任何Spring应用程序的源代码中,都可以找到java配置或XML配置,他们为应用程序开启了特定的特性和功能。

    2.起步依赖:告诉SpringBoot需要什么功能,他就能引入需要的库。

      SpringBoot起步依赖基本都以spring-boot-starter打头,随后是直接代表其功能的名字,比如web、test。

    3.命令行界面:这是SpringBoot的可选特性,借此你只需写代码就能完成完整的应用程序,无需传统项目构建。

    4.Actuator:让你能够深入运行中的SpringBoot应用程序,一探究竟。
      Spring应用程序上下文里配置的Bean
      SpringBoot的自动配置做的决策
      应用程序取到的环境变量、系统属性、配置属性和命令行参数
      应用程序里线程的当前状态
      应用程序最近处理过的HTTP请求的追踪情况
      各种和内存用量、垃圾回收、Web请求以及数据源用量的相关指标

  SpringBoot不是什么

    SpringBoot不是应用服务器

      SpringBoot可以把Web应用程序变为可自执行的JAR文件,不用部署到传统Java应用服务器里就能在命令行里运行。SpringBoot在应用程序里嵌入了一个Servlet容器(tomcat、Jetty或Undertow),以此实现这一功能。但这是内嵌的Servlet容器提供的功能,不是SpringBoot实现的。

    SpringBoot没有引入任何形式的代码生成,而是利用了Spring 4的条件化配置特性,以及Maven和Gradle提供的传递依赖解析,以此实现Spring应用程序上下文里的自动配置。

    Spring4.0对条件化配置提供了支持,根据应用程序的Classpath、环境和其他因素,运行时决策将使用哪些配置,忽略哪些配置。

    从本质上来说SpringBoot就是Spring,它做了那些没有它你自己也会做的Spring Bean配置。

  使用IEDA构建第一个SpringBoot应用

    File→newProject→SpringInitalizr

    项目创建完成后,你会看到如下图的项目结构

    

    整个项目遵循传统Maven或Gradle项目的布局,即主要应用程序代码位于src/main/java目录里,资源都在src/main/resource目录里,测试代码则在src/test/java目录里。

    ReadingListAppliaction.java : 应用程序的启动类(bootstrap class),也是主要的Spring配置类。

    Application.properties : 用于配置应用程序和SpringBoot的属性。

    RedingListApplicationTests.java : 一个基本的集成测试类。

  1.启动Spring

    ReadingListApplication在SpringBoot应用程序里有两个作用:配置和启动引导。首先,这是主要的Spring配置类。虽然SpringBoot的自动配置免除了很多Spring配置,但你还需要少量配置来启用自动配置。

    

    

    @SpringBootApplication开启了Spring的组件扫描和SpringBoot的自动配置功能。实际上,@SpringBootApplicationj将三个有用的注解组合在了一起。
      )1.Spring的@Configuration:标明该类使用Spring的基于Java的配置。
      )2.Spring的@ComponentScan:启用组件扫描,这样你写的Web控制器和其他组件才能被自动发现并注册为Spring应用上下文里的Bean。
      )3.SpringBoot的@EnableAutoConfiguration:开启了SpringBoot的自动配置
    要运行SpringBoot应用程序有几种方式,其中包含传统的war文件部署。但这里的main()方法可以让你在命令行里把该应用程序当作一个可执行的JAR文件来运行。这里想SpringApplication.run()传递了一个ReadingListApplication类的引用,还有命令行参数,通过这些东西启动应用程序。
    应用程序跑起来之后,会启动一个监听8080端口的Tomcat服务器。可以通过localhost:8080,但由于还没有写控制器类,你只会收到一个HTTP 404错误页面。

  2.测试SpringBoot应用

    RedingListApplicationTest不止是个用于测试的占位符,他还是一个例子,告诉你如何为SpringBoot应用程序编写测试。

    

    一个典型的Spring集成测试会用@ContextConfiguration注解标识如何加载Spring的应用程序上下文。但是,为了充分发挥SpringBoot的魔力,这里应该用@SpringApplication-Configuration注解。正如上图,ReadingListApplicationTests使用@SpringApplicationConfiguration注解从ReadingListApplication配置类里加载Spring应用程序上下文。

    ReadingListApplicationTest里还有一个简单的测试方法,即contextLoads()。实际上它是就是个空方法。但这个空方法足以证明应用程序上下文的加载没有问题。如果ReadingListApplication里定义的配置是好的,就能通过测试,如果有问题,测试就会失败。

  3.配置应用程序属性  

    Initializr为你生成的applicaiton.properties文件是一个空文件。实际上,这个文件完全是可选的,可以删除,对程序运行没有任何影响。
    我们现在可以在里面配置一些东西
    server.port= 8000
    加上这一行,嵌入式Tomcat的监听端口就变成了8000。
    这说明application.propeties文件可以很方便的帮你细粒度地调整SpringBoot的自动配置,还可以用它来指定应用程序代码所需的配置项。
    要注意的是,完全不用告诉SpringBoot为你加载application.propeties,只要它存在就会被加载,Spring和应用程序代码都能获取其中的属性。

  SpringBoot集成Mybatis

    在pom文件中加入Mybatis相关依赖:  

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>   

    在application.properties中加入:

spring.datasource.driver-class-name=com.mysql.jdbc.Driver
spring.datasource.url=jdbc:mysql://127.0.0.1:3306/successful_said?useSSL=false&useUnicode=true&characterEncoding=utf-8&zeroDateTimeBehavior=convertToNull&serverTimezone=Hongkong
spring.datasource.data-username=root
spring.datasource.data-password=root

    在启动类中加入:

@MapperScan("com.example.second.demosecond.dao")

    在src/main/resource目录下创建mapper文件(也可使用注解开发),并在mapper文件中创建userMapper.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.second.demosecond.dao.UserDao" >
    <resultMap id="BaseResultMap" type="com.example.second.demosecond.entity.User" >
        <id column="id" property="id" jdbcType="INTEGER" />
        <result column="name" property="userName" jdbcType="VARCHAR" />
        <result column="address" property="address" jdbcType="VARCHAR" />
    </resultMap>
    <sql id="Base_Column_List" >
        id, name, address
    </sql>
    <select id="selectUser" resultMap="BaseResultMap">
        select
        <include refid="Base_Column_List" />
        from user
    </select>
</mapper>

    其中, mapper标签的namespace属性对应的是你的Dao,resultMap的type属性对应的是你的JavaBean。

    在你的启动类的平级目录下创建Entity,Dao,Controller,Service四个文件夹,并编写相关代码,如下。

     )1.在Entity文件夹中创建JavaBean,编辑代码如下:

     

public class User {

    private String UserName;

    private Integer id;

    private String address;

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getAddress() {
        return address;
    }

    public void setAddress(String address) {
        this.address = address;
    }

    public String getUserName() {
        return UserName;
    }

    public void setUserName(String userName) {
        UserName = userName;
    }

}

      )2.在Dao文件夹中创建Dao,代码如下:

import java.util.List;

@Mapper
public interface UserDao {

    List<User>  selectUser();
}

      )3.在Controller文件中创建Controller,代码如下:

import com.example.second.demosecond.dao.UserDao;
import com.example.second.demosecond.entity.User;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.autoconfigure.EnableAutoConfiguration;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

import java.util.List;

@RestController
@EnableAutoConfiguration
@RequestMapping(value = "/boot")
public class BootController {

    @Autowired
    private UserDao userDao;
    @RequestMapping(value = "getUser")
    public User getUser()
    {
        User user=new User();
        user.setUserName("test");
        return user;
    }

    @RequestMapping(value = "getAllUser")
    public List<User> getUsers()
    {
        List<User> userList= userDao.selectUser();
        return userList;
    }
}

  SpringBoot对静态资源的映射规则

    所有/webjars/**,都去classpath:/META-INF/resoures/webjars/找资源;
    webjars:以jar包的方式引入静态资源;

    webjar的网站:https://www.webjars.org/

    maven中央仓库:https://mvnrepository.com/

    页面都放在resource/templates下

  SpringBoot整合Redis作为缓存

    1.引入Redis的相关依赖

 <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-redis</artifactId>
            <version>1.3.8.RELEASE</version>
        </dependency>

    2.在application.properties中配置Redis

application.properties中加入:
#Redis主机地址
spring.redis.host=

    3.测试

     我这里使用Spring内置的RedisTemplate(也可以使用jedis)

    @Autowired
    StringRedisTemplate stringRedisTemplate; //操作字符串

    @Autowired
    RedisTemplate redisTemplate; //key value

    新增一个字符串类型的值

stringRedisTemplate.opsForValue().append("msg","hello");

    读取

stringRedisTemplate.opsForValue().get("msg");

    新增一个List类型的值

        stringRedisTemplate.opsForList().leftPush("list","xiaoming");
        stringRedisTemplate.opsForList().leftPush("list","xiaohong");

    存入对象类型的数据

        User user=userDao.findUserById(1);
        redisTemplate.opsForValue().set("emp01",user);

  存入后可使用RedisDesktopManager这款工具来查看。

  你会发现,存入的数据为序列化后的(乱码),虽然不会影响正常的查询,下面个人提供两种解决方式:

    默认如果保存对象,使用JDK序列化机制,序列化后的数据保存到Redis中。

     将数据以JSON的方式保存

      1)自己将对象转换成JSON

      2)改变默认的序列化规则方式

        1.创建一个类

@Configuration
public class MyRedisConfig{
    @Bean
     public RedisTemplate(Object,User)UserRedisTemplate(RedisConnectionFacation redisConntionFacation) throws UnknownHostException{
        RedisTemplate<Object,User> template = new RedisTemplate();
        templcate.setConnectionFactory(redisConnectionFacatiory);
        Jackson2JsonRedisSerializer<User> userJackson2JsonRedisSerializer = new Jackson2JsonRedisSerializer<User>(User.class);
        template.setDefaultSerializer(userJackson2JsonRedisSerializer);
        return template;
  }
} 

      2.使用@Autowired注解将方法自动装配到controoler里

    @Autowired
    RedisTemplate<Object, User> UserRedisTemplate;

      3.测试使用

UserRedisTemplate.opsForValue().set("emp02",user);

  SpringBoot任务

      1.测试异步任务(在启动方法里还要 加上 @EnableAsync 注解 才可生效)

    @Async
    public void async(){
        try {
            Thread.sleep(3000);
        }catch (InterruptedException e){
            e.printStackTrace();
        }
        System.out.print("处理数据中...");
    }

    2.测试定时任务(在启动类里要加上 @EnableScheduling注解才可生效)

    @Scheduled(cron = "0,1,2,3,4 * * * * MON-SAT")
    public void scheduled(){
        System.out.print("定时发送...");
    }

    3.邮件任务

      1)邮件发送需要引入 spring-boot-starter-mail

      2)在appilcation.properties中配置邮箱

spring.mail.username=1242919235@qq.com
#pssword自己去邮箱里查看
spring.mail.password=
spring.mail.host=smtp.qq.com
#如果发送不出去(530)需使用以下配置
#spring.mail.properties.mail.smtp.ssl.enable=true

      3)测试

    @Autowired
    JavaMailSenderImpl javaMailSender;

    @Test
    public void email(){
        SimpleMailMessage message =new SimpleMailMessage();
        //邮件标题
        message.setSubject("今晚开会");
        //邮件内容
        message.setText("今晚7:30开会");
        //发给谁
        message.setTo("xfy19990101@163.com");
        //谁发的
        message.setFrom("1242919235@qq.com");
        javaMailSender.send(message);
    }

  SpringBoot简化开发 —— lombok

    引入lombok依赖

      <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>1.18.4</version>
        </dependency>

    lombok的一些注解

@NonNull : 注解在参数上, 如果该类参数为 null , 就会报出异常,  throw new NullPointException(参数名)

@Cleanup : 注释在引用变量前, 自动回收资源 默认调用 close() 方法

@Getter/@Setter : 注解在类上, 为类提供读写属性

@Getter(lazy=true) :

@ToString : 注解在类上, 为类提供 toString() 方法

@EqualsAndHashCode : 注解在类上, 为类提供 equals() 和 hashCode() 方法

@NoArgsConstructor, @RequiredArgsConstructor, @AllArgsConstructor : 注解在类上, 为类提供无参,有指定必须参数, 全参构造函数

@Data : 注解在类上, 为类提供读写属性, 此外还提供了 equals()、hashCode()、toString() 方法

@Value :

@Builder : 注解在类上, 为类提供一个内部的 Builder

@SneakThrows :

@Synchronized : 注解在方法上, 为方法提供同步锁

@Log :

@Log4j : 注解在类上, 为类提供一个属性名为 log 的 log4j 的日志对象

@Slf4j : 注解在类上, 为类提供一个属性名为 log 的 log4j 的日志对象

@AllArgsConstructor  生成一个无参构造

@NoArgdConstuctor    生成一个无参构造

    我们使用@Data注解就可以有以下注解的功能:
    @ToString
    @Getter
    @Setter
    @EqualsAnHashCode
    @NoArgsConstructor
    需要注意的是,同时使用@Data和@AllArgsConstructor后,默认的无藏构造函数失效,如果需要它,要需要设置@noArgsConstructor

  SpringBoot虚拟路径,物理路径的配置及跨平台时的解决方案

    1.application.properites 中配置

    

    2.添加WebMvcConfig工具类

    3.创建文件夹

    这样在不确定项目部署在什么平台下时,有两种选择方案,平台改变,只需修改配置文件即可。

  SpringBoot工程生产环境的发布

    1.打成Jar

      使用nohup java -jar text.jar > log.txt &命令启动工程

        log.txt : 用来存储日志,自动创建。
        & : 后台运行。
        java -jar : 系统环境变量配置的jre。
        nohup : 不挂断地运行命令,一般结合&使用。

    2.打成war(不推荐)

      1)修改pom文件

         <packaging>war</packaging>

      2)将SpringBoot默认的tomcat设置为provided

            <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-tomcat</artifactId>
            <scope>provided</scope>
        </dependency>

      3)Application启动类继承SpringBootServletInitializer

      4)claen package

      5)copy生成的war到tomcat的wabapps下,运行tomcat

      注:tomcat的版本必须是8及以上

原文地址:https://www.cnblogs.com/XiaFengyi/p/10387171.html

时间: 2024-10-28 11:49:45

SpringBoot实战的相关文章

SpringBoot实战 之 异常处理篇

在互联网时代,我们所开发的应用大多是直面用户的,程序中的任何一点小疏忽都可能导致用户的流失,而程序出现异常往往又是不可避免的,那该如何减少程序异常对用户体验的影响呢?其实方法很简单,对异常进行捕获,然后给予相应的处理即可.但实现的方式却有好多种,例如: try { ... } catch (Exception e) { doSomeThing(); } 像这种标准的 try-catch 是可以解决问题,但如果让你在每个接口实现里面都 try-catch 一下,我想你应该是不太愿意的.那么下面来介

重磅发布-SpringBoot实战实现分布式锁视频教程

概要介绍:历经一个月的时间,我录制的分布式锁实战之SpringBoot实战实现系列完整视频教程终于出世了!在本课程中,我分享介绍了分布式锁出现的背景.实现方式以及将其应用到实际的业务场景中,包括"重复提交"."CRM系统销售人员抢单",并采用当前相当流行的微服务SpringBoot来搭建项目实战实现分布式锁. 课程学习:目前博主已将分布式锁实现以及实际业务场景实战的要点整理成课程,感兴趣的童鞋可以前往学习:http://edu.51cto.com/course/15

SpringBoot实战实现分布式锁一之重现多线程高并发场景

实战前言:上篇博文我总体介绍了我这套视频课程:"SpringBoot实战实现分布式锁" 总体涉及的内容,从本篇文章开始,我将开始介绍其中涉及到的相关知识要点,感兴趣的小伙伴可以关注关注学习学习!!工欲善其事,必先利其器,介绍分布式锁使用的前因后果之前,得先想办法说清楚为啥需要分布式锁以及如何才需要将分布式锁搬上用场!!其中,该课程的学习链接:http://edu.51cto.com/course/15684.html感兴趣的童鞋可以前往观看学习!!! 实战概要:故而此文将介绍一下分布式

apollo客户端springboot实战(四)

1. apollo客户端springboot实战(四) 1.1. 前言 ??经过前几张入门学习,基本已经完成了apollo环境的搭建和简单客户端例子,但我们现在流行的通常是springboot的客户端,所以这章还是来学习下springboot客户端如何和apollo整合 ??接下来我来改造我自己的项目,我本来的项目接入的是spring config配置管理中心,读的git上的配置,它没有管理界面,功能也比较单一,所以我打算替换成apollo 1.2. 配置改动 添加配置类,这个@EnableAp

[书] SpringBoot(实战)

[书] SpringBoot(实战) <embed src="https://github.com/heyunxiong/books/raw/master/SpringBoot%E5%AE%9E%E6%88%98(%E7%AC%AC4%E7%89%88).pdf" type="application/pdf" width=800 height=800 /> 原文地址:https://www.cnblogs.com/seanho/p/11260374.ht

springboot实战(汪云飞)学习-1-2

java EE开发的颠覆者 spring boot 实战 随书学习-1 接上一篇,Java配置的学习(还是上一篇的项目中,添加新的包和代码): java配置是spring4.x推荐的配置方式,可以完全替代xml配置,也是springboot推荐的配置方式.Java 配置是通过@Configuration和@Bean来实现的. @Configuration 声明当前类是一个配置类 ,通过@ComponentScan 注解自动扫描指定包下的所有使用@Service @Component @Repos

springboot实战(汪云飞)学习-1-1

java EE开发的颠覆者 spring boot 实战 随书学习-1 1.学习案例都是maven项目,首先要在eclipse 中配置 maven,主要修改maven的配置文件:配置文件下载链接: https://github.com/liuch0228/springboot-wangyunfei-learn ,最主要的是修改镜像地址,这里使用阿里云的镜像: 1 <mirrors> 2 <!-- mirror 3 | Specifies a repository mirror site

消息中间件——RabbitMQ(十)RabbitMQ整合SpringBoot实战!(全)

前言 1. SpringBoot整合配置详解 publisher-confirms,实现一个监听器用于监听Broker端给我们返回的确认请求:RabbitTemplate.ConfirmCallback publisher-returns,保证消息对Broker端是可达的,如果出现路由键不可达的情况,则使用监听器对不可达的消息进行后续的处理,保证消息的路由成功:RabbitTemplate.ReturnCallback 注意一点,在发送消息的时候对template进行配置mandatory=tr

springboot实战:我们的第一款开源软件

在信息爆炸时代,如何避免持续性信息过剩,使自己变得专注而不是被纷繁的信息所累?每天会看到各种各样的新闻,各种新潮的技术层出不穷,如何筛选出自己所关心的? 各位看官会想,我们是来看开源软件的,你给我扯什么信息干嘛,别着急,听我慢慢道来. 背景 浏览器收藏夹应该是我们在收藏文章.网站的第一个利器,平时遇到喜欢的网站或者文章很方便的收藏到收藏夹中:很快我们的收藏夹就满了,于是就像我这样,创建文件夹来分组两层.三层都有: 有的也会借助百度首页导航这样的一些功能来整理自己收藏的网站,以前我记得QQ还有一款

SpringBoot实战总汇--详解

简介 Spring 诞生时是 Java 企业版(Java Enterprise Edition,JEE,也称 J2EE)的 轻量级代替品.无需开发重量级的 Enterprise JavaBean(EJB),Spring 为企业级 Java 开发提供了一种相对简单的方法,通过依赖注入和面向切面编程,用简单的Java 对象(Plain Old Java Object,POJO)实现了 EJB 的功能. springboot起步 1.添加依赖 在pom.xml中添加依赖 <parent> <g