使用Intellij Idea+Gradle 搭建Java 本地开发环境

非常感谢 http://www.jianshu.com/p/25039d901ac2


项目搭建采用技术栈为:Spring+Spring MVC+Hibernate+Jsp+Gradle+tomcat+mysql5.6

搭建环境文档目录结构说明:

  1. 使用Intellj Idea 搭建项目过程详解
  2. 项目各配置文件讲解及部署
  3. 各层包功能讲解&项目搭建完毕最终效果演示图
  4. 项目中重要代码讲解
  5. webapp文件夹下分层详解
  6. 配置tomcat 运行环境

1. 使用Intellj Idea 搭建项目过程详解


1.1 打开Intellj Idea


Intellj idea 截图

1.2 操纵 Intellj Idea 工具栏 新建项目


操纵idea 工具栏

使用Gradle创建项目

完善项目信息

设置Gradle

确定项目信息

选择New Window

初始化项目结构截图

需要说明的是,最初创建的项目视图是不完整的,包括webapp文件夹下没有web.xml,以及src包下缺少Java文件夹(放置java源代码文件),Resources文件夹(放置项目配置文件)。
我们继续做以下操作,使得项目的结构符合web 应用项目的层级标准。


操纵工具栏为项目添加 web.xml全局配置文件

出现如下视图:


新建 web.xml文件

设置web.xml文件存储位置

接下来:单击main文件夹按照如下操作:


手动创建src中main文件夹下java目录

输入java 文件夹名称

点击ok,再按照上图操作操作一遍,输入文件名为resources
最终的结构图如下图所示:


项目最终结构图

2. 项目各配置文件讲解及部署


完成了项目的初始化结构创建,接下来我们需要来创建配置文件。
首先是resources文件夹下的配置文件
2.1 resources下资源文件截图:(最终配置的结果)


项目所需配置文件最终配置结果


2.2 data-access-applicationContext.xml
主要管理数据库访问组件

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
  4. xmlns:context = "http://www.springframework.org/schema/context"
  5. xsi:schemaLocation = "http://www.springframework.org/schema/beans
  6. http://www.springframework.org/schema/beans/spring-beans.xsd
  7. http://www.springframework.org/schema/context
  8. http://www.springframework.org/schema/context/spring-context.xsd
  9. " >
  10. <!-- 配置自动扫描的包 -->
  11. <context:component-scan base-package="com.fxmms" use-default-filters="false">
  12. <context:include-filter type="regex" expression="com.fxmms.*.*.dao.*"/>
  13. <context:include-filter type="regex" expression="com.fxmms.*.dao.*"/>
  14. </context:component-scan>
  15. <!-- 配置数据源 -->
  16. <context:property-placeholder location="classpath:db.properties"/>
  17. <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
  18. <property name="driverClassName" value="${jdbc.driverClass}"/>
  19. <property name="url" value="${jdbc.jdbcUrl}"/>
  20. <property name="username" value="${jdbc.user}"/>
  21. <property name="password" value="${jdbc.password}"/>
  22. </bean>
  23. <!--配置hibernate SessionFactory-->
  24. <bean id="sessionFactory"
  25. class = "org.springframework.orm.hibernate4.LocalSessionFactoryBean" >
  26. <property name="dataSource" ref="dataSource"> </property>
  27. <property name="hibernateProperties">
  28. <props>
  29. <prop key="hibernate.dialect">${dataSource.hibernate.dialect} </prop>
  30. <prop key="hibernate.show_sql">${dataSource.hibernate.show_sql} </prop>
  31. <prop key="hibernate.format_sql">true </prop>
  32. <!--负责自动创建数据表,基本上不能打开注释,否则所有的数据库中表信息都会被删除,重新创建-->
  33. <!-- <prop key="hibernate.hbm2ddl.auto">create</prop> -->
  34. </props>
  35. </property>
  36. <!-- <property name="hibernate.jdbc.batch_size" value="50"></property> -->
  37. <property name="packagesToScan">
  38. <list>
  39. <value>com.fxmms.*.*.domain </value>
  40. <value>com.fxmms.*.domain </value>
  41. </list>
  42. </property>
  43. </bean>
  44. <!--jdbcTemplate start -->
  45. <bean id="jdbcTemplate" class="org.springframework.jdbc.core.JdbcTemplate">
  46. <property name="dataSource" ref="dataSource"> </property>
  47. </bean>
  48. <!--Spring JDBC 中操作 LOB 数据 -->
  49. <bean id="lobHandler" class="org.springframework.jdbc.support.lob.DefaultLobHandler"
  50. lazy-init = "true" > </bean>
  51. <!-- 配置JPA部分 -->
  52. <!-- 配置JPA的EntityManagerFactory -->
  53. <!-- <bean id="entityManagerFactory"
  54. class="org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean">
  55. <property name="dataSource" ref="dataSource"></property>
  56. <property name="jpaVendorAdapter">
  57. <bean class="org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter"></bean>
  58. </property>
  59. <property name="packagesToScan" value="com.fxmms"></property>
  60. <property name="jpaProperties">
  61. <props>
  62. <prop key="hibernate.ejb.naming_strategy">org.hibernate.cfg.ImprovedNamingStrategy</prop>
  63. <prop key="hibernate.hbm2ddl.auto">update</prop>
  64. <prop key="hibernate.show_sql">true</prop>
  65. <prop key="hibernate.format_sql">true</prop>
  66. <prop key="hibernate.dialect">org.hibernate.dialect.MySQL5InnoDBDialect</prop>
  67. <prop key="hibernate.cache.use_second_level_cache">true</prop>
  68. <prop key="hibernate.cache.region.factory_class">org.hibernate.cache.ehcache.EhCacheRegionFactory
  69. </prop>
  70. <prop key="hibernate.cache.use_query_cache">true</prop>
  71. </props>
  72. </property>
  73. <!–使用二級緩存–>
  74. <property name="sharedCacheMode" value="ENABLE_SELECTIVE"></property>
  75. </bean>
  76. <!– 配置事务 –>
  77. <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
  78. <property name="entityManagerFactory" ref="entityManagerFactory"></property>
  79. </bean>-->
  80. <!-- <!– 配置SpringData部分 –>
  81. <jpa:repositories base-package="com.fxmms"
  82. entity-manager-factory-ref="entityManagerFactory">
  83. </jpa:repositories>-->
  84. </beans>

