struts2.2.1.1+spring3+hibernate3+json

来源:互联网 发布:mac jenkins 编辑:程序博客网 时间:2024/06/06 05:29

  折腾了半天终于将json搭配到struts2.2.1.1中,在一个神奇的地方(json-lib所有jar包:http://2011down.com/detail/TWFFThW)下载了一个JSON完整包,解决了冲突问题。并且有了struts2-json-plugin-2.2.1.1.jar就不再需要json-lib-2.1-jdk15.jar包。

 

  1.包结构:

 

  2.web.xml文件:

 

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5"
 xmlns="http://java.sun.com/xml/ns/javaee"
 xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation="http://java.sun.com/xml/ns/javaee
 http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd">
 
  <context-param>
   <param-name>contextConfigLocation</param-name>
   <param-value>/WEB-INF/classes/applicationContext.xml</param-value>
  </context-param>
  <listener>
   <listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
  </listener>
 
  <filter>
   <filter-name>struts2</filter-name>
   <filter-class>org.apache.struts2.dispatcher.FilterDispatcher</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>

  3.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>
 <package name="struts2" extends="struts-default"> 
      <action name="loginAction" class="loginAction">
             <result name="success">/index.jsp</result>
             <result name="login">/index.jsp</result>
      </action>
      <action name="regAction" class="regAction">
             <result name="success">/index.jsp</result>
             <result name="login">/index.jsp</result>
      </action>
 </package>
 <package name="paging" namespace="/paging" extends="struts-default">
      <action name="pagingAction" class="pagingAction" method="getPagingAction">
      <result name="success">/index.jsp</result>
      </action>
 </package>
</struts>

  4.applicationContext.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: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-2.5.xsd
http://www.springframework.org/schema/tx
http://www.springframework.org/schema/tx/spring-tx-2.5.xsd
http://www.springframework.org/schema/aop http://www.springframework.org/schema/aop/spring-aop-2.5.xsd ">

<!-- sql server 2005 JDBC -->
 <!--    <bean id="dataSource"
  class="org.apache.commons.dbcp.BasicDataSource">
  <property name="driverClassName"
   value="com.microsoft.sqlserver.jdbc.SQLServerDriver">
  </property>
  <property name="url"
   value="jdbc:sqlserver://localhost:1433;databaseName=test">
  </property>
  <property name="username" value="sa"></property>
  <property name="password" value="11"></property>
 </bean>
 <bean id="sessionFactory"
  class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
  <property name="dataSource">
   <ref bean="dataSource" />
  </property>
  <property name="hibernateProperties">
   <props>
    <prop key="hibernate.dialect">
     org.hibernate.dialect.SQLServerDialect
    </prop>
    <prop key="hibernate.show_sql">true</prop>
    <prop key="hibernate.hbm2ddl.auto">update</prop>
   </props>
  </property>
  <property name="mappingDirectoryLocations">
            <value>classpath:com/ss/model</value>
        </property>
 </bean>

-->

 

<!-- mysql JDBC -->

<!--

<bean id="dataSource"
  class="org.apache.commons.dbcp.BasicDataSource">
  <property name="driverClassName"
   value="com.mysql.jdbc.Driver">
  </property>
  <property name="url"
   value="jdbc:mysql://localhost:3306/test">
  </property>
  <property name="username" value="root"></property>
  <property name="password" value="11"></property>
 </bean>

 -->
 <!-- sql server 2000 JDBC -->

 <bean id="dataSource"
  class="org.apache.commons.dbcp.BasicDataSource">
  <property name="driverClassName"
   value="com.microsoft.jdbc.sqlserver.SQLServerDriver">
  </property>
  <property name="url"
   value="jdbc:sqlserver://localhost:1433; DatabaseName=test">
  </property>
  <property name="username" value="sa"></property>
  <property name="password" value="11"></property>
 </bean>
 <bean id="sessionFactory"
  class="org.springframework.orm.hibernate3.annotation.AnnotationSessionFactoryBean">
  <property name="dataSource">
   <ref bean="dataSource" />
  </property>
  <property name="hibernateProperties">
   <props>
    <prop key="hibernate.dialect">
     org.hibernate.dialect.SQLServerDialect
     
    </prop>
    <prop key="hibernate.show_sql">true</prop>
    <prop key="hibernate.hbm2ddl.auto">update</prop>
   </props>
  </property>
  <property name="mappingDirectoryLocations">
            <value>classpath:com/ss/model</value>
        </property>
  </bean>
  

  
 <bean id="transactionManager"
  class="org.springframework.orm.hibernate3.HibernateTransactionManager">
  <property name="sessionFactory" ref="sessionFactory" />
 </bean>
 
    <bean id="dao" class="com.ss.dao.impl.DaoImpl">
  <property name="sessionFactory" ref="sessionFactory"></property>
 </bean>
 
 <bean id="userProxy" class="com.ss.service.impl.UserManagerImpl">
  <property name="dao" ref="dao"></property>
  <property name="sessionFactory" ref="sessionFactory"></property>
 </bean>
 
 <bean id="loginAction" class="com.ss.action.web.LoginAction">
  <property name="userProxy" ref="userProxy"></property>
 </bean>
 
 <bean id="regAction" class="com.ss.action.web.RegAction">
  <property name="userProxy" ref="userProxy"></property>
 </bean>
 
 <bean id="audioVideoDAO" class="com.ss.dao.impl.AudioVideoDAOImpl">
  <property name="sessionFactory">
   <ref bean="sessionFactory" />
  </property>
 </bean>
 <bean id="avProxy" class="com.ss.service.impl.AudioVideoManagerImpl">
  <property name="audioVideoDAO" ref="audioVideoDAO"></property>
  <property name="sessionFactory" ref="sessionFactory"></property>
 </bean>
 <bean id="pagingAction" class="com.ss.action.web.AudioVideoAction">
  <property name="avProxy" ref="avProxy"></property>
 </bean>
 
 <tx:advice id="txAdvice" transaction-manager="transactionManager">
        <tx:attributes>
            <tx:method name="save*" propagation="REQUIRED" isolation="DEFAULT" />
            <tx:method name="update*" propagation="REQUIRED" isolation="DEFAULT" />
            <tx:method name="delete*" propagation="REQUIRED" isolation="DEFAULT" />

            <tx:method name="load*" propagation="REQUIRED" isolation="DEFAULT" read-only="true" />
            <tx:method name="get*" propagation="REQUIRED" isolation="DEFAULT" read-only="true" />
            <tx:method name="find*" propagation="REQUIRED" isolation="DEFAULT" read-only="true" />

            <tx:method name="*" propagation="REQUIRED" isolation="DEFAULT" />
        </tx:attributes>
    </tx:advice>

 <aop:config>
        <aop:pointcut id="txPointcut" expression="execution(* *..*ManagerImpl.*(..))"/>
        <aop:advisor advice-ref="txAdvice" pointcut-ref="txPointcut"/>
    </aop:config>
   
 </beans>

 

  5.action里调用JSON

 

/**
 *
 */
package com.ss.action.web;

import java.util.List;

import net.sf.json.JSONArray;

import com.opensymphony.xwork2.ActionSupport;
import com.ss.model.AudioVideo;
import com.ss.service.IAudioVideoManager;

 

/**
 * @author Administrator
 *
 * implements ServletRequestAware,SessionAware
 *
 * public void setServletRequest(HttpServletRequest request)
 * public void setSession(Map session)
 *
 */
public class AudioVideoAction extends ActionSupport {

 private IAudioVideoManager<AudioVideo> avProxy;

 public void setAvProxy(IAudioVideoManager<AudioVideo> avProxy) {
  this.avProxy = avProxy;
 }

 /**
  *
  */ 
 public void getPagingAction(){
  
  List<AudioVideo> list = avProxy.findAll();

  JSONArray jsonArray = JSONArray.fromObject(list);
  System.out.println(jsonArray);
 }
 
}

原创粉丝点击