spring boot介绍及使用详解
Spring Boot是由Pivotal团队提供的全新框架,其设计目的是用来简化新Spring应用的初始搭建以及开发过程。该框架使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。通过这种方式,Boot致力于在蓬勃发展的快速应用开发领域(rapid application development)成为领导者。
Spring boot的特点
- 创建独立的Spring应用程序
- 嵌入的Tomcat,无需部署WAR文件
- 简化Maven配置
- 自动配置Spring
- 提供生产就绪型功能,如指标,健康检查和外部配置
- 绝对没有代码生成和对 没有要求配置
Spring boot的优点
spring boot 可以支持你快速的开发出 restful 风格的微服务架构
自动化确实方便,做微服务再合适不过了,单一jar包部署和管理都非常方便。只要系统架构设计合理,大型项目也能用,加上nginx负载均衡,轻松实现横向扩展
spring boot 要解决的问题, 精简配置是一方面, 另外一方面是如何方便的让spring生态圈和其他工具链整合(比如redis, email, elasticsearch)
Spring boot的使用
1、maven配置文件
<? version="1.0" encoding="UTF-8"?>
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>org.springboot.sample</groupId><artifactId>spring-boot-sample</artifactId><version>0.0.1-SNAPSHOT</version><packaging>war</packaging><name>spring-boot-sample</name><de ion>Spring Boot Sample Web Application</de ion><parent> <groupId>org.spring work.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.3.2.RELEASE</version> <relativePath /> </parent><properties> <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding> <java.version>1.8</java.version></properties><dependencies> <dependency> <groupId>org.spring work.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- MYSQL --> <dependency> <groupId>mysql</groupId> <artifactId>mysql-connector-java</artifactId> </dependency> <!-- Spring Boot JDBC --> <dependency> <groupId>org.spring work.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency> <dependency> <groupId>org.spring work.boot</groupId> <artifactId>spring-boot-configuration-processor</artifactId> <optional>true</optional> </dependency></dependencies><build> <plugins> <plugin> <groupId>org.spring work.boot</groupId> <artifactId>spring-boot-maven-plugin</artifactId> </plugin> </plugins></build>2、application类
@SpringBootApplication
@ServletComponentScan
public class SpringBootApplication extends SpringBootServletInitializer {
private static final Logger logger = LoggerFactory.getLogger(SpringBootSampleApplication.class);public static void main(String[] args) { SpringApplication.run(SpringBootSampleApplication.class, args);}}
3、配置类
@Repository
@Component
@Configuration
public class MyWebAppConfigurer extends WebMvcConfigurerAdapter implements EnvironmentAware{
private static final Logger logger = LoggerFactory.getLogger(MyWebAppConfigurer.class);private RelaxedPropertyResolver propertyResolver;@Overridepublic void addInterceptors(InterceptorRegistry registry) { // 多个拦截器组成一个拦截器链 // addPathPatterns 用于添加拦截规则 // excludePathPatterns 用户排除拦截 registry.addInterceptor(new MyInterceptor1()).addPathPatterns("/**"); registry.addInterceptor(new MyInterceptor2()).addPathPatterns("/**"); super.addInterceptors(registry);}@Overridepublic void addResourceHandlers(ResourceHandlerRegistry registry) { registry.addResourceHandler("/res/**").addResourceLocations("classpath:/res/"); // 可以直接使用addResourceLocations 指定磁盘绝对路径,同样可以配置多个位置,注意路径写法需要加上file: registry.addResourceHandler("/imgs/**").addResourceLocations("file:D:/imgs/"); super.addResourceHandlers(registry);}}
4、添加filter
@WebFilter(filterName="myFilter",urlPatterns="/*")
public class MyFilter implements Filter {
@Overridepublic void destroy() { System.out.println("过滤器销毁");}@Overridepublic void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { System.out.println("执行过滤操作"); chain.doFilter(request, response);}@Overridepublic void init(FilterConfig config) throws ServletException { System.out.println("过滤器初始化");}}
5、controller
@RestController
@RequestMapping("/hello")
public class HelloController {
@RequestMapping("/info")public Map<String, String> getInfo(@RequestParam String name) { Map<String, String> map = new HashMap<>(); return map;} }
6、service
@Service
public class HelloWorldService {
public String getHelloMessage() { return "Hello world";}}
7、全局异常处理
@ControllerAdvice
public class GlobalExceptionHandler {
@ExceptionHandler(RuntimeException.class) @ResponseBody //在返回自定义相应类的情况下必须有,这是@ControllerAdvice注解的规定 public MyExceptionResponse exceptionHandler(RuntimeException e, HttpServletResponse response) { return resp; }}
说明:
@ControllerAdvice是controller的一个辅助类,最常用的就是作为全局异常处理的切面类
@ControllerAdvice可以指定扫描范围
@ControllerAdvice约定了几种可行的返回值,如果是直接返回model类的话,需要使用@ResponseBody进行json转换
1、返回String,表示跳到某个view
2、返回modelAndView
3、返回model + @ResponseBody
8、添加被其他配置使用的bean
@Bean
public PageHelper pageHelper(DataSource dataSource) {
PageHelper pageHelper = new PageHelper();return pageHelper;}
9、添加数据加载类
@Component
public class MyStartupRun implements CommandLineRunner {
@Overridepublic void run(String... args) throws Exception { System.out.println(">>>>>>>>>>>>>>>服务启动执行");}}
该组件在项目启动时会立即执行
作者:zecoo
来源:CSDN
原文:https://blog.csdn.net/king866/article/details/53996632
版权声明:本文为博主原创文章,转载请附上博文链接!
继续阅读与本文标签相同的文章
【译】数据湖正在成为新的数据仓库
-
跨域问题与SpringBoot解决方案
2026-05-24栏目: 教程
-
【Android电量】Battery Historian高级用法
2026-05-24栏目: 教程
-
【Android电量】Battery Historian耗电分析
2026-05-24栏目: 教程
-
[Android电量] 耗电信息统计服务battery / BatteryStats
2026-05-24栏目: 教程
-
[Android电量] 耗电概述 & 计算公式
2026-05-24栏目: 教程
