跟我一起写大虾网(第1天)

一、先整合spring2.5+jpa1.0,使用扫描加注解的方式加快开发速度,SessionFactory创建所需要的時間较长,使用单例
模式.事务也交给spring管理.

 

1.1 、导入项目相关jar包,先集成spring2.5+jpa1.0,在src目录下建立META-INF子目录,在这个目录下建立一个名为persistence.xml,这个模板文件可以在hibernate-entitymanager-3.3.1.GA\test-resources下的子包找到。

<?xml version="1.0"?>
<persistence xmlns="http://java.sun.com/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/persistence http://java.sun.com/xml/ns/persistence/persistence_1_0.xsd" version="1.0">
<!-- 配置一个持久化单元,名为mydaxia -->
  <persistence-unit name="mydaxia" transaction-type="RESOURCE_LOCAL">
  	<!-- 使用的是Hibernate提供的jpa支持 -->
  	<provider>org.hibernate.ejb.HibernatePersistence</provider>
	<properties>
         <property name="hibernate.dialect" value="org.hibernate.dialect.MySQL5Dialect"/>
         <property name="hibernate.connection.driver_class" value="org.gjt.mm.mysql.Driver"/>
         <property name="hibernate.connection.username" value="root"/>
         <property name="hibernate.connection.password" value="root"/>
         <property name="hibernate.connection.url" value="jdbc:mysql://localhost:3306/mydaxia?useUnicode=true&amp;characterEncoding=UTF-8"/>
 
         <property name="hibernate.max_fetch_depth" value="3"/>
         <!-- 开发阶段建议用update -->
         <property name="hibernate.hbm2ddl.auto" value="update"/>
	     <property name="hibernate.jdbc.fetch_size" value="18"/>
	     <property name="hibernate.jdbc.batch_size" value="10"/>
	     <property name="hibernate.show_sql" value="false"/>
	     <property name="hibernate.format_sql" value="false"/>     
      </properties>
  </persistence-unit>
</persistence>

 

1.2、在src目录下建一个名为beans.xml文件,其实编译完后会放到WebRoot\WEB-INF\classes目录下.

<?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:aop="http://www.springframework.org/schema/aop"
       xmlns:tx="http://www.springframework.org/schema/tx"
       xsi:schemaLocation="http://www.springframework.org/schema/beans
           http://www.springframework.org/schema/beans/spring-beans-2.5.xsd
           http://www.springframework.org/schema/context http://www.springframework.org/schema/context/spring-context-2.5.xsd
           http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd
           http://www.springframework.org/schema/tx http://www.springframework.org/schema/tx/spring-tx-2.5.xsd">
   <!--注册bean扫描器,启用注解能力 -->
   <context:component-scan base-package="cn.daxia"/>
   <!-- 注册实体管理器工厂 -->
   <bean id="entityManagerFactory" class="org.springframework.orm.jpa.LocalEntityManagerFactoryBean">
 		<property name="persistenceUnitName" value="mydaxia"/>
   </bean>	
   <!-- 注册事务管理器 ,spring容器管理事务-->   
   <bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
        <property name="entityManagerFactory" ref="entityManagerFactory"/>
   </bean>
   <!-- 开启事务注解能力 -->
   <tx:annotation-driven transaction-manager="transactionManager"/>
</beans>

 

1.3、新建一个用户实体bean: cn.daxia.bean.user.User

@Entity 
public class User implements Serializable{

	private static final long serialVersionUID = -3476050387771606955L;
	private String username;
	
	private String password;
	
	public User() {}
	public User(String username, String password) {
		this.username = username;
		this.password = password;
	}
	
	@Id @Column(length=80)
	public String getUsername() {
		return username;
	}

	public void setUsername(String username) {
		this.username = username;
	}

	@Column(length=50)
	public String getPassword() {
		return password;
	}

	public void setPassword(String password) {
		this.password = password;
	}
}

 

 知识提示: @Entity 标识这个类为实体类,要与数据库表进行映射的,默认名与类的简单名相同,即User; @Id 是这个实体类的标识属性,与表对应的是主键. @Column 表示要与表字段映射的属性.

1.4、新建一个用户业务接口:cn.daxia.service.user.UserService,定义一个保存方法

public interface UserService {

	public void save(User user);
}

 

       新建一个用户业务接口实现类:cn.daxia.service.user.impl.UserServiceBean

