Spring 诞生时是 Java 企业版(Java Enterprise Edition,JEE,也称 J2EE)的轻量级代替品。无需开发重量级的 Enterprise JavaBean(EJB),Spring 为企业级Java 开发提供了一种相对简单的方法,经过依赖注入和面向切面编程,用简单的Java 对象(Plain Old Java Object,POJO)实现了 EJB 的功能。java
虽然 Spring 的组件代码是轻量级的,但它的配置倒是重量级的。一开始,Spring 用 XML 配置,并且是不少 XML 配置。Spring 2.5 引入了基于注解的组件扫描,这消除了大量针对应用程序自身组件的显式 XML 配置。Spring 3.0 引入了基于 Java 的配置,这是一种类型安全的可重构配置方式,能够代替 XML。全部这些配置都表明了开发时的损耗。由于在思考 Spring 特性配置和解决业务问题之间须要进行思惟切换,因此写配置挤占了写应用程序逻辑的时间。和全部框架同样,Spring 实用,但与此同时它要求的回报也很多。web
除此以外,项目的依赖管理也是件吃力不讨好的事情。决定项目里要用哪些库就已经够让人头痛的了,你还要知道这些库的哪一个版本和其余库不会有冲突,这难题实在太棘手。而且,依赖管理也是一种损耗,添加依赖不是写应用程序代码。一旦选错了依赖的版本,随之而来的不兼容问题毫无疑问会是生产力杀手。spring
Spring Boot 让这一切成为了过去。编程
Spring Boot 是 Spring 社区较新的一个项目。该项目的目的是帮助开发者更容易的建立基于 Spring 的应用程序和服务,让更多人的人更快的对 Spring 进行入门体验,为 Spring 生态系统提供了一种固定的、约定优于配置风格的框架。json
Spring Boot 具备以下特性:浏览器
(1)为基于 Spring 的开发提供更快的入门体验tomcat
(2)开箱即用,没有代码生成,也无需 XML 配置。同时也能够修改默认值来知足特定的需求。安全
(3)提供了一些大型项目中常见的非功能性特性,如嵌入式服务器、安全、指标,健康检测、外部配置等。springboot
(4)Spring Boot 并非不对 Spring 功能上的加强,而是提供了一种快速使用 Spring 的方式。服务器
建立Maven工程 springboot_demo(打包方式jar)
在pom.xml中添加以下依赖
<parent> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-parent</artifactId> <version>1.4.0.RELEASE</version> </parent> <dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> </dependencies> |
咱们会惊奇地发现,咱们的工程自动添加了好多好多jar包
........
而这些jar包正式咱们作开发时须要导入的jar包。由于这些jar包被咱们刚才引入的spring-boot-starter-web所引用了,因此咱们引用spring-boot-starter-web后会自动把依赖传递过来。
咱们发现默认状况下工程的JDK版本是1.6 ,而咱们一般用使用1.7的版本,因此咱们须要在pom.xml中添加如下配置
<properties> <java.version>1.7</java.version> </properties> |
添加后更新工程,会发现版本已经变动为1.7
只须要建立一个引导类 .
package cn.itcast.demo; import org.springframework.boot.SpringApplication; import org.springframework.boot.autoconfigure.SpringBootApplication; @SpringBootApplication public class Application { public static void main(String[] args) { SpringApplication.run(Application.class, args); } } |
简单解释一下,@SpringBootApplication其实就是如下三个注解的总和
@Configuration: 用于定义一个配置类
@EnableAutoConfiguration :Spring Boot会自动根据你jar包的依赖来自动配置项目。
@ComponentScan: 告诉Spring 哪一个packages 的用注解标识的类 会被spring自动扫描而且装入bean容器。
咱们直接执行这个引导类,会发现控制台出现的这个标识
你能不能看出来上边这个图是什么东西?
咱们如今开始使用spring MVC框架,实现json数据的输出。若是按照咱们原来的作法,须要在web.xml中添加一个DispatcherServlet的配置,再添加一个spring的配置文件,配置文件中须要添加以下配置
<!-- 使用组件扫描,不用将controller在spring中配置 --> <context:component-scan base-package="cn.itcast.demo.controller" /> <!-- 使用注解驱动不用在下边定义映射器和适配置器 --> <mvc:annotation-driven> <mvc:message-converters register-defaults="true"> <bean class="com.alibaba.fastjson.support.spring.FastJsonHttpMessageConverter"> <property name="supportedMediaTypes" value="application/json"/> <property name="features"> <array> <value>WriteMapNullValue</value> <value>WriteDateUseDateFormat</value> </array> </property> </bean> </mvc:message-converters> </mvc:annotation-driven> |
可是咱们用SpringBoot,这一切都省了。咱们直接写Controller类
package cn.itcast.demo.controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @RestController public class HelloWorldController { @RequestMapping("/info") public String info(){ return "HelloWorld"; } } |
咱们运行启动类来运行程序
在浏览器地址栏输入 http://localhost:8080/info 便可看到运行结果
在src/main/resources下建立application.properties
server.port=8088 |
从新运行引导类。地址栏输入
在src/main/resources下的application.properties 增长配置
url=http://www.itcast.cn |
我要在类中读取这个配置信息,修改HelloWorldController
@Autowired private Environment env;
@RequestMapping("/info") public String info(){ return "HelloWorld~~"+env.getProperty("url"); } |
咱们在开发中反复修改类、页面等资源,每次修改后都是须要从新启动才生效,这样每次启动都很麻烦,浪费了大量的时间,能不能在我修改代码后不重启就能生效呢?能够,在pom.xml中添加以下配置就能够实现这样的功能,咱们称之为热部署。
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-devtools</artifactId> </dependency> |
赶快试试看吧,是否是很爽。
(1)在pom.xml中引入ActiveMQ起步依赖
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-activemq</artifactId> </dependency> |
(2)建立消息生产者
/** * 消息生产者 * @author Administrator */ @RestController public class QueueController { @Autowired private JmsMessagingTemplate jmsMessagingTemplate;
@RequestMapping("/send") public void send(String text){ jmsMessagingTemplate.convertAndSend("itcast", text); } } |
(3)建立消息消费者
@Component public class Consumer { @JmsListener(destination="itcast") public void readMessage(String text){ System.out.println("接收到消息:"+text); } } |
测试:启动服务后,在浏览器执行
http://localhost:8088/send.do?text=aaaaa
便可看到控制台输出消息提示。Spring Boot内置了ActiveMQ的服务,因此咱们不用单独启动也能够执行应用程序。
在src/main/resources下的application.properties增长配置, 指定ActiveMQ的地址
spring.activemq.broker-url=tcp://192.168.25.135:61616 |
运行后,会在activeMQ中看到发送的queue
(1)修改QueueController.java
@RequestMapping("/sendmap") public void sendMap(){ Map map=new HashMap<>(); map.put("mobile", "13900001111"); map.put("content", "恭喜得到10元代金券"); jmsMessagingTemplate.convertAndSend("itcast_map",map); } |
(2)修改Consumer.java
@JmsListener(destination="itcast_map") public void readMap(Map map){ System.out.println(map); } |