1,框架版本:JDK1.8 Spring-4.2.5.RELEASE hibernate-5.0.8.Final
如果用的eclipse,在菜单window -- preferences -- General -- Workspace -- Text file encoding 设置为UTF-8,这样工程下所有新建的项目编码格式都是UTF-8。
2,准备工具:我选择的是eclipse4.6.2 。
D:\Program Files\Java\jdk1.8.0_121\bin\java.exe
-startup
plugins/org.eclipse.equinox.launcher_1.3.201.v20161025-1711.jar
--launcher.library
plugins/org.eclipse.equinox.launcher.win32.win32.x86_64_1.1.401.v20161122-1740
-product
org.eclipse.epp.package.jee.product
--launcher.defaultAction
openFile
-showsplash
org.eclipse.platform
--launcher.defaultAction
openFile
--launcher.appendVmargs
-vmargs
-Dosgi.requiredJavaVersion=1.8
-XX:+UseG1GC
-XX:+UseStringDeduplication
-Dosgi.requiredJavaVersion=1.8
-Xms256m
-Xmx1024m
第一行是指定的jdk,-Dosgi.requiredJavaVersion=1.8为版本,最下面的是内存大小,mx设置为512M,设置1G项目小很浪费分配的内存空间,ms256或512。
2.1 :eclipse有了,讲下maven,maven只是一个很简单的管理插件。
maven:jar包管理仓库,方便引用可以打包,项目结构也比经典的WEB项目要清晰。
1:先搞清楚版本对应,我常用的对应是:jdk1.6对3.2.5 , jdk1.7对3.3.3 , jdk1.8对3.3.9,maven配置变量完毕后,还要修改下conf下配置文件。
2:默认是C盘user .M2下的repository,找着很费劲,而且还占用C盘空间。
maven配置:远程仓库地址引用和本地磁盘存储位置,配置好了这个,以后随便走哪里,拷贝一个配置文件settings.xml替换可以了。找到maven目录下的conf文件夹下的settings.xml 修改为:
<?xml version="1.0" encoding="UTF-8"?>
<settings xmlns="http://maven.apache.org/SETTINGS/1.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/SETTINGS/1.0.0 http://maven.apache.org/xsd/settings-1.0.0.xsd">
<proxies></proxies>
<!--
<localRepository>e:\myCenterRepository</localRepository>
<localRepository>F:\greenProgram_dev\maven_serv_repo</localRepository>
-->
<servers>
<server>
<id>archiva.releases</id>
<username>deployment</username>
<password>deployment</password>
</server>
<server>
<id>archiva.snapshots</id>
<username>deployment</username>
<password>deployment</password>
</server>
<server>
<id>thirdparty</id>
<username>admin</username>
<password>admin123</password>
</server>
</servers>
<!-- 所有对central请求都转向 nexus groups -->
<mirrors>
<mirror>
<!--This sends everything else to /public -->
<id>nexus</id>
<mirrorOf>central</mirrorOf>
<!--
<url>http://172.168.3.202:8080/nexus/content/groups/public/</url>
<url>http://172.168.1.222:8080/nexus/content/groups/public/</url>-->
<url>http://repo1.maven.org/maven2</url>
</mirror>
</mirrors>
<profiles>
<profile>
<id>central</id>
<repositories>
<repository>
<id>central</id>
<name>Central Repository</name>
<url>http://repo1.maven.org/maven2</url>
<layout>default</layout>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
<repository>
<id>snapshots</id>
<name>Snapshots Repository</name>
<!--
<url>http://172.168.3.202:8080/nexus/content/repositories/snapshots/</url>
<url>http://172.168.1.222:8080/nexus/content/repositories/snapshots/</url>-->
<url>http://repo1.maven.org/maven2</url>
<layout>default</layout>
<snapshots>
<enabled>true</enabled>
</snapshots>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>central</id>
<name>Central Repository</name>
<url>http://repo1.maven.org/maven2</url>
<layout>default</layout>
<snapshots>
<enabled>false</enabled>
</snapshots>
<releases>
<updatePolicy>never</updatePolicy>
</releases>
</pluginRepository>
</pluginRepositories>
</profile>
</profiles>
<activeProfiles>
<activeProfile>central</activeProfile>
</activeProfiles>
<localRepository>D:/Program Files/Maven_Path</localRepository>
</settings>
2个重点:一个是远程仓库地址,http://repo1.maven.org/maven2/ 不挂掉就可以一直引用(推荐),二是本地存放管理的jar包路径localRepository,路径可以按照自己需要修改。
把上面的配置在eclipse中指定:
如果preferences里没有maven插件,自行安装maven插件。推荐下载一个较新的版本。
一个指向,一个引用本地磁盘和远程仓库。
3,开始搭建:
eclipse + maven 都准备好了,开始搭建:
右键new project --- > other
选择骨架,还是自定义,我一般是骨架(勾选create a simple project),因为maven是配置好了的,很方便。
选择骨架后:
搭建完成后的样子,这里不需要自己添加web.xml,用JAVAEE TOOLS 的 Generate Deployement Descriptor Stub,自动生成。
生成完毕:
右键项目,把java build path 换成指向的jdk1.8
且java编译 java complier 保持1.8
project facets 修改
4,修改web.xml(改变了web版本,必须修改)
修改为3.0,保存后自动下载引用版本编译。
5,配置pom.xml
+ View Code
6,新建applicationContext.xml 跳转文件,数据源加载文件,log4j文件。
Spring文件:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:tx="http://www.springframework.org/schema/tx"
xmlns:aop="http://www.springframework.org/schema/aop"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-4.1.xsd
http://www.springframework.org/schema/aop
http://www.springframework.org/schema/aop/spring-aop-4.1.xsd">
<!-- 属性文件位置 -->
<bean id="annotationPropertyConfigurer"
class="org.springframework.beans.factory.config.PropertyPlaceholderConfigurer">
<property name="locations">
<list>
<value>classpath:init.properties</value>
</list>
</property>
</bean>
<!-- 配置数据源 c3p0 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource"
destroy-method="close">
<property name="driverClass" value="${jdbc.driver}" />
<property name="jdbcUrl" value="${jdbc.url}" />
<property name="user" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
<!-- 请求超时时间 -->
<property name="checkoutTimeout" value="30000" />
<!-- 每60秒检查所有连接池中的空闲连接。默认值: 0,不检查 -->
<property name="idleConnectionTestPeriod" value="30" />
<!-- 连接数据库连接池最大空闲时间 -->
<property name="maxIdleTime" value="30" />
<!-- 连接池初始化连接数 -->
<property name="initialPoolSize" value="5" />
<property name="minPoolSize" value="5" />
<property name="maxPoolSize" value="20" />
<!--当连接池中的连接耗尽的时候c3p0一次同时获取的连接数。默认值: 3 -->
<property name="acquireIncrement" value="5" />
</bean>
<!-- 配置hibernate的SessionFactory -->
<bean id="sessionFactory"
class="org.springframework.orm.hibernate5.LocalSessionFactoryBean">
<!-- 注入数据源 相关信息看源码 -->
<property name="dataSource" ref="dataSource" />
<!-- hibernate配置信息 -->
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">${hibernate.dialect}</prop>
<prop key="hibernate.show_sql">${hibernate.show_sql}</prop>
<prop key="hibernate.format_sql">${hibernate.format_sql}</prop>
<prop key="hibernate.hbm2ddl.auto">${hibernate.hbm2ddl.auto}</prop>
<!-- 开启二级缓存 ehcache -->
<prop key="hibernate.cache.use_second_level_cache">${hibernate.cache.use_second_level_cache}</prop>
<prop key="hibernate.cache.use_query_cache">${hibernate.cache.use_query_cache}</prop>
<prop key="hibernate.cache.region.factory_class">${hibernate.cache.region.factory_class}</prop>
<prop key="hibernate.cache.provider_configuration_file_resource_path">${hibernate.cache.provider_configuration_file_resource_path}
</prop>
</props>
</property>
<!-- 扫描hibernate注解配置的entity -->
<property name="packagesToScan" value="org.yugh" />
</bean>
<!-- 配置事务管理器 -->
<bean id="transactionManager"
class="org.springframework.orm.hibernate5.HibernateTransactionManager">
<property name="sessionFactory" ref="sessionFactory" />
</bean>
<!-- 配置事务增强处理Bean,指定事务管理器 -->
<tx:advice id="transactionAdvice" transaction-manager="transactionManager">
<!-- 配置详细事务处理语义 -->
<tx:attributes>
<tx:method name="insert*" propagation="REQUIRED" />
<tx:method name="update*" propagation="REQUIRED" />
<tx:method name="delete*" propagation="REQUIRED" />
<tx:method name="get*" propagation="SUPPORTS" read-only="true" />
<tx:method name="find*" propagation="SUPPORTS" read-only="true" />
<tx:method name="select*" propagation="SUPPORTS" read-only="true" />
<tx:method name="load*" propagation="SUPPORTS" read-only="true" />
<!-- 其他采用默认事务方式 -->
<tx:method name="*" />
</tx:attributes>
</tx:advice>
<!-- Spring aop事务管理 -->
<aop:config>
<!-- 配置切入点 -->
<aop:pointcut id="transactionPointcut"
expression="execution(* org.yugh.services.*.*(..))" />
<!-- 指定在txAdvice切入点应用txAdvice事务增强处理 -->
<aop:advisor pointcut-ref="transactionPointcut" advice-ref="transactionAdvice" />
</aop:config>
</beans>
数据源可以根据情况自行选择,我自己搭建换的c3p0,pom.xml里的阿里的druid可以不用引用。
数据源init.properties
#mysql database setting
jdbc.driver=com.mysql.jdbc.Driver
jdbc.url=jdbc:mysql://127.0.0.1:3306/bit?useUnicode=true&characterEncoding=utf-8
jdbc.username=root
jdbc.password=root
#hibernate config
hibernate.dialect = org.hibernate.dialect.MySQLDialect
hibernate.show_sql = true
hibernate.format_sql = false
hibernate.hbm2ddl.auto = update
hibernate.cache.use_second_level_cache = false
hibernate.cache.use_query_cache = false
hibernate.current_session_context_class=thread
hibernate.cache.region.factory_class = org.hibernate.cache.ehcache.EhCacheRegionFactory
hibernate.cache.provider_configuration_file_resource_path = ehcache.xml
我测试用的mysql数据库。
日志文件log4j.properties
### set log levels ### INFO
log4j.rootLogger = INFO,stdout,E
log4j.appender.stdout = org.apache.log4j.ConsoleAppender
log4j.appender.stdout.Target = System.out
log4j.appender.stdout.layout = org.apache.log4j.PatternLayout
log4j.appender.stdout.layout.ConversionPattern = %d{ABSOLUTE} %5p %c{1}:%L - %m%n
log4j.logger.org.quartz=INFO
log4j.appender.E= org.apache.log4j.DailyRollingFileAppender
log4j.appender.E.File =logs/mylogs.log
log4j.appender.E.DatePattern=yyyy-MM-dd'.log'
log4j.appender.E.Threshold =INFO
log4j.appender.E.layout = org.apache.log4j.PatternLayout
log4j.appender.E.layout.ConversionPattern =%-d{yyyy-MM-dd HH\:mm\:ss}[%c] [%t\:%r] - [%p] %m%n
跳转文件,springmvc-servlet.xml
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:context="http://www.springframework.org/schema/context"
xmlns:mvc="http://www.springframework.org/schema/mvc"
xsi:schemaLocation="http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-4.1.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-4.1.xsd
http://www.springframework.org/schema/mvc
http://www.springframework.org/schema/mvc/spring-mvc-4.1.xsd">
<!-- 启用spring mvc 注解 -->
<!-- 扫描注解 -->
<context:component-scan base-package="org.yugh.controller" />
<!-- <mvc:annotation-driven /> -->
<!-- 处理请求时返回json字符串的中文乱码问题 -->
<!-- <mvc:annotation-driven> <mvc:message-converters> <bean class="org.springframework.http.converter.StringHttpMessageConverter">
<property name="supportedMediaTypes"> <list> <value>application/json;charset=UTF-8</value>
</list> </property> </bean> </mvc:message-converters> </mvc:annotation-driven> -->
<!-- 避免IE执行AJAX时,返回JSON出现下载文件 -->
<bean id="mappingJacksonHttpMessageConverter"
class="org.springframework.http.converter.json.MappingJackson2HttpMessageConverter">
<property name="supportedMediaTypes">
<list>
<value>text/html;charset=UTF-8</value>
</list>
</property>
</bean>
<!-- 启动SpringMVC的注解功能,完成请求和注解POJO的映射 -->
<bean
class="org.springframework.web.servlet.mvc.annotation.AnnotationMethodHandlerAdapter">
<property name="messageConverters">
<list>
<ref bean="mappingJacksonHttpMessageConverter" /> <!-- JSON转换器 -->
</list>
</property>
</bean>
<!-- 定义跳转的文件的前后缀 ,视图模式配置 -->
<bean
class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<!-- 这里的配置我的理解是自动给后面action的方法return的字符串加上前缀和后缀,变成一个 可用的url地址 -->
<property name="prefix" value="/WEB-INF/page/" />
<property name="suffix" value=".jsp" />
</bean>
<!-- 配置文件上传,如果没有使用文件上传可以不用配置,当然如果不配,那么配置文件中也不必引入上传组件包 -->
<bean name="multipartResolver"
class="org.springframework.web.multipart.commons.CommonsMultipartResolver">
<!-- 默认编码 -->
<property name="defaultEncoding" value="utf-8" />
<!-- 文件大小最大值 -->
<property name="maxUploadSize" value="10485760000" />
<!-- 内存中的最大值 -->
<property name="maxInMemorySize" value="40960" />
</bean>
</beans>
最后是web.xml文件
View Code
项目搭建完成,初次搭建完成后install一下,拉下repo1的jar包,方便后期写代码的引用。
maven项目报错很好调节,maven - update project ,或者调整项目JDK编译版本。
7,简单的跳转实现
1:index.jsp
web.xml里设置的初始页是index.jsp
1 <form id="myform" action="${ctx}/yugh/testPage" method="post">
2 <table cellpadding="0" cellspacing="0" border="0" class="tab_case_01" >
3 <tr>
4 <td colspan="1" style="text-align: right;">
5 <input type="button" id="seache" value="测试跳转" onclick="subData();" class="button icon edit" />
6 </td>
7 </tr>
8 </table>
9 </div>
10 </form>
一个简单的跳转按钮,提交看下面
1 function subData() {
2 $("#myform").attr("action","${ctx}/yugh/testPage");
3 $("#myform").submit();
4 }
2:controller类
/**
* @author: YuGH
* @e_mail:
* @name: TestController.java
* @creation: 2017年6月23日 上午10:36:46
* @description:测试控制类
* @version: 1.0
*/
@Controller
@RequestMapping("/yugh")
public class TestController {
@RequestMapping("/testPage")
public String controllerTest(ModelMap map){
String runTime = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(new Date());
map.addAttribute("date", runTime);
System.out.println("进入controller里,当前时间:"+runTime);
return "testPage/test";
}
}
8,测试查看