EverydayOneCat
🎆tamaya🎇
Spring Boot入门
1.什么是Spring Boot
Spring 诞生时是 Java 企业版(Java Enterprise Edition,JEE,也称 J2EE)的轻量级代替品。无需开发重量级的 Enterprise JavaBean(EJB),Spring 为企业级Java 开发提供了一种相对简单的方法,通过依赖注入和面向切面编程,用简单的Java 对象(Plain Old Java Object,POJO)实现了 EJB 的功能。
虽然 Spring 的组件代码是轻量级的,但它的配置却是重量级的。一开始,Spring 用 XML 配置,而且是很多 XML 配置。Spring 2.5 引入了基于注解的组件扫描,这消除了大量针对应用程序自身组件的显式 XML 配置。Spring 3.0 引入了基于 Java 的配置,这是一种类型安全的可重构配置方式,可以代替 XML。所有这些配置都代表了开发时的损耗。因为在思考 Spring 特性配置和解决业务问题之间需要进行思维切换,所以写配置挤占了写应用程序逻辑的时间。和所有框架一样,Spring 实用,但与此同时它要求的回报也不少。
除此之外,项目的依赖管理也是件吃力不讨好的事情。决定项目里要用哪些库就已经够让人头痛的了,你还要知道这些库的哪个版本和其他库不会有冲突,这难题实在太棘手。并且,依赖管理也是一种损耗,添加依赖不是写应用程序代码。一旦选错了依赖的版本,随之而来的不兼容问题毫无疑问会是生产力杀手。
Spring Boot 让这一切成为了过去。
Spring Boot 是 Spring 社区较新的一个项目。该项目的目的是帮助开发者更容易的创建基于 Spring 的应用程序和服务,让更多人的人更快的对 Spring 进行入门体验,为 Spring 生态系统提供了一种固定的、约定优于配置风格的框架。
Spring Boot 具有如下特性:
(1)为基于 Spring 的开发提供更快的入门体验
(2)开箱即用,没有代码生成,也无需 XML 配置。同时也可以修改默认值来满足特定的需求。
(3)提供了一些大型项目中常见的非功能性特性,如嵌入式服务器、安全、指标,健康检测、外部配置等。
(4)Spring Boot 并不是不对 Spring 功能上的增强,而是提供了一种快速使用 Spring 的方式。
2.入门小Demo
2.1起步依赖
创建Maven工程 springboot_demo(打包方式jar)
在pom.xml中添加如下依赖
1 | <parent> |
我们的工程自动添加了好多好多jar包,这些jar包正式我们做开发时需要导入的jar包。因为这些jar包被我们刚才引入的spring-boot-starter-web所引用了,所以我们引用spring-boot-starter-web后会自动把依赖传递过来。
2.2变更JDK版本
我们发现默认情况下工程的JDK版本是1.6 ,而我们通常用使用1.7的版本,所以我们需要在pom.xml中添加以下配置
1 | <properties> |
添加后更新工程,会发现版本已经变更为1.7
2.3引导类
只需要创建一个引导类
1 |
|
简单解释一下,@SpringBootApplication其实就是以下三个注解的总和
@Configuration: 用于定义一个配置类
@EnableAutoConfiguration :Spring Boot会自动根据你jar包的依赖来自动配置项目。
@ComponentScan: 告诉Spring 哪个packages 的用注解标识的类 会被spring自动扫描并且装入bean容器。
我们直接执行这个引导类,会发现控制台出现的这个标识
2.4简单Controller层
我们直接写Controller类
1 |
|
我们运行启动类来运行程序:在浏览器地址栏输入 http://localhost:8080/info 即可看到运行结果
2.5修改tomcat启动端口
在src/main/resources下创建application.properties
1 | server.port=8088 |
重新运行引导类。地址栏输入http://localhost:8088/info
2.6读取配置文件信息
在application.properties 增加配置
1 | url=http://www.itcast.cn |
我要在类中读取这个配置信息,修改HelloWorldController
1 |
|
2.7热部署
我们在开发中反复修改类、页面等资源,每次修改后都是需要重新启动才生效,这样每次启动都很麻烦,浪费了大量的时间,能不能在我修改代码后不重启就能生效呢?可以,在pom.xml中添加如下配置就可以实现这样的功能,我们称之为热部署。
1 | <dependency> |
3.Spring Boot与ActiveMQ整合
3.1使用内嵌服务
在pom.xml中引入ActiveMQ起步依赖
1 | <dependency> |
创建消息生产者
1 | /** |
创建消息消费者
1 |
|
测试:启动服务后,在浏览器执行 http://localhost:8088/send.do?text=aaaaa
3.2使用外部服务
application.properties增加配置, 指定ActiveMQ的地址
1 | spring.activemq.broker-url=tcp://192.168.25.135:61616 |
短信解决方案
1.阿里大于简介
阿里大于是阿里云旗下产品,融合了三大运营商的通信能力,通过将传统通信业务和能力与互联网相结合,创新融合阿里巴巴生态内容,全力为中小企业和开发者提供优质服务阿里大于提供包括短信、语音、流量直充、私密专线、店铺手机号等个性化服务。通过阿里大于打通三大运营商通信能力,全面融合阿里巴巴生态,以开放API及SDK的方式向开发者提供通信和数据服务,更好地支撑企业业务发展和创新服务。
2.短信微服务
构建一个通用的短信发送服务(独立于品优购的单独工程),接收activeMQ的消息(MAP类型) 消息包括手机号(mobile)、短信模板号(template_code)、签名(sign_name)、参数字符串(param )
2.1工程搭建
创建工程itcast_sms (JAR工程),POM文件引入依赖
1 | <properties> |
创建配置文件application.properties
1 | server.port=9003 |
2.2短信工具类
创建短信工具类
1 | /** |
2.3消息监听类
创建SmsListener.java
1 |
|
3.用户注册
完成用户注册功能
3.1工程搭建
参照之前的搭建过程,依次创建用户服务接口层、用户服务实现层、用户中心WEB层
3.2基本注册功能实现
修改pinyougou-user-service的UserServiceImpl.java
1 | /** |
修改userController.js
1 | //控制层 |
4.注册判断短信验证码
4.1实现思路
点击页面上的”获取短信验证码”连接,向后端传递手机号。后端随机生成6位数字作为短信验证码,将其保存在redis中(手机号作为KEY),并发送到短信网关。
用户注册时,后端根据手机号查询redis中的验证码与用户填写的验证码是否相同,如果不同则提示用户不能注册。
4.2生成验证码
(1)修改pinyougou-user-interface工程UserService.java ,增加方法
1 | /** |
(2)修改pinyougou-user-service工程的UserServiceImpl.java
1 |
|
(3)添加工具类PhoneFormatCheckUtils.java,用于验证手机号
1 | package util; |
(4)修改pinyougou-user-web的UserController.java
1 | /** |
(5)pinyougou-user-web的userService.js
1 | //发送验证码 |
(6)pinyougou-user-web的userController.js
1 | //发送验证码 |
(7)修改页面register.html
1 | <a ng-click="sendCode()" >获取短信验证码</a> |
4.3用户注册判断验证码
(1)修改pinyougou-user-interface的UserService.java
1 | /** |
(2)修改pinyougou-user-service的 UserServiceImpl.java
1 | /** |
(3)修改pinyougou-user-web的UserController.java
1 | /** |
4.4短信验证码发送到手机
(1)在pinyougou-user-service添加配置文件applicationContext-activemq.xml
1 | <!-- 真正可以产生Connection的ConnectionFactory,由对应的 JMS服务厂商提供--> |
(2)修改pinyougou-user-service的UserServiceImpl.java
1 |
|
结语
又是迷茫的一周,保佑我六级能过啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊!!!