首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > Web前端 >

struts2+spring+ibatis框架筹建心得

2012-09-10 
struts2+spring+ibatis框架搭建心得? 我们知道struts1与spring整合是靠org.springframework.web.struts.De

struts2+spring+ibatis框架搭建心得

? 我们知道struts1与spring整合是靠org.springframework.web.struts.DelegatingActionProxy来实现的,以下通过具体一个用户登录实现来说明struts2整合spring的相关内容.

????一、准备工作

1.配置开发环境:MyEclipse6.0+Eclipse3.3+JDK6.0+Tomcat6.0+Struts 2.0+spring2.5.6+ibatis2.3.4。

2.新建web项目,导入相应的jar包,如以下所示:
???? a.由于现在IDE开发工具还没有对struts2.0有很好的支持,所有我们需要手功配置,首先将我们刚下下来的struts2.0的lib里面的asm-3.1.jar、asm-commons-3.1.jar、asm-tree-3.1.jar、commons-fileupload-1.2.2.jar、commons-io-2.0.1.jar、commons-lang-2.5.jar、freemarker-2.3.16.jar、javassist-3.11.0.GA.jar、ognl-3.0.1.jar、struts2-core-2.2.3.jar、xwork-core-2.2.3.jar、commons-logging-1.0.4.jar、、commons-pool-1.4.jar、log4j-1.2.15.jar、spring-2.5.6.jar、spring-webmvc-struts-2.5.6.jar、struts2-spring-plugin-2.0.9.jar、xercesImpl-2.8.1.jar、xml-apis-1.3.03.jar、commons-dbcp-1.2.2.jar、ibatis-2.3.4.726.jar、ojdbc6.jar(很多jar其实没必要,有待深究) ? 添加的WEB-INF/lib下面

3.配置(WEB-INF\)web.xml,如下:

<?xml version="1.0" encoding="UTF-8"?><web-app id="WebApp_9" 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">    <display-name>Struts Blank</display-name><!-- struts -->    <filter>        <filter-name>struts_demo001</filter-name>        <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>    </filter>    <filter-mapping>        <filter-name>struts_demo001</filter-name>        <url-pattern>/*</url-pattern>    </filter-mapping>    <welcome-file-list>        <welcome-file>index.html</welcome-file>    </welcome-file-list><!-- spring -->    <listener>        <listener-class>            org.springframework.web.context.ContextLoaderListener        </listener-class>    </listener>   <!-- spring配置文件 -->    <context-param><param-name>contextConfigLocation</param-name><param-value> /WEB-INF/test/conf/test.applicationContext.xml</param-value></context-param></web-app>

?4.struts文件(src\)配置

<!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.devMode" value="true"></constant><constant name="struts.custom.i18n.resources" value="test"></constant>    <include file="struts-default.xml"></include>    <package name="test" extends="struts-default" namespace="/" >       <action name="loginAction" >           <result name="init">/WEB-INF/test/jsp/login.jsp</result>       </action>    </package>    </struts>

4.test.applicationContext.xml(/WEB-INF/test/conf/)

<?xml version="1.0" encoding="UTF-8"?><beans    xmlns="http://www.springframework.org/schema/beans"    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"    xsi:schemaLocation="http://www.springframework.org/schema/beans http://www.springframework.org/schema/beans/spring-beans-2.0.xsd">            <bean id="propertyConfigurer"destroy-method="close"><property name="driverClassName" value="${test.driverClassName}" /><property name="url" value="${test.url}" /><property name="username" value="${test.username}" /><property name="password" value="${test.password}" /></bean><bean id="sqlMapClient" value="/WEB-INF/SqlMapConfig.xml" /><property name="dataSource" ref="dataSource" /></bean>    <bean id="loginDao" ref="sqlMapClient"></property></bean>        <bean name="loginService" >    <property name="loginDao" ref="loginDao"></property>    </bean>        <bean name="resultAction" name="code">test.driverClassName=oracle.jdbc.driver.OracleDrivertest.url=jdbc:oracle:thin:@192.168.1.12:1521:testtest.username=nametest.password=pwd
?

?

6.SqlMapConfig.xml(WEB-INF/)

<?xml version="1.0" encoding="UTF-8"?><!DOCTYPE sqlMapConfig PUBLIC "-//ibatis.apache.org//DTD SQL Map Config 2.0//EN"    "http://ibatis.apache.org/dtd/sql-map-config-2.dtd"><sqlMapConfig>       <settings useStatementNamespaces="true" />       <sqlMap resource="test/daoImpl/test.xml" /></sqlMapConfig>

?7.test.xml()

<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE sqlMap PUBLIC "-//ibatis.apache.org//DTD SQL Map 2.0//EN"    "http://ibatis.apache.org/dtd/sql-map-2.dtd"><sqlMap namespace="test">       <typeAlias alias="userInfoVo" type="test.vo.UserInfoVo" />       <select id="queryByLoginName" resultname="code">package test.action;import java.sql.SQLException;import java.util.Map;import javax.management.loading.PrivateClassLoader;import org.apache.struts2.util.IteratorGenerator.Converter;import org.omg.PortableInterceptor.SUCCESSFUL;import org.omg.PortableInterceptor.SYSTEM_EXCEPTION;import test.service.LoginService;import com.opensymphony.xwork2.ActionContext;import com.opensymphony.xwork2.ActionSupport;import com.sun.net.httpserver.Authenticator.Success;public class LoginAction extends ActionSupport {   private LoginService loginService;       public String query() throws Exception     {        String pwd = loginService.querybyLoginName("name");        System.out.print(pwd);              return "init";    }        public String init()    {        return "init";    }   /**    * @return 返回 loginService    */   public LoginService getLoginService()   {       return loginService;   }   /**    * @param 对loginService进行赋值    */   public void setLoginService(LoginService loginService)   {       this.loginService = loginService;   }}

?9.LoginServiceImpl文件

?

package test.serviceImpl;import java.sql.SQLException;import test.dao.LoginDao;import test.service.LoginService;public class LoginServiceImpl implements LoginService{    private LoginDao loginDao;              public String querybyLoginName(String name) throws SQLException    {       return loginDao.querybyLoginName(name);    }    public String  queryForResult()    {               return "service return:loveYY";       }        /**     * @return 返回 loginDao     */    public LoginDao getLoginDao()    {        return loginDao;    }    /**     * @param 对loginDao进行赋值     */    public void setLoginDao(LoginDao loginDao)    {        this.loginDao = loginDao;    }}

?10.LoginDaoImpl文件

package test.daoImpl;import java.sql.SQLException;import com.ibatis.sqlmap.client.SqlMapClient;import test.dao.LoginDao;public class LoginDaoImpl  implements LoginDao{    SqlMapClient sqlMap ;        public String querybyLoginName(String name) throws SQLException    {        String pwd=null;        try{             pwd = (String)sqlMap.queryForObject("test.queryByLoginName",(String)"1");        }        catch (Exception  e){            e.printStackTrace();        }        return pwd;    }    /**     * @return 返回 sqlMap     */    public SqlMapClient getSqlMap()    {        return sqlMap;    }    /**     * @param 对sqlMap进行赋值     */    public void setSqlMap(SqlMapClient sqlMap)    {        this.sqlMap = sqlMap;    }   }
?

?

热点排行