Spring S2S集成开发

[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())});
	}
	
}

-->

你可能感兴趣的:(DAO,spring,Web,bean,jdbc)