login in

yu447438546 2011-11-28 01:20:51
ssh(struts、spring、hibernate)模式就是把三个框架合理地结合在一起,以发挥各自在不同位置上的作用,而如何把他们整合在一起就是关键。其实把他们整合在一起并不难,但不是任何时候都需要把他们整合来使用,这要看场合,我们应该合理的使用,合适就好。但不管怎么说它都是一种不错的模式,用MyEclipse工具会很方便地把它们整合在一起。下面简单说一下过程:

1.先加struts包和配置文件(可以手动添加,也可以在myeclipse的myeclipse菜单里面把struts的环境添加上去,后面的spring会用到struts的配置文件。
2.添加spring,可以像添加struts一样把spring的环境添加上去,不过一定要添加spring的web包。可以把spring的配置文件和struts的配置文件一起放在WEN-INF目录下。
3.添加Hibernate,添加Hibernate的时候对待Hibernate的配置文件我们有两种处理方式:一:按往常一样新建一个配置文件,把它放在src目录下(一般情况);二:无需新建配置文件,而是把Hibernate的配置信息加入到spring的配置文件里面,这种方式需要建立一个dataSource数据库连接。进行ssh整合一般使用第二种方式。
4.把三个框架都添加上去之后,就需要把他们联系起来,下面以一个登录的例子说明他们是怎样配合工作的:
1)、首先从前台发送一个登录的请求,【如下】:
Html代码
<body>
<form action="loginAction.do" method="post">
<table border="1">
<tr><td>name:</td>
<td><input type="text" name="name"/></td></tr>
<tr><td>password:</td>
<td><input type="password" name="password"/></td></tr>
<tr><td colspan="2" align="center">
<input type="submit" value="login"/>
<input type="reset" value="reset"/>
</td>
</tr>
</table>
</form>
</body>

<body>
<form action="loginAction.do" method="post">
<table border="1">
<tr><td>name:</td>
<td><input type="text" name="name"/></td></tr>
<tr><td>password:</td>
<td><input type="password" name="password"/></td></tr>
<tr><td colspan="2" align="center">
<input type="submit" value="login"/>
<input type="reset" value="reset"/>
</td>
</tr>
</table>
</form>
</body>

2)、请求被struts截获,转到struts的配置文件寻找相对应的action【如下】,这时发现找到的是一个代理action,这个代理action就会找到用<plug-in>标签注册的spring插件,从而找到spring的配置文件。
Xml代码
<action-mappings>
<!-- login action -->
<action name="loginActionForm" path="/loginAction"
scope="request"
type="org.springframework.web.struts.DelegatingActionProxy">
<forward name="success" path="/success.jsp"></forward>
<forward name="failed" path="/failed.jsp" redirect="true"></forward>
</action>
</action-mappings>

<message-resources
parameter="com.yourcompany.struts.ApplicationResources" />
<plug-in
className="org.springframework.web.struts.ContextLoaderPlugIn">
<set-property property="contextConfigLocation"
value="/WEB-INF/applicationContext.xml" />
</plug-in>

<action-mappings>
<!-- login action -->
<action name="loginActionForm" path="/loginAction"
scope="request"
type="org.springframework.web.struts.DelegatingActionProxy">
<forward name="success" path="/success.jsp"></forward>
<forward name="failed" path="/failed.jsp" redirect="true"></forward>
</action>
</action-mappings>

<message-resources
parameter="com.yourcompany.struts.ApplicationResources" />
<plug-in
className="org.springframework.web.struts.ContextLoaderPlugIn">
<set-property property="contextConfigLocation"
value="/WEB-INF/applicationContext.xml" />
</plug-in>

3)、在spring的配置文件中寻找跟path属性的名称相同的action,【如下】。在action调用了userService类,userService又调用了userDAO。在userDAO中我们需要做用户的登录验证。
Xml代码
<!-- 依赖注入action -->
<bean name="/loginAction" class="com.dc.action.LoginAction">
<property name="userService" ref="userService"></property>
</bean>

