Spring Boot入门 and Spring Boot与ActiveMQ整合

1.Spring Boot入门

1.1什么是Spring Boot

Spring 诞生时是 Java 企业版(Java Enterprise EditionJEE,也称 J2EE)的轻量级代替品。无需开发重量级的 Enterprise JavaBeanEJB),Spring 为企业级Java 开发提供了一种相对简单的方法,经过依赖注入和面向切面编程,用简单的Java 对象(Plain Old Java ObjectPOJO)实现了 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

4Spring Boot 并非不对 Spring 功能上的加强,而是提供了一种快速使用 Spring 的方式。服务器

1.2 Spring Boot入门小Demo

1.2.1起步依赖

建立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后会自动把依赖传递过来。

1.2.2变动JDK版本

咱们发现默认状况下工程的JDK版本是1.6 ,而咱们一般用使用1.7的版本,因此咱们须要在pom.xml中添加如下配置

  <properties>   

    <java.version>1.7</java.version>

  </properties>

添加后更新工程,会发现版本已经变动为1.7

1.2.3引导类

只须要建立一个引导类 .

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容器

咱们直接执行这个引导类,会发现控制台出现的这个标识

 

你能不能看出来上边这个图是什么东西?

1.2.4 Spring MVC实现Hello World输出

咱们如今开始使用spring MVC框架,实现json数据的输出。若是按照咱们原来的作法,须要在web.xml中添加一个DispatcherServlet的配置,再添加一个spring的配置文件,配置文件中须要添加以下配置

    <!-- 使用组件扫描,不用将controllerspring中配置 -->

<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 便可看到运行结果

1.2.5修改tomcat启动端口

src/main/resources下建立application.properties

server.port=8088

从新运行引导类。地址栏输入

http://localhost:8088/info

1.2.6读取配置文件信息

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");

}

1.2.7热部署

咱们在开发中反复修改类、页面等资源,每次修改后都是须要从新启动才生效,这样每次启动都很麻烦,浪费了大量的时间,能不能在我修改代码后不重启就能生效呢?能够,在pom.xml中添加以下配置就能够实现这样的功能,咱们称之为热部署。

<dependency>  

    <groupId>org.springframework.boot</groupId>  

    <artifactId>spring-boot-devtools</artifactId>  

</dependency>  

赶快试试看吧,是否是很爽。

1.3 Spring BootActiveMQ整合

1.3.1使用内嵌服务

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的服务,因此咱们不用单独启动也能够执行应用程序。

1.3.2使用外部服务

src/main/resources下的application.properties增长配置, 指定ActiveMQ的地址

spring.activemq.broker-url=tcp://192.168.25.135:61616

运行后,会在activeMQ中看到发送的queue

 

1.3.3发送Map信息

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);

}

相关文章
相关标签/搜索