Struts2登录及其拦截器的实现(Struts2+Hibernate)

1 登录功能的简单实现

1.1 Action类

package com.itykd.web.action;

import org.apache.struts2.ServletActionContext;

import com.itykd.domain.User;
import com.itykd.service.UserService;
import com.itykd.service.impl.UserServiceImpl;
import com.opensymphony.xwork2.ActionSupport;
import com.opensymphony.xwork2.ModelDriven;

public class LoginAction extends ActionSupport implements ModelDriven<User>{
	private User user = new User();
	@Override
	public User getModel() {
		return user;
	}
	public String login() {
		UserService userService = new UserServiceImpl();
		User existUser = userService.login(user);
		if(existUser == null){
			this.addActionError("用户名或密码错误");
			return LOGIN;
		}else{
			ServletActionContext.getRequest().getSession().setAttribute("existUser", existUser);
			return SUCCESS;
		}
	}

}

1.2  struts.xml的配置

<struts>
	<package name="demo" extends="struts-default" namespace="/">
		<action name="login_*" class="com.itykd.web.action.LoginAction" method="{1}">
		    <result name="success" type="redirect">/success.jsp</result>
		    <result name="login">/loginTest.jsp</result>
		</action>
</struts>

1.3 jsp页面的编写 

<%@ page language="java" contentType="text/html; charset=UTF-8"
    pageEncoding="UTF-8"%>
<%@ taglib uri="/struts-tags" prefix="s" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
</head>
<body>
    <s:actionerror/>
	<form action="${pageContext.request.contextPath }/login_login.action" method="post">
	        用户名 :<input type="text" name="user_code" /><br/> 
	        密码:<input type="password" name="user_password"/><br/> 
	   <input type="submit" value="提交"/>
	</form>
</body>
</html>

 1.4 service层编写

package com.itykd.service.impl;

import com.itykd.dao.UserDao;
import com.itykd.dao.impl.UserDaoImpl;
import com.itykd.domain.User;
import com.itykd.service.UserService;

public class UserServiceImpl implements UserService {

	@Override
	public User login(User user) {
		UserDao userDao = new UserDaoImpl();
		return userDao.login(user);
	}

}

1.5 dao层编写

package com.itykd.dao.impl;

import java.util.List;

import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.Transaction;

import com.itykd.dao.UserDao;
import com.itykd.domain.User;
import com.itykd.util.HibernateUtils;

public class UserDaoImpl implements UserDao {

	@Override
	public User login(User user) {
		Session session = HibernateUtils.getCurrentSession();
		Transaction tx = session.beginTransaction();	
		Query query = session.createQuery("from User where user_code=? and user_password=?");
		query.setParameter(0, user.getUser_code());
		query.setParameter(1, user.getUser_password());
		List<User> list = query.list();
		if(list.size()>0){
			return list.get(0);
		}
		
		tx.commit();
		return null;
	}

}

2 登录拦截器的实现 

2.1 Interceptor类的编写

package com.itykd.web.interceptor;

import org.apache.struts2.ServletActionContext;

import com.itykd.domain.User;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.ActionSupport;
import com.opensymphony.xwork2.interceptor.MethodFilterInterceptor;

public class PrivilegeInterceptor extends MethodFilterInterceptor{

	@Override
	protected String doIntercept(ActionInvocation invocation) throws Exception {
		//判断session中是否存在用户数据
		User existUser=(User) ServletActionContext.getRequest().getSession().getAttribute("existUser");
		//判断从session中获取的用户的信息是否为空
		if(existUser==null) {
			//session中没有用户信息,则没有登录
			ActionSupport actionSupport = (ActionSupport) invocation.getAction();
			//输出提示信息
			actionSupport.addActionError("没有登录,没有权限访问");
			//返回登录页面
			return actionSupport.LOGIN;
		}else {
			//已经登录
			return invocation.invoke();
			
		}
		
	}

}

 2.2 拦截器的配置

<struts>
	<package name="demo" extends="struts-default" namespace="/">
    	<interceptors>
	        <interceptor name="privilegeInterceptor" class="com.itykd.web.interceptor.PrivilegeInterceptor"/>	    
	    </interceptors>
		<action name="login_*" class="com.itykd.web.action.LoginAction" method="{1}">
		    <result name="success" type="redirect">/success.jsp</result>
		    <result name="login">/loginTest.jsp</result>
          <!-- 引入拦截器 -->
			<interceptor-ref name="privilegeInterceptor"> 
		        <!-- LoginAction.login()不需要进行拦截 -->
		       <param name="execludeMethods">login</param>
		    </interceptor-ref>
		    <interceptor-ref name="defaultStack"/>
		</action>
</struts>

猜你喜欢

转载自blog.csdn.net/W2612888/article/details/85217804