<!-- 依赖注入UserDAO -->
<bean id="userDAO" class="com.dc.dao.UserDAOImpl">
<property name="sessionFactory" ref="SessionFactory"></property>
</bean>

<!-- 依赖注入UserService -->
<bean id="userService" class="com.dc.dao.UserServiceImpl">
<property name="dao" ref="userDAO"></property>
</bean>

<!-- 依赖注入action -->
<bean name="/loginAction" class="com.dc.action.LoginAction">
<property name="userService" ref="userService"></property>
</bean>

<!-- 依赖注入UserDAO -->
<bean id="userDAO" class="com.dc.dao.UserDAOImpl">
<property name="sessionFactory" ref="SessionFactory"></property>
</bean>

<!-- 依赖注入UserService -->
<bean id="userService" class="com.dc.dao.UserServiceImpl">
<property name="dao" ref="userDAO"></property>
</bean>

前面说过,Hibernate的配置信息是添加在spring的配置文件里的,在上面的userDAO中引用的sessionFactory就需要用到这些信息【如下】。
Xml代码
<!-- 配置连接数据库和事物管理参数 -->
<bean id="dataSource"
class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName"
value="com.mysql.jdbc.Driver">
</property>
<property name="url"
value="jdbc:mysql://127.0.0.1:3306/test">
</property>
<property name="username" value="root"></property>
<property name="password" value="root"></property>
</bean>
<bean id="SessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource"></ref>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.MySQLDialect
</prop>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.format_sql">true</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>com/dc/pojo/User.hbm.xml</value></list>
</property>
</bean>

<!-- 配置连接数据库和事物管理参数 -->
<bean id="dataSource"
class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName"
value="com.mysql.jdbc.Driver">
</property>
<property name="url"
value="jdbc:mysql://127.0.0.1:3306/test">
</property>
<property name="username" value="root"></property>
<property name="password" value="root"></property>
</bean>
<bean id="SessionFactory"
class="org.springframework.orm.hibernate3.LocalSessionFactoryBean">
<property name="dataSource">
<ref bean="dataSource"></ref>
</property>
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">
org.hibernate.dialect.MySQLDialect
</prop>
<prop key="hibernate.show_sql">true</prop>
<prop key="hibernate.format_sql">true</prop>
</props>
</property>
<property name="mappingResources">
<list>
<value>com/dc/pojo/User.hbm.xml</value></list>
</property>
</bean>

userDAO的验证方法【如下】:在这个类中继承了一个HibernateDaoSupport类,继承后在配置文件中就可以添加一个sessionFactory属性,用于获取HibernateSessionFactory。
Java代码
public class UserDAOImpl extends HibernateDaoSupport implements UserDAO {
public User checkUser(String name, String password) {
String sql = "from User u where u.name=? and password=?";
List userList = this.getHibernateTemplate().find(sql.toString(),
new Object[]{name, password});
return userList.size() == 0 ? null : (User) userList.get(0);
}
}

public class UserDAOImpl extends HibernateDaoSupport implements UserDAO {
public User checkUser(String name, String password) {
String sql = "from User u where u.name=? and password=?";
List userList = this.getHibernateTemplate().find(sql.toString(),
new Object[]{name, password});
return userList.size() == 0 ? null : (User) userList.get(0);
}
}

4)、找到action后处理用户的登录,【如下】。 userService调用了getUserByParam方法,而在getUserByParam方法中又调用了userDAO的checkUser方法。验证通过后转到成功页面,否则转到失败页面。
Java代码
//用户登录验证
public ActionForward execute(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response) {
LoginActionForm laf = (LoginActionForm) form;
String name = laf.getName();
String password = laf.getPassword();
User user=userService.getUserByParam(name, password);
if(user!=null){
HttpSession session=request.getSession();
session.setAttribute("user", user);
return mapping.findForward("success");
}
return mapping.findForward("failed");
...全文
101 点赞 收藏 回复
写回复
回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
相关推荐
发帖
非技术区
创建于2007-09-28

2.3w+

社区成员

Java 非技术区
申请成为版主
帖子事件
创建了帖子
2011-11-28 01:20
社区公告
暂无公告