2.3 service-applicationContext.xml
主要管理业务逻辑组件,包括对数据库访问的事务控制,以及定时任务。

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
  4. xmlns:context = "http://www.springframework.org/schema/context"
  5. xmlns:aop = "http://www.springframework.org/schema/aop"
  6. xmlns:task = "http://www.springframework.org/schema/task"
  7. xmlns:tx = "http://www.springframework.org/schema/tx"
  8. xsi:schemaLocation = "http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans.xsd
  9. http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context.xsd
  10. http://www.springframework.org/schema/aop
  11. http://www.springframework.org/schema/aop/spring-aop.xsd
  12. http://www.springframework.org/schema/tx
  13. http://www.springframework.org/schema/tx/spring-tx.xsd
  14. http://www.springframework.org/schema/task
  15. http://www.springframework.org/schema/task/spring-task.xsd" >
  16. <aop:aspectj-autoproxy/>
  17. <!--设置定时任务-->
  18. <task:annotation-driven/>
  19. <context:component-scan base-package="com.fxmms.www" use-default-filters="false">
  20. <context:include-filter type="annotation" expression="org.springframework.stereotype.Service"/>
  21. </context:component-scan>
  22. <!-- enable the configuration of transactional behavior based on annotations -->
  23. <tx:annotation-driven transaction-manager="txManager"/>
  24. <bean id="txManager" class="org.springframework.orm.hibernate4.HibernateTransactionManager">
  25. <property name="sessionFactory" ref="sessionFactory"/>
  26. </bean>
  27. </beans>

2.4 default-servlet.xml
设置springmvc-applicationContext.xml,前端控制器将请求转发到相应的controller层中的处理方法上。

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
  4. xmlns:context = "http://www.springframework.org/schema/context"
  5. xmlns:mvc = "http://www.springframework.org/schema/mvc"
  6. xsi:schemaLocation = "http://www.springframework.org/schema/beans
  7. http://www.springframework.org/schema/beans/spring-beans.xsd
  8. http://www.springframework.org/schema/context
  9. http://www.springframework.org/schema/context/spring-context.xsd
  10. http://www.springframework.org/schema/mvc
  11. http://www.springframework.org/schema/mvc/spring-mvc.xsd" >
  12. <!---->
  13. <mvc:annotation-driven>
  14. <!--json解析-->
  15. <mvc:message-converters>
  16. <bean class="org.springframework.http.converter.StringHttpMessageConverter"/>
  17. <bean class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter"/>
  18. </mvc:message-converters>
  19. </mvc:annotation-driven>
  20. <context:component-scan base-package="com.fxmms.www.controller">
  21. <context:include-filter type="annotation" expression="org.springframework.stereotype.Controller"/>
  22. </context:component-scan>
  23. <!--因为web.xml中defaultDispatcherServlet对所有请求进行了拦截,所以对一些.css .jpg .html .jsp也进行了拦截,所以此配置项
  24. 保证对对静态资源不拦截-->
  25. <mvc:default-servlet-handler/>
  26. <!--视图解析器-->
  27. <bean id="viewResolver"
  28. class = "org.springframework.web.servlet.view.InternalResourceViewResolver" >
  29. <property name="prefix" value="/WEB-INF/views/"/>
  30. <property name="suffix" value=".jsp"/>
  31. </bean>
  32. <!--配置文件上上传-->
  33. <bean id="multipartResolver" class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
  34. <property name="defaultEncoding" value="utf-8"/>
  35. <property name="maxUploadSize" value="10485760000"/>
  36. <property name="maxInMemorySize" value="40960"/>
  37. </bean>
  38. </beans>

