首先申明:这是我在网上看的视频写的笔记,感谢孙宇老师。
一、sping环境搭建
1.1新建web工程(ss2he
)
注意:最后一步中一定要选中Standart Maven JEE project structure
,这表示使用标准maven的目录结构。
1.2配置spring
pom.xml
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.ss2he</groupId>
<artifactId>ss2he</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<name>ss2he</name>
<description/>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<!-- spring3 -->
<dependency>
<!-- spring核心包 -->
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>3.1.2.RELEASE</version>
</dependency>
<dependency>
<!-- spring上下文,必须 -->
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>3.1.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>3.1.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
<version>3.1.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>3.1.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-expression</artifactId>
<version>3.1.2.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-orm</artifactId>
<version>3.1.2.RELEASE</version>
</dependency>
<!-- javaeeAPI -->
<dependency>
<groupId>javax</groupId>
<artifactId>javaee-api</artifactId>
<version>7.0</version>
<scope>provided</scope>
</dependency>
<!-- jstl -->
<dependency>
<groupId>org.glassfish.web</groupId>
<artifactId>javax.servlet.jsp.jstl</artifactId>
<version>1.2.2</version>
</dependency>
<!-- log4j -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
<!-- junit -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.10</version>
<scope>test</scope>
</dependency>
<!-- mysql驱动 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.38</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.3.2</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
<plugin>
<artifactId>maven-war-plugin</artifactId>
<version>2.2</version>
<configuration>
<version>3.1</version>
<failOnMissingWebXml>false</failOnMissingWebXml>
</configuration>
</plugin>
</plugins>
</build>
</project>
这里我们先给出最基本的配置,后面在往上面继续添加其他的配置。
web.xml
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1">
<!-- spring配置文件位置 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring.xml</param-value>
</context-param>
<!-- spring监听器 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>
spring的配置文件:spring.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" xsi:schemaLocation="
http://www.springframework.org/schema/beans
http://www.springframework.org/schema/beans/spring-beans-3.0.xsd
http://www.springframework.org/schema/context
http://www.springframework.org/schema/context/spring-context-3.0.xsd">
<!-- 引入属性文件 -->
<context:property-placeholder location="classpath:config.properties" />
<!-- 自动扫描dao和service包(自动注入) -->
<context:component-scan base-package="sy.dao,sy.service" />
</beans>
这里我们配置自动扫描dao和service包,便于我们后面使用注解,同时我们不需要配置bean,我们可以采用注解的方式将相关的bean注入进来,而不使用xml文件进行配置。同时注意:这里我们将所有资源文件都放在src/main/resources
包中,我们没有使用默认的spring配置文件名,如果要使用spring默认的配置文件名需要放在WEB-INF
下面,此时就不需要在web.xml
配置属性文件的地址了。
1.3测试
在src/main/java
中放置和项目相关的java文件。
UserService.java
package sy.service;
public interface UserService {
public void test();
}
UserServiceImpl.java
package sy.service.impl;
import org.apache.log4j.Logger;
import org.springframework.stereotype.Service;
import sy.action.UserAction;
import sy.service.UserService;
//这就相当于我们以前在配置文件中配置的bean
@Service(value="userService")
public class UserServiceImpl implements UserService{
private static final Logger logger = Logger.getLogger(UserAction.class);
@Override
public void test() {
//System.out.println("测试");
logger.info("测试");
}
}
说明:可以看到这里我们使用log4e
插件进行打印测试结果而没有使用系统的打印,因为系统打印很消耗内存,所以不用。
在src/main/source
中放置项目相关的资源文件。
log4j.properties
log4j.rootLogger=INFO,A1,R
log4j.appender.A1=org.apache.log4j.ConsoleAppender
log4j.appender.A1.Target=System.out
log4j.appender.A1.layout=org.apache.log4j.PatternLayout
log4j.appender.A1.layout.ConversionPattern=[%c]%m%n
log4j.appender.R=org.apache.log4j.RollingFileAppender
log4j.appender.R.File=sshe.log
log4j.appender.R.MaxFileSize=10MB
log4j.appender.R.Threshold=ALL
log4j.appender.R.layout=org.apache.log4j.PatternLayout
log4j.appender.R.layout.ConversionPattern=[%p][%d{yyyy-MM-dd HH\:mm\:ss,SSS}][%c]%m%n
在src/test/java
中放置用于测试的java文件。
TestSpring.java
package sy.test;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import sy.service.UserService;
//在spring.xml中我们配置了自动扫描,于是这里spring会帮我们将我们需
//要的bean注入进来
public class TestSpring {
@Test
public void test(){
ApplicationContext ac = new ClassPathXmlApplicationContext(new String[]{ "classpath:spring.xml" });
UserService userService = (UserService) ac.getBean("userService");//使用注解中找到此service的bean
userService.test();
}
}
最后我们直接使用junit进行测试。
二、struts2环境搭建
首先我们需要在pom.xml
中配置struts2需要的依赖包。
pom.xml
<!-- struts2 -->
<dependency>
<groupId>org.apache.struts</groupId>
<artifactId>struts2-core</artifactId>
<version>2.3.4.1</version>
<!-- 下面的配置表示不引入哪些包,因为之后的Hibernate中也有这些包 -->
<!-- <exclusions>
<exclusion>
<groupId>javassist</groupId>
<artifactId>javassist</artifactId>
</exclusion>
</exclusions> -->
</dependency>
<dependency>
<!-- 让spring去管理struts的action -->
<groupId>org.apache.struts</groupId>
<artifactId>struts2-spring-plugin</artifactId>
<version>2.3.4.1</version>
</dependency>
<dependency>
<!-- 使用struts2的注解 -->
<groupId>org.apache.struts</groupId>
<artifactId>struts2-convention-plugin</artifactId>
<version>2.3.4.1</version>
</dependency>
将struts2的配置文件放在src/main/resources
struts.xml
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.3//EN" "http://struts.apache.org/dtds/struts-2.3.dtd">
<struts>
<!-- 指定由spring负责action对象的创建 -->
<constant name="struts.objectFactory" value="spring" />
<!-- 所有匹配*.action的请求都由struts2处理 -->
<constant name="struts.action.extension" value="action" />
<!-- 是否启用开发模式 -->
<constant name="struts.devMode" value="true" />
<!-- struts配置文件改动后,是否重新加载 -->
<constant name="struts.configuration.xml.reload" value="true" />
<!-- 设置浏览器是否缓存静态内容 -->
<constant name="struts.serve.static.browserCache" value="false" />
<!-- 请求参数的编码方式 -->
<constant name="struts.i18n.encoding" value="utf-8" />
<!-- 每次HTTP请求系统都重新加载资源文件,有助于开发 -->
<constant name="struts.i18n.reload" value="true" />
<!-- 文件上传最大值 -->
<constant name="struts.multipart.maxSize" value="104857600" />
<!-- 让struts2支持动态方法调用 -->
<constant name="struts.enable.DynamicMethodInvocation" value="true" />
<!-- Action名称中是否还是用斜线 -->
<constant name="struts.enable.SlashesInActionNames" value="false" />
<!-- 允许标签中使用表达式语法 -->
<constant name="struts.tag.altSyntax" value="true" />
<!-- 对于WebLogic,Orion,OC4J此属性应该设置成true -->
<constant name="struts.dispatcher.parametersWorkaround" value="false" />
<package name="basePackage" extends="struts-default"></package>
</struts>
说明:这里可以看到我们只是配置了一个package,没有配置bean,因为我们在项目中使用的是注解方式。
在web.xml
中配置struts的拦截器
web.xml
<!-- Struts2配置 -->
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>*.action</url-pattern>
</filter-mapping>
说明:这里我们拦截一切.action
结尾的请求。
测试:我们新建一个action类
UserAction.java
package sy.action;
import org.apache.log4j.Logger;
import org.apache.struts2.ServletActionContext;
import org.apache.struts2.convention.annotation.Action;
import org.apache.struts2.convention.annotation.Namespace;
import org.apache.struts2.convention.annotation.ParentPackage;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.context.ApplicationContext;
import org.springframework.web.context.support.WebApplicationContextUtils;
import sy.service.UserService;
@ParentPackage("basePackage")
@Namespace("/")
@Action(value="userAction")
public class UserAction {
private static final Logger logger = Logger.getLogger(UserAction.class);
//方式二:推荐方式
private UserService userService;
public UserService getUserService() {
return userService;
}
@Autowired
public void setUserService(UserService userService) {
this.userService = userService;
}
public void test(){
//System.out.println("进入action");
logger.info("进入action");
//方式一:不推荐
/*ApplicationContext ac = WebApplicationContextUtils.getWebApplicationContext(ServletActionContext.getServletContext());
UserService userService = (UserService) ac.getBean("userService");
userService.test();*/
//方式二:推荐
userService.test();
}
}
说明:
- 1.先单纯的测试struts2,我们使用
logger.info("进入action");
打印测试结果,直接使用junit测试。 - 2.之后我们测试struts2和spring的整合。提供了两种方式,先看第一种,第一种中和我们之前测试spring的方式是一样的,较为繁琐,这里不推荐;第二种是我们申明一个UserService对象,让spring为我们注入此对象,然后我们直接调用此对象即可。
- 3.最后我们可以看到我们使用注解配置action,其实和在文件中配置是一样的,但是较为方便。我们使用
http://localhost:8080/ss2he/userAction!test.action
进行访问,看能不能访问到之前UserServiceImpl.java
中的那个test方法。访问成功则表示struts2和spring整合成功。
三、Hibernate开发环境搭建
先配置Hibernate需要的jar包:
<!-- hibernate4 -->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>4.2.21.Final</version>
</dependency>
注意:视频中老师使用的是4.1.7版本,但是我再试验的过程中spring总是不能将sessionFactory注入进去,后来换成了这个版本。但是可能是TestSpring.java
中也使用了UserService而我们在src/test/resources
中没有放置配置文件而导致找不到配置文件引发不能注入的问题。我们可以将TestSpring.java
中的测试方法注释掉再试试。
在dao层中:
UserDaoImpl.java
package sy.dao.impl;
import java.io.Serializable;
import org.hibernate.SessionFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Repository;
import sy.dao.UserDao;
import sy.model.User;
//我们可以看到这里就和Hibernate3不一样了,Hibernate3中我们是需要继承一个Hibernate的类的
//Hibernate4中不能这样调用,使用注入的方式
//Dao也应该交给spring管理,加上注解
@Repository(value="userDao")
public class UserDaoImpl implements UserDao {
private SessionFactory sessionFactory;
@Override
public Serializable save(User user) {
//这里为什么不用open session?因为我们已经将事务交给spring管理了,直接使用getCurrentSession方法
return this.sessionFactory.getCurrentSession().save(user);
}
public SessionFactory getSessionFactory() {
return sessionFactory;
}
//这里使用注入的方式
@Autowired
public void setSessionFactory(SessionFactory sessionFactory) {
this.sessionFactory = sessionFactory;
}
}
说明:这里我们可以看到我们是使用的注入方式,让spring为我们将SessionFactory注入到dao层中,注意Hibernate3和Hibernate4的区别。
在service层中我们需要增加相关方法:
UserServiceImpl.java
package sy.service.impl;
import java.io.Serializable;
import org.apache.log4j.Logger;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import sy.action.UserAction;
import sy.dao.UserDao;
import sy.model.User;
import sy.service.UserService;
//这就相当于我们以前在配置文件中配置的bean
@Service(value="userService")
public class UserServiceImpl implements UserService{
private static final Logger logger = Logger.getLogger(UserServiceImpl.class);
private UserDao userDao;
@Override
public void test() {
//System.out.println("测试");
logger.info("测试");
}
@Override
public Serializable save(User user) {
return userDao.save(user);
}
public UserDao getUserDao() {
return userDao;
}
//注意:方法名中的UserDao是和UserDaoImpl.java中的类上的注解是对应的,也就是那边是userDao,这里就是UserDao
@Autowired
public void setUserDao(UserDao userDao) {
this.userDao = userDao;
}
public static Logger getLogger() {
return logger;
}
}
说明:这里我们增加了一个save方法,注意我们没有new一个UserDao,而是让spring帮我们注入进来。
测试
TestHibernate.java
package sy.test;
import java.util.Date;
import java.util.UUID;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import sy.model.User;
import sy.service.UserService;
public class TestHibernate {
@Test
public void test(){
//获得spring的上下文,下面这行将两个配置文件联系起来了
ApplicationContext ac = new ClassPathXmlApplicationContext(new String[]{ "classpath:spring.xml","classpath:spring-hibernate.xml" });
UserService userService = (UserService) ac.getBean("userService");//使用注解中找到此service的bean
User user = new User();
user.setId(UUID.randomUUID().toString());
user.setUsername("张三");
user.setPassword("123");
user.setCreatedatetime(new Date());
userService.save(user);
}
}
说明:这里我们只是纯粹的测试了dao层,还没有从web层上进行测试,下面我们在web层上进行测试。
注意:在测试后我们就会向数据库中存相关的数据,此时如果我们进行打包,maven会再次运行测试方法,这会导致向数据库中插入重复数据,而数据库中有些字段是不能重复的,我们需要在打包的时候将一些测试方法注释掉。
首先在web.xml
中配置Hibernate的配置文件:
<?xml version="1.0" encoding="UTF-8"?>
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://xmlns.jcp.org/xml/ns/javaee" xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/javaee http://xmlns.jcp.org/xml/ns/javaee/web-app_3_1.xsd" id="WebApp_ID" version="3.1">
<display-name>ss2he</display-name>
<!-- spring配置文件位置 -->
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:spring.xml,classpath:spring-hibernate.xml</param-value>
</context-param>
<!-- openSessionInView配置 -->
<filter>
<filter-name>openSessionInViewFilter</filter-name>
<filter-class>org.springframework.orm.hibernate4.support.OpenSessionInViewFilter</filter-class>
<init-param>
<param-name>singleSession</param-name>
<param-value>true</param-value>
</init-param>
</filter>
<!-- Struts2配置 -->
<filter>
<filter-name>struts2</filter-name>
<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
</filter>
<filter-mapping>
<filter-name>struts2</filter-name>
<url-pattern>*.action</url-pattern>
</filter-mapping>
<!-- openSessionInView -->
<filter-mapping>
<filter-name>openSessionInViewFilter</filter-name>
<url-pattern>*.action</url-pattern>
</filter-mapping>
<!-- spring监听器 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>
说明:可以看到我们还配置了openSessionInViewFilter
,主要是用于控制session的,具体作用这里不多讲。
在UserAction.java
中增加这样一个方法:
//测试Hibernate
public void addUser(){
User user = new User();
user.setId(UUID.randomUUID().toString());
user.setUsername("xxx");
user.setPassword("111");
user.setCreatedatetime(new Date());
userService.save(user);
}
说明:然后使用地址:http://localhost:8080/ss2he/userAction!addUser.action
访问,如果没报错就表明Hibernate和spring整合成功。注意将以前的测试方法注释掉。但是这里碰到一个问题是为什么访问的时候这个方法会执行两次,导致我们报错,但是数据是已经插入成功的,只是第二次插入就会与第一次插入重复,而数据库中有些字段是不能重复的。最后网上有人说这是spring3.1版本的bug,我换成4.2.5版本之后就没问题了。
最后:
我们给出完整的pom.xml
文件:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.ss2he</groupId>
<artifactId>ss2he</artifactId>
<version>0.0.1-SNAPSHOT</version>
<packaging>war</packaging>
<name>ss2he</name>
<description/>
<!-- 指定Maven仓库 -->
<repositories>
<repository>
<id>central</id>
<name>Central Repository</name>
<url>https://repo.maven.apache.org/maven2</url>
<layout>default</layout>
<snapshots>
<enabled>false</enabled>
</snapshots>
</repository>
<repository>
<id>alibaba-opensource</id>
<name>alibaba-opensource</name>
<url>http://code.alibabatech.com/mvn/releases/</url>
<layout>default</layout>
</repository>
<repository>
<id>alibaba-opensource-snapshot</id>
<name>alibaba-opensource-snapshot</name>
<url>http://code.alibabatech.com/mvn/snapshots/</url>
<layout>default</layout>
</repository>
</repositories>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
</properties>
<dependencies>
<!-- 阿里巴巴数据源包druid -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.0.19</version>
</dependency>
<!-- fastJson -->
<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.1.24</version>
</dependency>
<!-- aspectjweaver -->
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.7.0</version>
</dependency>
<!-- hibernate4 -->
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-core</artifactId>
<version>4.2.21.Final</version>
</dependency>
<!-- struts2 -->
<dependency>
<groupId>org.apache.struts</groupId>
<artifactId>struts2-core</artifactId>
<version>2.3.4.1</version>
<!-- 下面的配置表示不引入哪些包,因为之后的Hibernate中也有这些包 -->
<exclusions>
<exclusion>
<groupId>javassist</groupId>
<artifactId>javassist</artifactId>
</exclusion>
</exclusions>
</dependency>
<dependency>
<!-- 让spring去管理struts的action -->
<groupId>org.apache.struts</groupId>
<artifactId>struts2-spring-plugin</artifactId>
<version>2.3.4.1</version>
</dependency>
<dependency>
<!-- 使用struts2的注解 -->
<groupId>org.apache.struts</groupId>
<artifactId>struts2-convention-plugin</artifactId>
<version>2.3.4.1</version>
</dependency>
<!-- spring3 -->
<dependency>
<!-- spring核心包 -->
<groupId>org.springframework</groupId>
<artifactId>spring-core</artifactId>
<version>4.2.5.RELEASE</version>
</dependency>
<dependency>
<!-- spring上下文,必须 -->
<groupId>org.springframework</groupId>
<artifactId>spring-context</artifactId>
<version>4.2.5.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-jdbc</artifactId>
<version>4.2.5.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-beans</artifactId>
<version>4.2.5.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-web</artifactId>
<version>4.2.5.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-expression</artifactId>
<version>4.2.5.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-orm</artifactId>
<version>4.2.5.RELEASE</version>
</dependency>
<!-- javaeeAPI -->
<dependency>
<groupId>javax</groupId>
<artifactId>javaee-api</artifactId>
<version>7.0</version>
<scope>provided</scope>
</dependency>
<!-- jstl -->
<dependency>
<groupId>org.glassfish.web</groupId>
<artifactId>javax.servlet.jsp.jstl</artifactId>
<version>1.2.2</version>
</dependency>
<!-- log4j -->
<dependency>
<groupId>log4j</groupId>
<artifactId>log4j</artifactId>
<version>1.2.17</version>
</dependency>
<!-- junit -->
<dependency>
<groupId>junit</groupId>
<artifactId>junit</artifactId>
<version>4.10</version>
<scope>test</scope>
</dependency>
<!-- mysql驱动 -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<version>5.1.38</version>
</dependency>
</dependencies>
<build>
<plugins>
<!-- 编译插件 -->
<plugin>
<artifactId>maven-compiler-plugin</artifactId>
<version>2.3.2</version>
<configuration>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
<!-- war包插件 -->
<plugin>
<artifactId>maven-war-plugin</artifactId>
<version>2.2</version>
<configuration>
<version>3.1</version>
<failOnMissingWebXml>false</failOnMissingWebXml>
</configuration>
</plugin>
</plugins>
</build>
</project>
四、整合easyUI
这里我们使用的是jquery-easyui-1.3.1
版本,由于整个包都不太大,所以我们直接将真个包拷贝到工程中src/main/webapp/js
目录下。然后我们在首页中需要引入相关的文件才能使用这个框架。
index.jsp
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<!DOCTYPE HTML>
<html>
<head>
<title>My JSP 'index.jsp' starting page</title>
<meta http-equiv="pragma" content="no-cache">
<meta http-equiv="cache-control" content="no-cache">
<meta http-equiv="expires" content="0">
<!-- 下面两个必须引用 -->
<script type="text/javascript" src="js/jquery-easyui-1.3.1/jquery-1.8.0.min.js"></script>
<script type="text/javascript" src="js/jquery-easyui-1.3.1/jquery.easyui.min.js"></script>
<!-- 国际化文件 -->
<script type="text/javascript" src="js/jquery-easyui-1.3.1/locale/easyui-lang-zh_CN.js"></script>
<!-- 默认样式 -->
<link rel="stylesheet" href="js/jquery-easyui-1.3.1/themes/default/easyui.css">
<!-- 图标 -->
<link rel="stylesheet" href="js/jquery-easyui-1.3.1/themes/icon.css">
</head>
<body>
This is my JSP page. <br>
</body>
</html>
资源文件(config.properties
)
#hibernate.dialect=org.hibernate.dialect.OracleDialect
#driverClassName=oracle.jdbc.driver.OracleDriver
#validationQuery=SELECT 1 FROM DUAL
#jdbc_url=jdbc:oracle:thin:@127.0.0.1:1521:orcl
#jdbc_username=sshe
#jdbc_password=sshe
hibernate.dialect=org.hibernate.dialect.MySQLDialect
driverClassName=com.mysql.jdbc.Driver
validationQuery=SELECT 1
jdbc_url=jdbc:mysql://localhost:3305/sshe?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull
jdbc_username=root
jdbc_password=walp1314
#hibernate.dialect=org.hibernate.dialect.SQLServerDialect
#driverClassName=net.sourceforge.jtds.jdbc.Driver
#validationQuery=SELECT 1
#jdbc_url=jdbc:jtds:sqlserver://127.0.0.1:1433/sy
#jdbc_username=sa
#jdbc_password=123456
#jndiName=java:comp/env/dataSourceName
hibernate.hbm2ddl.auto=update
hibernate.show_sql=true
hibernate.format_sql=true
sessionInfoName=sessionInfo
uploadFieldName=filedata
uploadFileMaxSize=20971520
uploadFileExts=txt,rar,zip,doc,docx,xls,xlsx,jpg,jpeg,gif,png,swf,wmv,avi,wma,mp3,mid
uploadDirectory=attached
之后我们就可以使用相关的框架文件了。
最后:
到此我们就将整个框架搭建好了,可以进行下一步开发了。当然如果要使用其他前端框架也是可以的,只需要将上面的前端框架换掉即可。最后补充一点是,我们在使用MyEclipse进行反向生成表的时候没有直接在工程中进行,而是另外建了一个工程,然后将里面的实体类复制过来了,因为在反向生成的时候MyEclipse会生成一些不需要的文件(如hibernate的配置文件和sessionFactory类),而这里我们是使用spring注入,所以这些都不需要。