[color=red]
struts2.0 和 Spring 集成开发
知识点:DAO层的应用和基本的配置介绍
提示:S2集成Spring时struts2-spring-plugin-2[1].0.6.jar要加入到项目中去
1、首先搭建基本的struts2.0 的web 运行环境 和 Spring 的环境
2、配置 spring 在web 的运行环境:[/color]
如:
在web.xml 中配置:
<!-- 配置Spring 在web上的运行环境 -->
<listener>
<listener-class>org.springframework.web.context.ContextLoaderListener</listener-class>
</listener>
<context-param>
<param-name>contextConfigLocation</param-name>
<param-value>classpath:applicationContext.xml</param-value>
</context-param>
说明:
org.springframework.web.context.ContextLoaderListener 该类是:
org.springframework.web-3.0.1.Release-a.jar 下的
理解:好似事件中的监听,等待触发;
3、在struts.xml 中配置sturts2.0 与 spring 的管理关系
首先配置常量用来说明:struts 的对象由spring 来管理:
<constant name="struts.objectFactory" value="spring"></constant>
然后:action 中class 的值为:需要访问的Action 在Spring容器中bean 的ID,
通过容器来注入并实现调用;
例如:
<action name="user_*" method="{1}" class="useraction"></action>
说明:useraction 对应:
<bean id="useraction" class="com.svse.action.UserAction" scope="prototype"></bean>
注意:Action会被多次的调用,而且直接关系到界面和数据库数据的同步,所以此处必须明确的指出该bean 使用代理模式,以保证数据的同步性:即设置:scope="prototype";
4、在applicationContext.xml 中配置连接数据库的数据源:
<bean id="datasources" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="com.microsoft.sqlserver.jdbc.SQLServerDriver"></property>
<property name="url" value="jdbc:sqlserver://localhost:1433;database=TESTDB"></property>
<property name="username" value="sa"></property>
<property name="password" value="svse"></property>
</bean>
说明:org.apache.commons.dbcp.BasicDataSource 这个类属于:commons-dbcp.jar包
<!-- 注入DAO层 : dataSource 是UserDao从JdbcDaoSupport 中继承而来,用于处理数据的 -->
<!-- 依赖注入数据源,马上就可以操作数据库了 -->
<bean id="userDao" class="com.svse.dao.UserDao">
<property name="dataSource" ref="datasources"></property>
</bean>
5、在DAO层 ,对数据进行增、删、该、查
<!--
package com.svse.dao;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.util.List;
import org.springframework.dao.DataAccessException;
import org.springframework.jdbc.core.ResultSetExtractor;
import org.springframework.jdbc.core.RowMapper;
import org.springframework.jdbc.core.support.JdbcDaoSupport;
import com.svse.entity.UserEntity;
/**
*
* @author Administrator
* Spring 中DAO层,操作数据库需要继承JdbcDaoSupport *
*/
public class UserDao extends JdbcDaoSupport {
/**
* 增加
* @param user
*/
public void addUser(UserEntity user) {
this.getJdbcTemplate().update("insert into t_user values(?,?,?)",
new Object[]{user.getU_name(),user.getSex(),user.getHib()});
}
/**
* 删除
* @param uId
*/
public void delUser(int uId) {
this.getJdbcTemplate().update("delete from t_user where u_id=?",new Object[]{new Integer(uId)});
}
/**
* 查询所有
* @return list
*/
public List findAllUser() {
return this.getJdbcTemplate().query("select * from t_user",new RowMapper(){
/**
* rs : 保存了查询出来的结果集 , 此处可以直接进行获取,并且不需要进行while循环读取
* @return user : 此处返回的使用个UserEntity的实体对象,返回后由RwoMapper自动的封装成
* 一个集合,最后的返回给业务逻辑层
*/
public Object mapRow(ResultSet rs, int arg1) throws SQLException {
UserEntity user = new UserEntity();
user.setU_id(rs.getInt("u_id"));
user.setU_name(rs.getString("u_name"));
user.setSex(rs.getString("u_sex"));
user.setHib(rs.getString("u_hid"));
return user;
}});
}
/**
* 查询一个
* @param uId
* @return user
*/
public UserEntity findUserById(int uId) {
//此处直接返回一个UserEntity 的实体对象,需要进行强转;
return (UserEntity)this.getJdbcTemplate().query("select * from t_user where u_id =?" ,
new Object[]{new Integer(uId)},
new ResultSetExtractor(){
/**
* @param rs : 一个结果集 , 此处获取rs中的值需要while判断取值
*/
public Object extractData(ResultSet rs)
throws SQLException, DataAccessException {
UserEntity user = null;
while(rs.next()){
user = new UserEntity();
user.setU_id(rs.getInt("u_id"));
user.setU_name(rs.getString("u_name"));
user.setSex(rs.getString("u_sex"));
user.setHib(rs.getString("u_hid"));
}
return user;
}});
}
/**
* 修改
* @param user
*/
public void uppUser(UserEntity user) {
this.getJdbcTemplate().update(
"update t_user set u_name=?,u_sex=? ,u_hid=? where u_id=?",
new Object[] {user.getU_name(),user.getSex(),user.getHib(),new Integer(user.getU_id())});
}
}
-->