2.5 spring-security.xml
设置spring-security 权限控制配置文件,项目中权限的控制统一在此配置文件中配置,包括从数据库中获取用户的相关信息,以及配置相应pattern的请求过滤规则。

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <beans xmlns="http://www.springframework.org/schema/beans"
  3. xmlns:sec = "http://www.springframework.org/schema/security"
  4. xmlns:context = "http://www.springframework.org/schema/context"
  5. xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
  6. xsi:schemaLocation = "http://www.springframework.org/schema/beans
  7. http://www.springframework.org/schema/beans/spring-beans-3.2.xsd
  8. http://www.springframework.org/schema/context
  9. http://www.springframework.org/schema/context/spring-context.xsd
  10. http://www.springframework.org/schema/security
  11. http://www.springframework.org/schema/security/spring-security-3.2.xsd" >
  12. <!-- <sec:http pattern="/**/*.jpg" security="none"></sec:http>
  13. <sec:http pattern="/**/*.jpeg" security="none"></sec:http>
  14. <sec:http pattern="/**/*.gif" security="none"></sec:http>
  15. <sec:http pattern="/**/*.png" security="none"></sec:http>s
  16. <sec:http pattern="/getCode" security="none" /><!– 不过滤验证码 –>
  17. <sec:http pattern="/test/**" security="none"></sec:http><!– 不过滤测试内容 –>-->
  18. <!--spring security 权限管理配置文件-->
  19. <context:component-scan base-package="com.fxmms.common.security">
  20. </context:component-scan>
  21. <context:property-placeholder location="classpath:db.properties"> </context:property-placeholder>
  22. <!--权限控制-->
  23. <sec:http auto-config="true" use-expressions="true">
  24. <sec:intercept-url pattern="/superadmin/**" access="hasRole('superadmin')"/>
  25. <sec:intercept-url pattern="/admin/**" access="hasRole('admin')"/>
  26. <sec:intercept-url pattern="/customer/**" access="hasRole('customer')"/>
  27. <!--自定义登陆页面,权限验证失败页面,登录成功页面-->
  28. <sec:form-login login-page="/login.jsp" authentication-failure-url="/login.jsp" login-processing-url="/j_spring_security_check"
  29. authentication-success-handler-ref = "loginSuccessHandler" />
  30. <!--用户权限不一致出现的权限不可得情况,默认情况下跳转到403页面-->
  31. <sec:access-denied-handler ref="accessDeniedServletHandler" />
  32. <sec:logout logout-success-url="/login.jsp" />
  33. </sec:http>
  34. <sec:authentication-manager>
  35. <sec:authentication-provider>
  36. <!--配置从数据库查询用户权限 and isDelete = 0 and enable = 1-->
  37. <sec:jdbc-user-service data-source-ref="dataSource"
  38. users-by-username-query = "select userName,password,enable from mms_admin where userName=? and isDelete = 0 and enable = 1"
  39. authorities-by-username-query = "select userName,role from mms_admin where username=?"
  40. > </sec:jdbc-user-service>
  41. </sec:authentication-provider>
  42. </sec:authentication-manager>
  43. </beans>

2.6 db.properties
数据库访问配置文件

  1. jdbc.user=root
  2. jdbc.password=feixun* 123
  3. jdbc.driverClass=com.mysql.jdbc.Driver
  4. #jdbc.jdbcUrl=jdbc:mysql: //localhost/fxmms?useUnicode=true&characterEncoding=UTF-8
  5. jdbc.jdbcUrl=jdbc:mysql: //222.73.156.132:13306/fxmms?useUnicode=true&characterEncoding=UTF-8
  6. jdbc.initPoolSize= 5
  7. jdbc.maxPoolSize= 20
  8. dataSource.hibernate.dialect=org.hibernate.dialect.MySQL5Dialect
  9. #######################
  10. ## local ##
  11. #######################
  12. dataSource.hibernate.show_sql= true

2.7 log4j.properties
配置项目日志文件,日志输出模式为Console

  1. ###########################################################################
  2. # Properties file for the log4j logger system
  3. #
  4. # Note: During the uPortal build, the file at /properties/Logger.properties is copied
  5. # to the log4j standard location /WEB-INF/classes/log4j.properties . This means that editing the file
  6. # at /properties/Logger.properties in a deployed uPortal will have no effect.
  7. #
  8. # Please read the instructions for the Log4J logging system at
  9. # http: //jakarta.apache.org/log4j/ if you want to modify this.
  10. ###########################################################################
  11. # You should probably replace the word "debug" with "info" in the
  12. # following line after everything is running. This will turn off
  13. # the tons of debug messages, and leave only INFO, WARN, ERROR, etc.
  14. #
  15. log4j.rootLogger = info,stdout,D,E
  16. #配置stdout
  17. log4j.appender.stdout=org.apache.log4j.ConsoleAppender
  18. log4j.appender.stdout.Target=System.out
  19. log4j.appender.stdout.layout=org.apache.log4j.PatternLayout
  20. log4j.appender.stdout.layout.ConversionPattern=%d{yyyy-MM-dd HH\:mm\:ss,SSS} [%p]-[%l] %m%n
  21. #配置D 保存info debug级别的系统日志信息
  22. log4j.appender.D = org.apache.log4j.DailyRollingFileAppender
  23. #/Users/mark/mms/log.log 指定info debug级别日志信息存储位置
  24. log4j.appender.D.File = /Users/mark /mms/log.log
  25. log4j.appender.D.Append = true
  26. log4j.appender.D.Threshold = INFO,DEBUG
  27. log4j.appender.D.layout = org.apache.log4j.PatternLayout
  28. log4j.appender.D.layout.ConversionPattern = %d{yyyy-MM-dd HH\:mm\:ss,SSS} [%p]-[%l] %m%n
  29. #配置E 保存系统异常日志
  30. log4j.appender.E = org.apache.log4j.DailyRollingFileAppender
  31. #/Users/mark/mms/error.log 指定info debug级别日志信息存储位置
  32. log4j.appender.E.File = /Users/mark /mms/error.log
  33. log4j.appender.E.Append = true
  34. log4j.appender.E.Threshold = ERROR
  35. log4j.appender.E.layout = org.apache.log4j.PatternLayout
  36. log4j.appender.E.layout.ConversionPattern = %d{yyyy-MM-dd HH\:mm\:ss,SSS} [%p]-[%l] %m%n
  37. #log4j.logger.org.hibernate=INFO
  38. #
  39. ## Log all JDBC parameters
  40. #log4j.logger.org.hibernate.type=ALL
  41. ##Hibernate begin 打印每次数据访问产生的sql语句至log.log 文件当中##
  42. log4j.logger.org.hibernate=info
  43. #配置SQL打印与输出
  44. log4j.logger.org.hibernate.SQL=DEBG
  45. log4j.logger.org.hibernate.HQL=DEGUG
  46. #log4j.logger.org.hibernate.type=ALL

