Strut1+Spring2+Hibernate3 基础工作代码 流程

struts配置文件中配置控制跳转:

<action input="/admin/userList.jsp" name="userListForm"
	path="/admin/userList" scope="request"
	type="com.bettersoft.admin.UserListAction" validate="false">
	<forward name="out" path="/admin/userList.jsp" />
	<forward name="success" path="/admin/userList.jsp" />
	<forward name="error" path="/error.jsp" />
</action>

applicationContext.xml文件中配置:

<!--  将session工厂注入BaseDAO  -->
<bean id="baseDao" class="com.bytter.framework.persistence.dao.BaseDAO">
	<property name="sessionFactory">
		<ref local="sessionFactory" />
	</property>
</bean>
继承baseDao后spring会直接注入,不用再次写ref属性
<bean id="userDao" class="com.bytter.budget.user.dao.impl.UserDaoImpl" parent="baseDao">
</bean>
将Dao注入Service

<bean id="userService" class="com.bytter.budget.item.server.impl.UserServiceImpl">
	<property name="userDao">
		<ref bean="userDao"/>
	</property>
</bean>

实现BaseDao类,BaseDao需要继承HibernateDaoSupport类(注:最好提取BaseDao的公用方法写一个IBaseDAO 接口,接口优势可参考List接口的实现,降低程序耦合。)

自己的Dao类实现接口继承BaseDao,数据库的操作在此层完成。示例:

public class UserDaoImpl extends BaseDAO implements UserDao {

	public List findUsersList() throws Exception {
		List lstUsers = new ArrayList();
		String sql = "select * from bt_user order by user_name asc";
		lstUsers = this.search_sql(null, "", sql, "", null);
		return lstUsers;
	}

}
接下来是Service层,Service通过set取得Dao对象,通过Dao对数据库进行操作。
List rslist = userDao.findUsersList();//userDao对象直接通过set方法直接获取
		List lstUsers = new ArrayList();
		Iterator iterator = rslist.iterator();//通过迭代器把查询出来的Object对象转换成Bean的类型的对象然后再放进list中
		while(iterator.hasNext()){
			Object[] obj=(Object[])iterator.next();
			UserBean user = new UserBean();
			user.setUser_code(obj[0].toString());
			user.setUser_name(obj[1].toString());
			user.setPassword(obj[2].toString());
			lstUsers.add(user);
		}
//Service处理之后直接给Action返回一个List<User>链表
 

Action中直接调用Service的处理方法,获取List,然后放入request(logic标签直接获取request中的值)

request.setAttribute("listObject", lstUsers);//list对象放入request中接下来就是jsp页面通过调用logic标签来实现数据的显示

		<table class='list' width="50%" border="1" cellspacing="0" cellpadding="1" backgroud="blue">
			<tr class="title">
				<td nowrap>编码</td>
				<td nowrap>名称</td>
			</tr>
			<logic:empty name="listObject">
				<td nowrap colspan="20">没有查询到相关数据!</td>
			</logic:empty>
			<logic:iterate id="user" name="listObject">
				<tr title='<bean:write name="user" property="corp_code"/>'>
					<td nowrap><bean:write name="user" property="user_code" /></td>
					<td nowrap><bean:write name="user" property="user_name" /></td>
					<td nowrap><bean:write name="user" property="password" /></td>
				</tr>
			</logic:iterate>
		</table>

好啦,完工。
效果图:




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值