项目地址:https://github.com/BruceZhangXL/wolf
这是一个完整的使用spring boot搭建的整合dubbo的项目
脚手架
构建:maven
基础:spring-boot
ORM:mybatis
数据库:MySQL
中间件:redis,rabbitMQ
项目结构脚手架
启动说明
找到wolf-web下的Application类,右击:run as:java application,当看到输出日志“---------WOLF IS READY---------”,即启动成功。
访问路径:http://localhost:8080/index 默认是8080端口,如何改默认端口,以及日志配置,数据库的配置,往下看。
wolf项目的说明
profile配置
spring boot项目的配置默认都在application.properties文件里,也即是wolf-web模块下的src/main/resources目录下的application.properties 但是,这些配置是和环境相关的,dev,test,prep,prod的配置是不同的,所以为了区分,spring boot提供了与maven的profile配合使用,我们放了 4个配置文件,分别对应这几个环境。同时你会发现application.properties依然存在,但是它里面只放了一些默认的配置。当你使用 mvn package -Dmaven.test.skip=true -Pdev打包的时候,这个默认的配置文件和application-dev.properties,这两个配置文件都会代入变量。
内置tomcat配置
都在application.properties文件中 端口server.port=8080
server.tomcat.accept-count=
server.tomcat.max-connections=
server.tomcat.max-http-post-size=0
server.tomcat.max-threads=0
server.tomcat.min-spare-threads=0
当然还有其他配置,可以查文档
数据源配置
以前的是需要单独的dataSource配置文件来配置数据源,现在只要在application-{profiles.active}.properties中配置数据源就好了 spring.datasource.driverClassName=com.mysql.jdbc.Driver spring.datasource.url=jdbc:mysql://127.0.0.1:3306/goodscenter?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull&useSSL=false
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.initialSize=10
spring.datasource.maxActive=30
spring.datasource.maxIdle=10
spring.datasource.maxWait=10000
必须要以spring开头,此时你一定会有疑问,如何指定特定的数据源比如c3p0,durid,当有多个数据源时怎么办,不用担心,这些spring boot都是支持的,只要稍微改动下 application.properties即可。
日志
使用logback,配置在src/main/resources目录下的logback-spring.xml 为啥叫logback-spring.xml,为啥不直接叫logback.xml,官方推荐是要携带spring的,直接叫 logback.xml也可以,但是spring boot可能无法将一些自有特性加上去。 此外,日志的级别,日志文件路径在application-{profiles.active}.properties中配置 ## log configuration logging.path=/Users/zhangxiaolong/Documents/logs
loggingLevel=DEBUG
与dubbo的融合
以前项目中会有一个dubbo.properties文件,里面内容如下 dubbo.spring.config=classpath*:/spring/spring-*.xml,classpath*:/spring_service/spring-*.xml 这样在触发dubbo的Main方法启动的时候,就能读到项目中的dubbo的consumer和provider的配置。 在spring boot项目中,延续使用了要通过xml来reference提供者,可怎么初始化这些配置文件呢? 配置文件放在了vms-rpc模块的src/main/resources目录下的dubbo文件夹中。 映射关系通过wolf-common模块下的DubboConfig类来映射。
与jsp的结合
在application.properties文件中定义了,如下一些配置
spring.mvc.view.prefix=/WEB-INF/jsp/
spring.mvc.view.suffix=.jsp
service层单元测试
可参考wolf-service模块下的src/java/test目录下的WolfIndexServiceTest类 注意:这种方式仍会启动spring容器,并不是纯粹的单元测试,如何mock,有待补充 为什么没有web层单元测试? 感觉没有必要,web层启动都这么简单了!
过滤器,拦截器,AOP
过滤器
待补充
拦截器
通过WolfWebMvcConfigurer类来扩展
AOP
在application.properties文件中增加如下配置
spring.aop.auto=true # 开启AOP 相当于注释 @EnableAspectJAutoProxy
spring.aop.proxy-target-class=true # 如果设置为true,意思是使用cglib的字节码方式生成代理类,为false则是使用java的动态代理来 如果使用cglib的方式,pom要增加依赖 org.springframework.boot spring-boot-starter-aop
事务控制
单库事务
VMS项目中,service模块单库事务控制已经开启,如需对某个方法加控制,方法上增加@Transactional 注解即可。
分布式事务
VMS项目使用默认的事务管理器DataSourceTransactionManager,所以暂不支持分布式事务。 但是我们可以通过手动配置,显示指定事务管理器为JtaTransactionManager来支持分布式事务。
Spring Security实现登录
cn.htd.vms.web.config.VmsWebSecurityConfig类实现了所有的登录相关的配置,资源访问限制,登录策略,登录成功后处理逻辑,登录失败后的逻辑,以及 登出策略等。
CSRF防范
CSRF攻击,如果你不了解,请自行百度。 spring security自带了对CSRF攻击的防范,使用_csrf的token机制。
当我们向后端发起POST请求,spring security会有拦截器识别本次请求中的token是否与后台session中的token一致,如果token不合法或者没有传递,则会响应403异常。 一般向后端提交POST请求有两种方式:
1 表单形式提交
需要在form表单元素中增加隐藏表单域,这两个值直接引用即可
2 ajax提交
vms项目中,已经在公共js中增加了在ajax请求头中传递csrf需要的token,在使用ajax方式请求时,按照ajax常规方式使用就可以了。
swagger
vms项目中集成了接口文档工具swagger,启动后,直接访问http://localhost:8080/swagger-ui.html#/就可以看到
将vms项目部署到外部tomcat
排除对内置tomcat依赖,修改wolf-web/pom.xml,排除spring-boot-starter-tomcat
为了保证,使用内置tomcat还是可以启动,手动依赖tomcat,并且周期范围是provider
修改启动main方法,继承SpringBootServletInitializer类,并覆写方法configure
以上三个步骤配置好后,即可使用tomcat8来部署,此时项目支持两种启动方式,一种是通过application的main方法启动,一种是通过外部tomcat启动
qq:597810804
网友评论