@Service("userServiceBean") @Transactional
public class UserServiceBean implements UserService {

	@PersistenceContext(unitName="mydaxia") 
	protected EntityManager em;
	
	public void save(User user) {
		em.persist(user);
		System.out.println("执行了UserServiceBean.save()方法");
	}

}

 

 知识提示: @Service("userServiceBean") 标识这个类要交给spring管理,id为userServiceBean,默认也是这个id;

@Transactional 标识这个类的所有业务方法都要开启事务; @PersistenceContext(unitName="mydaxia") 从容器里面获取一个持久化单元,名为mydaxia.

 

1.5、新建一个测试类:UserServiceTest

 

public class UserServiceTest {

	@BeforeClass
	public static void setUpBeforeClass() throws Exception {
	}

	@Test
	public void testSpringContext(){
		ApplicationContext act = new ClassPathXmlApplicationContext("beans.xml");
		UserService userService = (UserService)act.getBean("userServiceBean");
		
		userService.save(new User("yulon","123456"));
	}
}

 

知识提示: 测试库采用的是junit4,测试通过!

 

二、集成struts2,该项目使用的struts版本是2.1.8

 

2.1、新建一个Action: cn.daxia.bean.web.action.user.UserRegAction

@Controller("userRegAction")
public class UserRegAction extends ActionSupport{
	
	private static final long serialVersionUID = 1159518406043666180L;
	
	public String registerUI()throws Exception{
System.out.println("调用了UserRegAction.registerUI()方法");
		return null;
	}
	public String register() throws Exception {
System.out.println("调用了UserRegAction.register()方法");		
		return null;
	}
}

 

 知识提示: @Controller("userRegAction"),也是标识这个类交给spring管理,与之前@Service("userServiceBean") 不同的是,@Controller标识的是控制层的类. 但目前这两个注解没什么区别,以后的版本可能会有所不同!

 

1.2 配置struts.xml文件与struts-user.xml文件

    struts.xml 文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
    "http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
    <constant name="struts.i18n.encoding" value="UTF-8"/>
    <constant name="struts.action.extension" value="do,action"/>
    <!-- 设置浏览器是否缓存静态内容 -->
    <constant name="struts.serve.static.browserCache" value="false"/>
    <!-- 当struts的配置文件修改后,系统是否自动重新加载该文件 -->
    <constant name="struts.configuration.xml.reload" value="true"/>
    <!-- 打印详细的错误信息,开发阶段打开,便于寻找错误 -->
    <constant name="struts.devMode" value="true" />
     <!-- 设置默认的视图主题为simple -->
    <constant name="struts.ui.theme" value="simple" />
    <!-- 由spring创建action对象-->
    <constant name="struts.objectFactory" value="spring" /> 
    
    <!-- 文件包含 -->
    <include file="struts-user.xml"></include>
</struts>

 struts-user.xml文件

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE struts PUBLIC
    "-//Apache Software Foundation//DTD Struts Configuration 2.0//EN"
    "http://struts.apache.org/dtds/struts-2.0.dtd">
<struts>
<package name="forward" namespace="/" extends="struts-default">
	<action name="registerUI" class="userRegAction" method="registerUI">
		<result>/WEB-INF/forward/register.jsp</result>
	</action>
	<action name="register" class="userRegAction" method="register">
		<result>/WEB-INF/forward/register.jsp</result>
	</action>
</package> 
</struts>

 如有对struts2不了解的同学,可以看看struts2相关的文件,在此不在细写

 

配置web.xml文件

 

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4" 
	xmlns="http://java.sun.com/xml/ns/j2ee" 
	xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
	xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee 
	http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">

	<!-- 指定spring的配置文件,默认从web根目录寻找配置文件,我们可以通过spring提供的classpath:前缀指定从类路径下寻找 -->
	<context-param>
	   <param-name>contextConfigLocation</param-name>
	   <param-value>classpath:beans.xml</param-value>
	</context-param>
	<!-- 对Spring容器进行实例化,放在application范围 -->
	<listener>
	      <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
	</listener>

   <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>/*</url-pattern>
   </filter-mapping> 

  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
</web-app>

 

  测试:访问http://localhost:8081/mydaxia01/registerUI.action,控制台输出

调用了UserRegAction.registerUI()方法

 测试成功,到此三个框架的集成已结束!

你可能感兴趣的:(spring,xml,Hibernate,bean,struts)