文档章节

struts2验证用户是否登陆

 南桥北木
发布于 2017/02/16 10:05
字数 268
阅读 5
收藏 0

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>

© 著作权归作者所有

共有 人打赏支持
粉丝 0
博文 164
码字总数 27655
作品 0
武汉
关于struts2中的拦截器和登陆验证

今天给几个热爱JAVA的同学们讲了Struts2的一些知识,重点讨论了其最具价值的拦截器。 不知道大家还记不记得,在《Struts2之服务器端验证》里我说过这样一句话“在到达Login Action之前,验证已...

长平狐
2012/11/12
3K
0
jquery.uploadify 上传插件cookie丢失问题。

因为jquery.uploadify上传插件是通过flash来运行上传的。 然后才会进入我的action, 本人环境struts2。 有一登陆验证拦截器。 根据cookie判断是否登陆。 ----- 以下三种环境 IE ,request中的...

吴叙文
2010/11/19
3.6K
6
浅谈Struts2拦截器的原理与实现

拦截器与过滤器 拦截器是对调用的Action起作用,它提供了一种机制可以使开发者定义在一个action执行的前后执行的代码,也可以在一个action执行前阻止其执行。同时也是提供了一种可以提取act...

chape
2013/06/08
0
0
Struts2安全缺陷(上)(转)

本文介绍了java开发流行框架struts2以及webwork的一些安全缺陷,并举例说明框架本身以及开发人员使用框架时,所产生的种种安全问题,以及作者挖掘框架安全漏洞的一些心得体会。 推荐以下人群...

floger
2010/11/25
0
1
Struts2安全缺陷(上)(转)

本文介绍了java开发流行框架struts2以及webwork的一些安全缺陷,并举例说明框架本身以及开发人员使用框架时,所产生的种种安全问题,以及作者挖掘框架安全漏洞的一些心得体会。 推荐以下人群...

wsj
2010/11/08
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

Nginx防盗链、访问控制、Nginx解析PHP相关配置、Nginx代理

Nginx防盗链 在配置文件里写入以下内容: 用curl测试 访问控制 Nginx限制某些IP不能访问或者只允许某些IP访问。 配置文件写入如下内容: allow 表示允许访问的IP,deny限制访问的IP。 匹配正...

黄昏残影
11分钟前
0
0
自己动手实现RPC服务调用框架

转载 TCP的RPC 引言 本文利用java自带的socket编程实现了一个简单的rpc调用框架,由两个工程组成分别名为battercake-provider(服务提供者)、battercake-consumer(服务调用者)。 设计思路...

雨中漫步的鱼
14分钟前
0
0
Centos6.x安装之后的9件事

Centos6.x安装之后的9件事 这些不是必须都做的,只不过是我个人的习惯,在此记录一下。 1.修改yum源到国内 CentOS系统更换软件安装源 备份你的原镜像文件,以免出错后可以恢复。 mv /etc/yu...

叶云轩
19分钟前
5
0
springboot2 使用jsp NoHandlerFoundException

开发图片上传功能,为验证测试功能是否正常,使用JSP编写表单提交进行测试 开发完成后,请求API提示如下异常: No mapping found for HTTP request with URI [/WEB-INF/jsp/avatar_upload.j...

showlike
25分钟前
0
0
springboot踩坑记--springboot正常启动但访问404

一 spring boot的启动类不能直接放在main(src.java.main)这个包下面,把它放在有包的里面就可以了。 二 正常启动了,但是我写了一个controller ,用的@RestController 注解去配置的controlle...

onedotdot
26分钟前
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部