最全面的SpringBoot框架学习
2017-10-11 15:47
627 查看
最全面的SpringBoot框架学习
Spring 介绍
SpringBoot简介
在您第1次接触和学习Spring框架的时候,是否因为其繁杂的配置而退却了?在你第n次使用Spring框架的时候,是否觉得一堆反复黏贴的配置有一些厌烦?那么您就不妨来试试使用Spring Boot来让你更易上手,更简单快捷地构建Spring应用!Spring Boot让我们的Spring应用变的更轻量化。比如:你可以仅仅依靠一个Java类来运行一个Spring引用。你也可以打包你的应用为jar并通过使用java -jar来运行你的Spring Web应用。
Spring Boot的主要优点:
为所有Spring开发者更快的入门
开箱即用,提供各种默认配置来简化项目配置
内嵌式容器简化Web项目
没有冗余代码生成和XML配置的要求
本章主要目标完成Spring Boot基础项目的构建,并且实现一个简单的Http请求处理,通过这
个例子对Spring Boot有一个初步的了解,并体验其结构简单、开发快速的特性。
系统要求
Java 7及以上Spring Framework 4.1.5及以上
本文采用Java 1.8.0_73、Spring Boot 1.3.2调试通过。
快速入门
创建一个Maven工程
名为”springboot-helloworld” 类型为Jar的工程项目:pom文件引入依赖
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.3.3.RELEASE</version> </parent> <dependencies> <!—SpringBoot web 组件 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> </dependencies>
spring-boot-starter-parent作用
在pom.xml中引入spring-boot-start-parent,spring官方的解释叫什么stater poms,它可以提供dependency management,也就是说依赖管理,引入以后在申明其它dependency的时候就不需要version了,后面可以看到。
spring-boot-starter-web作用
springweb 核心组件
spring-boot-maven-plugin作用
如果我们要直接Main启动spring,那么以下plugin必须要添加,否则是无法启动的。如果使maven 的spring-boot:run的话是不需要此配置的。(我在测试的时候,如果不配置下面的plugin也是直接在Main中运行的。)
编写HelloWorld服务
创建package命名为com.wangys.controller(根据实际情况修改)创建HelloController类,内容如下
@RestController @EnableAutoConfiguration public class HelloController { @RequestMapping("/hello") public String index() { return "Hello World"; } public static void main(String[] args) { SpringApplication.run(HelloController.class, args); } }
@RestController
RestController 表示修饰该Controller所有的方法返回JSON格式,直接可以编写Restful接口@RestController==@Controller +@ResponseBody
@EnableAutoConfiguration
注解:作用在于让 Spring Boot 根据应用所声明的依赖来对 Spring 框架进行自动配置这个注解告诉Spring Boot根据添加的jar依赖猜测你想如何配置Spring。由于spring-boot-starter-web添加了Tomcat和Spring MVC,所以auto-configuration将假定你正在开发一个web应用并相应地对Spring进行设置。
@SpringbootApplication
一个@SpringbootApplication
相当于
@Configuration,@EnableAutoConfiguration和 @ComponentScan
并具有他们的默认属性值
SpringApplication.run(HelloController.class, args);
标识为启动类SpringBoot启动方式1
Springboot默认端口号为8080@RestController @EnableAutoConfiguration public class HelloController { @RequestMapping("/hello") public String index() { return "Hello World"; } public static void main(String[] args) { SpringApplication.run(HelloController.class, args); } }
启动主程序,打开浏览器访问http://localhost:8080/index,可以看到页面输出Hello World
SpringBoot启动方式2
@ComponentScan(basePackages = “com.wangys.controller”)—控制器扫包范围@ComponentScan(basePackages = "com.wangys.controller") @EnableAutoConfiguration public class App { public static void main(String[] args) { SpringApplication.run(App.class, args); } }
Web开发
静态资源访问
在我们开发Web应用的时候,需要引用大量的js、css、图片等静态资源。默认配置
Spring Boot默认提供静态资源目录位置需置于classpath下,目录名需符合如下规则:
/static
/public
/resources
/META-INF/resources
举例:我们可以在src/main/resources/目录下创建static,在该位置放置一个图片文件。启动程序后,尝试访问http://localhost:8080/D.jpg。如能显示图片,配置成功。
全局捕获异常
@ExceptionHandler 注解声明异常处理方法@ControllerAdvice 是 controller 的一个辅助类,最常用的就是作为全局异常处理的切面类
@ControllerAdvice 可以指定扫描范围
@ControllerAdvice 约定了几种可行的返回值,如果是直接返回 model 类的话,需要使用@ResponseBody 进行 json 转换
o返回 String,表示跳到某个 view
o返回 modelAndView
o返回 model + @ResponseBody
@ControllerAdvice public class GlobalExceptionHandler { @ExceptionHandler(RuntimeException.class) @ResponseBody public Map<String, Object> exceptionHandler() { Map<String, Object> map = new HashMap<String, Object>(); map.put("errorCode", "101"); map.put("errorMsg", "系統错误!"); return map; } }
渲染Web页面
[b]渲染Web页面[/b]在之前的示例中,我们都是通过@RestController来处理请求,所以返回的内容为json对象。那么如果需要渲染html页面的时候,要如何实现呢?
[b]模板引擎[/b]
在动态HTML实现上Spring Boot依然可以完美胜任,并且提供了多种模板引擎的默认配置支持,所以在推荐的模板引擎下,我们可以很快的上手开发动态网站。
Spring Boot提供了默认配置的模板引擎主要有以下几种:
Thymeleaf
FreeMarker
Velocity
Groovy
Mustache
Spring Boot建议使用这些模板引擎,避免使用JSP,若一定要使用JSP将无法实现Spring Boot的多种特性,具体可见后文:支持JSP的配置
当你使用上述模板引擎中的任何一个,它们默认的模板配置路径为:
src/main/resources/templates。当然也可以修改这个路径,具体如何修改,可在后续各模板引擎的配置属性中查询并修改。
使用Freemarker模板引擎渲染web视图
[b]pom文件引入:[/b]<!-- 引入freeMarker的依赖包. --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-freemarker</artifactId> </dependency>
[b]后台代码[/b]
在src/main/resources/创建一个templates文件夹,后缀为*.ftl
@RequestMapping("/index") public String index(Map<String, Object> map) { map.put("name","美丽的天使..."); return "index"; }
[b]前台代码[/b]
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8" /> <title></title> </head> <body> ${name} </body> </html>
[b]Freemarker其他用法[/b]
@RequestMapping("/index") public String index(Map<String, Object> map) { map.put("name","###蚂蚁课堂###"); map.put("sex",1); List<String> userlist=new ArrayList<String>(); userlist.add("余胜军"); userlist.add("张三"); userlist.add("李四"); map.put("userlist",userlist); return "index"; }
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8" /> <title>首页</title> </head> <body> ${name} <#if sex==1> 男 <#elseif sex==2> 女 </#else> 其他 </#if> <#list userlist as user> ${user} </#list> </body> </html>
[b]Freemarker配置[/b]
新建application.properties文件
######################################################## ###FREEMARKER (FreeMarkerAutoConfiguration) ######################################################## spring.freemarker.allow-request-override=false spring.freemarker.cache=true spring.freemarker.check-template-location=true spring.freemarker.charset=UTF-8 spring.freemarker.content-type=text/html spring.freemarker.expose-request-attributes=false spring.freemarker.expose-session-attributes=false spring.freemarker.expose-spring-macro-helpers=false #spring.freemarker.prefix= #spring.freemarker.request-context-attribute= #spring.freemarker.settings.*= spring.freemarker.suffix=.ftl spring.freemarker.template-loader-path=classpath:/templates/ #comma-separated list #spring.freemarker.view-names= # whitelist of view names that can be resolved
使用JSP渲染Web视图
[b]pom文件引入以下依赖[/b]<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.3.3.RELEASE</version> </parent> <dependencies> <!-- SpringBoot 核心组件 --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-tomcat</artifactId> </dependency> <dependency> <groupId>org.apache.tomcat.embed</groupId> <artifactId>tomcat-embed-jasper</artifactId> </dependency> </dependencies>
[b]在application.properties创建以下配置[/b]
spring.mvc.view.prefix=/WEB-INF/jsp/ spring.mvc.view.suffix=.jsp
[b]后台代码[/b]
@Controller public class IndexController { @RequestMapping("/index") public String index() { return "index"; } }
相关文章推荐
- SpringBoot学习笔记-集成其他组件框架记录
- Spring Boot 框架 初识 学习一
- spring boot框架学习学前掌握之重要注解(1)-java配置方式
- spring boot框架学习2-spring boot核心(1)
- springboot学习: 初识Spring Boot框架,搭建第一个项目!
- spring boot框架学习6-spring boot的web开发(2)
- 使用 Spring Boot 快速构建 Spring 框架应用---学习笔记
- 深入学习微框架:Spring Boot
- springboot学习: 初识Spring Boot框架,搭建第一个项目!
- spring boot框架学习5-spring boot的web开发(1)
- spring boot框架学习8-【干货】spring boot的web开发(4)-自定义拦截器处理权限
- spring boot框架学习2-spring boot核心(1)
- Spring-boot学习(一):IntelliJ IDEA 搭建Spring-boot 框架HelloWorld
- spring boot框架学习4-spring boot核心(3)
- spring boot框架学习7-spring boot的web开发(3)-自定义消息转换器
- spring boot框架学习5-spring boot的web开发(1)
- spring boot框架学习8-【干货】spring boot的web开发(4)-自定义拦截器处理权限
- Spring Boot学习(一)——框架介绍
- 深入学习微框架:Spring Boot