struts2验证用户是否登陆

login.jsp

<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>

<!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> <form action="loginaction" method="post"> <center> <h2>用户登录</h2> ${loginerror} 用户:<input type="text" name="username"><br><br>

    密码:<input type="password" name="password"><br><br>
  <input type="submit" value="提交">   
</center>

</form> </body> </html>

struts.xml

<?xml version="1.0" encoding="UTF-8" ?>

<!DOCTYPE struts PUBLIC "-//Apache Software Foundation//DTD Struts Configuration 2.1//EN" "http://struts.apache.org/dtds/struts-2.1.dtd">

<struts> <package name="default" namespace="/" extends="struts-default"> <!-- 注册拦截器 --> <interceptors> <interceptor name="validate" class="com.validate.lan.AuthorIntercept"></interceptor> </interceptors> <action name="author"> <result>/login.jsp</result> <result name="login">/login.jsp</result>

      <!-- 引用拦截器 -->

       <interceptor-ref name="defaultStack"></interceptor-ref>

       <interceptor-ref name="validate"></interceptor-ref> 

        
   </action>
    <action name="loginaction" class="com.validate.action.LoginAction" method="login">
        <result name="success">/manager.jsp</result>
        <result name="error">/login.jsp</result>
     
      
    </action>
</package>

</struts>

3LoginAction.java

package com.validate.action;

import java.util.Map;

import javax.jms.Session;

import org.apache.struts2.interceptor.SessionAware;

import com.opensymphony.xwork2.ActionSupport;

public class LoginAction extends ActionSupport implements SessionAware{ private String username; public String getUsername() { return username; }

public void setUsername(String username) {
	this.username = username;
}

public String getPassword() {
	return password;
}

public void setPassword(String password) {
	this.password = password;
}

private String password;

private Map<String,Object> session;

public void setSession(Map<String, Object> session) {
	  this.session=session;
}

public String login(){
	  if("123".equals(username)&&"123".equals(password)){
		  session.put("logininfo", username);
		  return SUCCESS;
	  }else{
		  session.put("loginerror", "用户名或密码错误");
		  return ERROR;  
	  }
}

}

4 AuthorIntercept.java

package com.validate.lan;

import java.util.Map;

import com.opensymphony.xwork2.ActionContext; import com.opensymphony.xwork2.ActionInvocation; import com.opensymphony.xwork2.interceptor.AbstractInterceptor;

public class AuthorIntercept extends AbstractInterceptor {

@Override
public String intercept(ActionInvocation invocation) throws Exception {
	ActionContext context=ActionContext.getContext();
	Map<String,Object> session=context.getSession();
	if(session.get("logininfo")!=null){
		String result=invocation.invoke();
		return result;
	}else{
		return "login";
	}
	

}

}

5 小知识 自定义拦截器栈

<interceptors>

    <interceptor name="validate" class="com.validate.lan.AuthorIntercept"></interceptor>

    <interceptor-stack name="mystack">

        <interceptor-ref name="validate"></interceptor-ref>

        <interceptor-ref name="defaultStack"></interceptor-ref>

    </interceptor-stack>

</interceptors>

转载于:https://my.oschina.net/u/2511906/blog/839716

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值