2.8 web.xml

  1. <?xml version="1.0" encoding="UTF-8"?>
  2. <web-app xmlns="http://xmlns.jcp.org/xml/ns/javaee"
  3. xmlns:xsi = "http://www.w3.org/2001/XMLSchema-instance"
  4. xsi:schemaLocation = "http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd"
  5. version = "3.1" >
  6. <!--配置需要加载的spring配置文件,这些文件中的配置的类都是被<context:component-scan>扫描到的,比如@Repository @Component
  7. @Service @Controller等-->
  8. <context-param>
  9. <param-name>contextConfigLocation </param-name>
  10. <param-value>classpath:data-access-applicationContext.xml;classpath:spring-security.xml;classpath:service-applicationContext.xml </param-value>
  11. </context-param>
  12. <!--配置日志监听 ,如果配置文件报红,没有关系可以正常运行,这个与idea的验证规则有关-->
  13. <context-param>
  14. <param-name>log4jConfigLocation </param-name>
  15. <param-value>classpath:log4j.properties </param-value>
  16. </context-param>
  17. <listener>
  18. <listener-class>org.springframework.web.util.Log4jConfigListener </listener-class>
  19. </listener>
  20. <listener>
  21. <listener-class>org.springframework.web.context.ContextLoaderListener </listener-class>
  22. </listener>
  23. <!--配置权限过滤器,注意必须配置在springmvc 之前,因为对用户访问资源的权限判断与控制是在访问特定url之前发生的-->
  24. <filter>
  25. <filter-name>springSecurityFilterChain </filter-name>
  26. <filter-class>org.springframework.web.filter.DelegatingFilterProxy </filter-class>
  27. </filter>
  28. <filter-mapping>
  29. <filter-name>springSecurityFilterChain </filter-name>
  30. <url-pattern>/* </url-pattern>
  31. </filter-mapping>
  32. <!-- 配置字符编码过滤器 必须配置在所有过滤器的最前面 -->
  33. <filter>
  34. <filter-name>CharacterEncodingFilter </filter-name>
  35. <filter-class>org.springframework.web.filter.CharacterEncodingFilter </filter-class>
  36. <init-param>
  37. <param-name>encoding </param-name>
  38. <param-value>UTF-8 </param-value>
  39. </init-param>
  40. <init-param>
  41. <param-name>forceEncoding </param-name>
  42. <param-value>true </param-value>
  43. </init-param>
  44. </filter>
  45. <filter-mapping>
  46. <filter-name>CharacterEncodingFilter </filter-name>
  47. <url-pattern>/* </url-pattern>
  48. </filter-mapping>
  49. <!--超级管理员 -->
  50. <!-- <filter>
  51. <filter-name>superAdminFilter</filter-name>
  52. <filter-class>com.fxmms.filter.SuperAdminFilter</filter-class>
  53. </filter>
  54. <filter-mapping>
  55. <filter-name>superAdminFilter</filter-name>
  56. <url-pattern>/fxmms/superadmin/*</url-pattern>
  57. </filter-mapping>
  58. <filter>
  59. <filter-name>adminFilter</filter-name>
  60. <filter-class>com.fxmms.filter.AdminFilter</filter-class>
  61. </filter>
  62. <filter-mapping>
  63. <filter-name>adminFilter</filter-name>
  64. <url-pattern>/fxmms/admin/*</url-pattern>
  65. </filter-mapping>
  66. <filter>
  67. <filter-name>customerFilter</filter-name>
  68. <filter-class>com.fxmms.filter.CustomerFilter</filter-class>
  69. </filter>
  70. <filter-mapping>
  71. <filter-name>customerFilter</filter-name>
  72. <url-pattern>/fxmms/customer/*</url-pattern>
  73. </filter-mapping>
  74. <servlet>
  75. <servlet-name>LoginServlet</servlet-name>
  76. <servlet-class>com.fxmms.servlet.LoginServlet</servlet-class>
  77. </servlet>
  78. <servlet>
  79. <servlet-name>InvalidateServlet</servlet-name>
  80. <servlet-class>com.fxmms.servlet.InvalidateServlet</servlet-class>
  81. </servlet>-
  82. <servlet-mapping>
  83. <servlet-name>LoginServlet</servlet-name>
  84. <url-pattern>/loginServlet</url-pattern>
  85. </servlet-mapping>
  86. <servlet-mapping>
  87. <servlet-name>InvalidateServlet</servlet-name>
  88. <url-pattern>/invalidateServlet</url-pattern>
  89. </servlet-mapping>-->
  90. <!-- 配置看可以把POST请求转为PUT,DELETE请求的Filter -->
  91. <filter>
  92. <filter-name>HiddenHttpMethodFilter </filter-name>
  93. <filter-class>org.springframework.web.filter.HiddenHttpMethodFilter </filter-class>
  94. </filter>
  95. <filter-mapping>
  96. <filter-name>HiddenHttpMethodFilter </filter-name>
  97. <url-pattern>/* </url-pattern>
  98. </filter-mapping>
  99. <!--配置中央控制器,对所有请求进行拦截并做请求路径,与处理请求桩模块之间的映射-->
  100. <servlet>
  101. <servlet-name>defaultDispatcherServlet </servlet-name>
  102. <servlet-class>org.springframework.web.servlet.DispatcherServlet </servlet-class>
  103. <init-param>
  104. <param-name>contextConfigLocation
  105. </param-name>
  106. <param-value>classpath:default-servlet.xml </param-value>
  107. </init-param>
  108. <load-on-startup>1 </load-on-startup>
  109. </servlet>
  110. <!--这里是拦截所有-->
  111. <servlet-mapping>
  112. <servlet-name>defaultDispatcherServlet </servlet-name>
  113. <url-pattern>/ </url-pattern>
  114. </servlet-mapping>
  115. </web-app>

2.9 build.gradle
项目构建脚本

  1. group 'com.fxmms'
  2. version '1.0-SNAPSHOT'
  3. apply plugin: 'java'
  4. apply plugin: 'idea'
  5. apply plugin: 'war'
  6. sourceCompatibility = 1.8
  7. repositories {
  8. maven { url "http://maven.aliyun.com/nexus/content/groups/public/" }
  9. mavenLocal()
  10. jcenter()
  11. maven { url "http://repo.maven.apache.org/maven2/"}
  12. maven { url 'https://repo.spring.io/libs-milestone'}
  13. mavenCentral()
  14. }
  15. dependencies {
  16. testCompile group: 'junit', name: 'junit', version: '4.12'
  17. // servlet-api
  18. compile group: 'javax.servlet', name: 'servlet-api', version: '2.5'
  19. //spring相关
  20. compile group: 'org.springframework', name: 'spring-webmvc', version: '4.3.3.RELEASE'
  21. compile group: 'org.springframework', name: 'spring-orm', version: '4.3.3.RELEASE'
  22. compile group: 'org.springframework', name: 'spring-aspects', version: '4.3.3.RELEASE'
  23. compile group: 'org.springframework.security', name: 'spring-security-config', version: '3.2.0.RELEASE'
  24. compile group: 'org.springframework.security', name: 'spring-security-taglibs', version: '3.2.0.RELEASE'
  25. compile 'org.springframework.security:spring-security-web:3.2.0.RELEASE'
  26. //hibernate相关
  27. compile 'org.hibernate:hibernate-core:4.3.6.Final'
  28. //c3p0连接池
  29. compile group: 'org.hibernate', name: 'hibernate-c3p0', version: '4.3.6.Final'
  30. //ehcahe二级缓存
  31. compile group: 'org.hibernate', name: 'hibernate-ehcache', version: '4.3.6.Final'
  32. //mysql
  33. compile group: 'mysql', name: 'mysql-connector-java', version: '5.1.39'
  34. //springData
  35. compile group: 'org.springframework.data', name: 'spring-data-jpa', version: '1.10.3.RELEASE'
  36. // https://mvnrepository.com/artifact/log4j/log4j日志
  37. compile group: 'log4j', name: 'log4j', version: '1.2.17'
  38. //json解析相关
  39. compile group: 'com.fasterxml.jackson.core', name: 'jackson-databind', version: '2.5.4'
  40. compile group: 'com.fasterxml.jackson.core', name: 'jackson-core', version: '2.5.4'
  41. //迅雷接口有关jar 包
  42. compile 'org.apache.httpcomponents:httpclient:4.4'
  43. compile 'org.json:json:20141113'
  44. compile group: 'org.apache.clerezza.ext', name: 'org.json.simple', version: '0.4'
  45. //https://mvnrepository.com/artifact/org.apache.commons/commons-io 读取文件相关
  46. compile group: 'org.apache.commons', name: 'commons-io', version: '1.3.2'
  47. // https://mvnrepository.com/artifact/org.apache.poi/poi 文件读取相关 apache-poi
  48. compile group: 'org.apache.poi', name: 'poi', version: '3.9'
  49. // https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml 解决execl 版本差异
  50. compile group: 'org.apache.poi', name: 'poi-ooxml', version: '3.9'
  51. // https://mvnrepository.com/artifact/commons-io/commons-io 文件上传
  52. compile group: 'commons-io', name: 'commons-io', version: '1.3.1'
  53. // https://mvnrepository.com/artifact/commons-fileupload/commons-fileupload
  54. compile group: 'commons-fileupload', name: 'commons-fileupload', version: '1.2.2'
  55. }

3. 各层包功能讲解&项目搭建完毕最终效果演示图


3.1 项目中各层包功能讲解
项目中Java源代码层级结构如下图所示:


项目中Java源代码层级结构

对于www包中的各分层,我们对照上图重点说明:

controller:用于路由各种HTTP访问,其中可以实现对前台页面参数的对象化绑定,这个功能的实现是依赖于spring mvc中的参数绑定功能,以及返回向前端页面返回数据。也可以实现基于Restful 风格API的编写。
dao:用于实现对数据库的操作,包中的代码继承并实现自common中的dao 层代码,采用的是类的适配器模式实现的,这里的代码值得细细品味,可以说是整个项目的灵魂所在之处,稍后说明。
domain:项目中的所有实体类都存在于这个包中,其中的每个具体实体类与数据库表相对应。
dto:实现了序列化的数据传输层对象,可用于接收前台参数,前台参数被封装成dto 对象传输至后台。同时也负责对从数据库中查询数据的封装。
qo:模糊查询对象所在的包,用于封装QBC动态查询参数。
rowmapper:用于映射jdbcTemplate查询数据库返回对象的数据集,并将数据集依照以此对象为集合的实例进行封装。
schedulejob:定时任务类所在的包,在此包中的类上都要加上@Service注解,因为定时任务注解配置在service-applicationContext.xml中,包扫描组件的规则是只扫描类上有@Service注解的组件类。
service:业务逻辑层,所有的业务逻辑组件Bean都放置在这个保重,其中的类中的业务逻辑方法调用了dao实现类中的方法,并且每个有关于数据库操作的方法上都加上了@Transaction注解,用于实现对数据库操作的事务管理。@Transaction是Spring Framework对AOP 的另一种区别于拦截器的自定义注解实现。

4.项目中重要代码讲解


主要讲解一下Dao层中代码对适配器设计模式的应用:
4.1 首先看下commom层中 BaseDao.java

  1. import com.fxmms.common.ro.DtoResultWithPageInfo;
  2. import org.hibernate.Criteria;
  3. import java.util.List;
  4. *
  5. * @usage 数据库公共操作接口
  6. @Repository
  7. *
  8. * @param id
  9. * @return T
  10. public T getById(Serializable id);
  11. /**
  12. *
  13. * @usage 根据id懒加载数据库中唯一纪录,封装成java对象并返回
  14. */
  15. *
  16. * @param columnName
  17. * @param value
  18. * @usage 根据列名,以及对应的值获取数据库中惟一纪录,封装成Java对象并返回
  19. * @return
  20. public T getByUniqueKey(String columnName, Object value);
  21. /**
  22. *
  23. *
  24. */
  25. *
  26. * @param columnName
  27. * @param value
  28. * @param sort
  29. * @param order
  30. * @return List<T>
  31. public List<T> getListByColumn(String columnName, Object value,
  32. * ͨ
  33. * @param nameValuePairs
  34. * @param sort
  35. * @param order
  36. * @return List<T>
  37. public List<T> getListByColumns(Map<String, Object> nameValuePairs,
  38. *
  39. * @return List<T>
  40. public List<T> getAll();
  41. /**
  42. *
  43. * @return Serializable id
  44. public Serializable save(T t);
  45. /**
  46. *
  47. */
  48. *
  49. * @param t
  50. public void delete(T t);
  51. /**
  52. * @return
  53. public Criteria createCriteria();
  54. /**
  55. * @param <D>
  56. * @param pageNo
  57. * @param dtoClazz
  58. */
  59. Criteria criteria, int pageNo, int pageSize, Class<D> dtoClazz);
  60. * @param <E>
  61. * @param criteria
  62. * @param class1
  63. */
  64. package com.fxmms.common.dao.hib;
  65. import com.fxmms.common.dao.BaseDao;
  66. import com.fxmms.common.ro.DtoResultWithPageInfo;
  67. import com.fxmms.common.ro.PageQo;
  68. import org.apache.commons.logging.LogFactory;
  69. import org.hibernate.Session;
  70. import org.hibernate.criterion.Order;
  71. import org.hibernate.criterion.Restrictions;
  72. import org.springframework.beans.factory.annotation.Autowired;
  73. import org.springframework.stereotype.Repository;
  74. import java.util.ArrayList;
  75. import java.util.Map;
  76. /**
  77. * @param <T>
  78. * 主要使用到QBC动态查询。主要思想是利用反射。
  79. @Repository
  80. protected static final Log log = LogFactory
  81. //通过反射,可以实现对不同类对应的数据表的操作
  82. protected SessionFactory sessionFactory;
  83. @Autowired
  84. public void setSessionFactory(SessionFactory sessionFactory) {
  85. }
  86. public Session getSession() {
  87. }
  88. public Session openNewSession() {
  89. }
  90. @Override
  91. public T getById(Serializable id) {
  92. }
  93. @Override
  94. public T getByUniqueKey(String columnName, Object value) {
  95. .add(Restrictions.eq(columnName, value)).uniqueResult();
  96. @SuppressWarnings("unchecked")
  97. Criteria criteria = getSession().createCriteria(getEntityClass());
  98. if(StringUtils.hasText(sort) && StringUtils.hasText(order)){
  99. criteria.addOrder(Order.asc(sort));
  100. criteria.addOrder(Order.desc(sort));
  101. }
  102. return list;
  103. @SuppressWarnings("unchecked")
  104. Criteria criteria = getSession().createCriteria(getEntityClass());
  105. List<T> list = criteria.list();
  106. }
  107. @Override
  108. public List<T> getListByColumns(Map<String, Object> nameValuePairs,String sort,String order){
  109. for (Map.Entry<String, Object> entry : nameValuePairs.entrySet()) {
  110. }
  111. if("asc".equals(order)){
  112. }else if("desc".equals(order)){
  113. }
  114. List<T> list = criteria.list();
  115. }
  116. @Override
  117. public List<T> getListByColumns(Map<String, Object> nameValuePairs){
  118. for (Map.Entry<String, Object> entry : nameValuePairs.entrySet()) {
  119. }
  120. return list;
  121. @Override
  122. public List<T> getAll() {
  123. }
  124. @Override
  125. public T getUniqueResult(Map<String, Object> nameValuePairs) {
  126. for (Map.Entry<String, Object> entry : nameValuePairs.entrySet()) {
  127. }
  128. }
  129. @Override
  130. public T load(Serializable id){
  131. }
  132. @Override
  133. return getSession().save(t);
  134. public void update(T t) {
  135. session.update(t);
  136. session.flush();
  137. public void delete(T t) {
  138. }
  139. /**
  140. *
  141. * @param pageSize
  142. * @param dtoClazz
  143. */
  144. int page, int pageSize,Q qo, Class<D> dtoClazz){
  145. return queryPageListByCriteria(criteria, page, pageSize, dtoClazz);
  146. * QO List<dtoClazz>
  147. * @param dtoClazz
  148. */
  149. Q qo, Class<D> dtoClazz){
  150. @SuppressWarnings("unchecked")
  151. List<D> resultsDtoList = new ArrayList<D>();
  152. try {
  153. BeanUtils.copyProperties(entity, dto);
  154. } catch (InstantiationException e) {
  155. } catch (IllegalAccessException e) {
  156. }
  157. return resultsDtoList;
  158. * queryPageListByCriteria
  159. * ͨcriteria DtoResultWithPageInfo<dtoClazz>list+ҳϢ
  160. * @param criteria
  161. * @param pageNo
  162. * @param pageSize
  163. * @param dtoClass
  164. *
  165. /*public <E, D extends Dto> DtoResultWithPageInfo<D> queryPageListByCriteria(
  166. pageSize);
  167. criteria.setFirstResult(pageInfo.getFirstResultNum());
  168. @SuppressWarnings("unchecked")
  169. List<D> resultsDtoList = new ArrayList<D>();
  170. D dto;
  171. dto = dtoClazz.newInstance();
  172. BeanUtils.copyProperties(result, dto);
  173. log.error("ҳѯ쳣bean쳣");
  174. }
  175. log.error("ҳѯ쳣dtoʼ쳣");
  176. dto = null;
  177. log.error("ҳѯ쳣dtoʼ쳣");
  178. dto = null;
  179. resultsDtoList.add(dto);
  180. DtoResultWithPageInfo<D> resultWithPageInfo = new DtoResultWithPageInfo<D>(
  181. return resultWithPageInfo;
  182. * ͨcriteria List<dtoClazz>
  183. * @param criteria
  184. * @return
  185. /*public <E, D extends Dto> List<D> queryListByCriteria(
  186. List<E> resultsList = criteria.list();
  187. for (E result : resultsList) {
  188. try {
  189. try {
  190. } catch (Exception e) {
  191. e.printStackTrace();
  192. } catch (InstantiationException e) {
  193. e.printStackTrace();
  194. } catch (IllegalAccessException e) {
  195. e.printStackTrace();
  196. }
  197. }
  198. }*/
  199. /*public DataTablePageList queryDataTablePageListByCriteria(
  200. // ܼ¼
  201. criteria.setProjection(Projections.rowCount());
  202. criteria.setProjection(null);
  203. criteria.setMaxResults(Integer.parseInt(displayLength));
  204. @SuppressWarnings("rawtypes")
  205. String.valueOf((int) totalRecords), resultsList);
  206. }
  207. /**
  208. *
  209. * @param pageNo
  210. * @return
  211. private PageInfo getInstancePageInfoWithCriteria(Criteria criteria,
  212. long totalQuantity = 0L;
  213. totalQuantity = (Long) criteria.uniqueResult();
  214. totalQuantity);
  215. }*/
  216. @Override
  217. // TODO Auto-generated method stub
  218. }
  219. * queryPageListByCriteria
  220. * ͨcriteria DtoResultWithPageInfo<dtoClazz>list+ҳϢ
  221. * @param criteria
  222. * @param pageNo
  223. * @param pageSize
  224. * @param dtoClass
  225. * ص DtoResultWithPageInfo
  226. * Ϊ queryPageListByCriteria
  227. @Override
  228. Criteria criteria, int pageNo, int pageSize, Class<D> dtoClazz) {
  229. PageInfo pageInfo = getInstancePageInfoWithCriteria(criteria, pageNo,
  230. criteria.setFirstResult(pageInfo.getFirstResultNum());
  231. @SuppressWarnings("unchecked")
  232. List<D> resultsDtoList = new ArrayList<D>();
  233. D dto;
  234. dto = dtoClazz.newInstance();
  235. BeanUtils.copyProperties(result, dto);
  236. log.error("ҳѯ쳣bean쳣");
  237. }
  238. log.error("ҳѯ쳣dtoʼ쳣");
  239. dto = null;
  240. log.error("ҳѯ쳣dtoʼ쳣");
  241. dto = null;
  242. resultsDtoList.add(dto);
  243. DtoResultWithPageInfo<D> resultWithPageInfo = new DtoResultWithPageInfo<D>(
  244. return resultWithPageInfo;
  245. * queryPageListByCriteriaWithQo
  246. * ͨcriteria DtoResultWithPageInfo<dtoClazz>list+ҳϢ
  247. * @param criteria
  248. * @param pageNo
  249. * @param pageSize
  250. * @param dtoClass
  251. * ص DtoResultWithPageInfo
  252. * Ϊ queryPageListByCriteria
  253. @Override
  254. //˷ĵãpageinfoѾfirstResult maxresult
  255. qo.add(criteria);
  256. criteria.setFirstResult(pageInfo.getFirstResultNum());
  257. @SuppressWarnings("unchecked")
  258. List<D> resultsDtoList = new ArrayList<D>();
  259. D dto;
  260. dto = dtoClazz.newInstance();
  261. BeanUtils.copyProperties(result, dto);
  262. log.error("ҳѯ쳣bean쳣");
  263. }
  264. log.error("ҳѯ쳣dtoʼ쳣");
  265. dto = null;
  266. log.error("ҳѯ쳣dtoʼ쳣");
  267. dto = null;
  268. resultsDtoList.add(dto);
  269. DtoResultWithPageInfo<D> resultWithPageInfo = new DtoResultWithPageInfo<D>(
  270. return resultWithPageInfo;
  271. * ͨѯʼҳϢ
  272. * @param criteria
  273. * @param pageSize
  274. */
  275. int pageNo, int pageSize) {
  276. // ܵtotalQuality
  277. totalQuantity = (Long) criteria.uniqueResult();
  278. PageInfo pageInfo = PageInfo.getInstance(pageNo, pageSize,
  279. return pageInfo;
  280. }

这个方法是极为重要的 protected abstract Class<?> getEntityClass();
后续介绍,现在暂时有个印象。
在www中的dao层有与各具体类(数据表)相对应的数据库操作实现:


屏幕快照 2016-11-20 下午11.22.30.png


上图声明了三个具体类对应的接口声明:AdminDao、MacDao、TaskDao。
对应三个接口有三个具体的实现类:AdminDaoImpl、MacDaoImpl、TaskDaoImpl。
我们以与Admin类相关的dao层操作为例:
Admin.java

  1. * Created by mark on 16/11/2.
  2. */
  3. @Table(name = "mms_admin")
  4. @Id
  5. @GenericGenerator(name = "increment", strategy = "increment")
  6. private int id;
  7. private String userName;
  8. private String password;
  9. private String role;
  10. private int enable;
  11. private int isDelete;
  12. public int getId() {
  13. }
  14. public void setId(int id) {
  15. }
  16. public String getUserName() {
  17. }
  18. public void setUserName(String userName) {
  19. }
  20. public String getPassword() {
  21. }
  22. public void setPassword(String password) {
  23. }
  24. public String getRole() {
  25. }
  26. public void setRole(String role) {
  27. }
  28. public int getEnable() {
  29. }
  30. public void setEnable(int enable) {
  31. }
  32. public int getIsDelete() {
  33. }
  34. public void setIsDelete(int isDelete) {
  35. }
  36. package com.fxmms.www.dao;
  37. import com.fxmms.common.dao.BaseDao;
  38. * Created by mark on 16/10/31.
  39. */
  40. package com.fxmms.www.dao.hib;
  41. import com.fxmms.common.dao.hib.HibernateTemplateDao;
  42. import com.fxmms.www.domain.Admin;
  43. /**
  44. * @usage 使用适配器模式,将common层中定义的公共访问数据库方法实现嫁接到Admin类的接口中。
  45. public class AdminDaoImpl extends HibernateTemplateDao<Admin> implements AdminDao {
  46. @Override
  47. // TODO Auto-generated method stub
  48. }
  49. @Override
  50. public T getByUniqueKey(String columnName, Object value) {
  51. .add(Restrictions.eq(columnName, value)).uniqueResult();
  52. <code class="java" ,monospace;="" font-size:12px;="" background-color:transparent;="" padding:0px;="" border:none"="" style="outline: 0px; padding: 8px; word-break: break-all; font-family: Menlo, Monaco, Consolas, "Courier New";"> }

getEntityClass()方法最终都会被具体的类所实现。这个设计真的是很巧妙。

5.webapp文件夹下分层详解


webapp下有res文件夹,用于存储静态文件,WEB-INF文件夹下有view文件夹用于放置应用中jsp页面。
文件组织结构如下图所示:


webapp下静态资源以及前端页面

6.配置tomcat 运行环境


项目搭建已经完毕,接下来需要做的就是配置项目的运行环境了,这里我们采用tomcat来充当应用服务器。
6.1 去官网下载tomcat 8.0http://tomcat.apache.org/download-80.cgi
6.2 配置 tomcat 服务器:
点击Edit Configurations


屏幕快照 2016-11-20 下午11.48.58.png


点击+,并选择Tomcat Server中local选项


屏幕快照 2016-11-20 下午11.51.03.png


添加启动任务名称,默认为unnamed


屏幕快照 2016-11-21 上午9.33.39.png


配置Application Server


屏幕快照 2016-11-21 上午9.39.06.png


装载开发版(exploded)应用war包,此步骤有两种方式:
第一种方式:选择Deploy at the server startup下方的+,入下图所示:


屏幕快照 2016-11-21 上午9.54.16.png


接下来在Select Artifacts Deploy 弹出框中 选择 exploded 属性的war包


屏幕快照 2016-11-21 上午9.54.31.png

接下来选择apply-> ok ,最终的结果是:


屏幕快照 2016-11-21 上午10.05.46.png

屏幕快照 2016-11-21 上午10.12.55.png


最终点击启动按钮启动应用


屏幕快照 2016-11-21 上午10.15.46.png


最终的启动效果如下所示


屏幕快照 2016-11-21 上午10.27.45.png

模板代码地址:https://coding.net/u/zongyuan/p/Java-backend-template/git
关于项目中应用到的JNI技术,会在后面讲解,主要侧重点是在代码层面解决JNI link library的问题。

猜你喜欢

转载自blog.csdn.net/zhangfeng5909/article/details/80855312