专栏首页啸天"s blogstruts2实现登录后跳转回本页面

struts2实现登录后跳转回本页面

这篇文章上次修改于 281 天前,可能其部分内容已经发生变化,如有疑问可询问作者。

   昨天在项目中用到这种技术,也在网上参考了不少资料,最终还是自己用拦截器处理了。说明方法之前,先说说我项目的情况。

      这是一个前台页面的登录,在好几个页面上都有登录窗口,刚开始做的不管在哪一个登录后都转到了首页,这显然是不太友好的,而且用户直接就能感觉出来的。我现在要实现的就是要在哪一页登录,返回到哪一页的这种情况,不过其它的情况也就大同小异了。下面,我说明方法:   一、新建一个拦截器LoginInter.java。

    代码如下:

import java.util.Map;

import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpSession;

import org.apache.log4j.Logger;
import org.apache.struts2.ServletActionContext;

import com.aircom.zzy.util.StringUtil;
import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
import com.opensymphony.xwork2.interceptor.MethodFilterInterceptor;

//继承可以指定方法的拦截器接口

public class LoginInter extends MethodFilterInterceptor {

  private static final long serialVersionUID = -72827036782663208L;
 
  private static  final Logger log = Logger.getLogger(LoginInter.class);
 
     public final static String SESSION_KEY="regUserId";
     public final static String GOTO_URL_KEY="GOING_TO";  

     protected String doIntercept(ActionInvocation invocation) throws Exception   
      {    
          HttpServletRequest request=ServletActionContext.getRequest();   
            
          HttpSession session=request.getSession();   
          //通过session 判断用户是否登录
          if(session!=null && session.getAttribute(SESSION_KEY)!=null) {   
                  return invocation.invoke();   
           }   
          //这里是关键点了 设置客户原来请求的url地址   
          setToGoingURL(request, session, invocation); 
          return invocation.invoke();   
      }   
  private void setToGoingURL(HttpServletRequest request,HttpSession session,ActionInvocation invocation)   
      {   
          //如果referer不为空 直接使用它。如果为空我们分别获得命名空间,action名,以及请求参数   
          //从新构造成一个URL保存在session中   
          String url=request.getHeader("referer");   
          log.info("待转向URL:"+request.getHeader("referer"));   
          if(url==null || url.equals(""))   
              {   
                  url="";   
                  String path=request.getContextPath();   
                  String actionName=invocation.getProxy().getActionName();   
                  String nameSpace=invocation.getProxy().getNamespace();   
                  if(StringUtil.validateNull(nameSpace))   
                      {   
                          url = url+path+nameSpace;   
                             
                      }   
                  if(StringUtil.validateNull(actionName))   
                      {   
                          url = url+"/"+actionName+".action"+"?";   
                      }   
                     
                  Map<String,String[]> zzMap = request.getParameterMap();   
                  if(zzMap!=null)   
                      {   
                          for(String s:zzMap.keySet())   
                              {   
                                  String[] value=zzMap.get(s);   
                                  for(String val:value)   
                                      {   
                                          url=url+s+"="+val+"&";   
                                      }   
                                     
                              }   
                      }   
                  log.info("完整URL:"+url);   
              }   
                 session.setAttribute(GOTO_URL_KEY, url);   
      }

}

二、新建统一中间跳转页面login_result.jsp

代码如下:

 <%
     String going_to = (String)session.getAttribute("GOING_TO");
     
     if(going_to != null) {
      response.sendRedirect(going_to);
      }
     %>

三、配置struts.xml文件:

代码如下:

<struts>
 <package name="login" extends="common">
  <interceptors>
   <interceptor name="loginInter" class="com.aircom.zzy.interceptor.LoginInter">
   </interceptor>
  </interceptors>
        <action name="login" class="com.aircom.zzy.action.LoginRegistAction" method="login">
            <result name="error">/webapp/login_result.jsp</result>
            <result name="input">/webapp/login_result.jsp</result>
            <result name="success">/webapp/login_result.jsp</result>
          <interceptor-ref name="defaultStack"/>
   <interceptor-ref name="loginInter">

    <!--只拦截这个action中的login方法-->
    <param name="includeMethods">login</param>
   </interceptor-ref>
        </action>
        <action name="logout" class="com.aircom.zzy.action.LoginRegistAction" method="logout">
            <result name="success">/webapp/login_result.jsp</result>
          <interceptor-ref name="defaultStack"/>
   <interceptor-ref name="loginInter">
    <param name="includeMethods">logout</param>
   </interceptor-ref>
        </action>
        <!-- The following set is the action for register. -->
        <action name="goRegister" class="com.aircom.zzy.action.LoginRegistAction" method="goRegisterPage">
            <result name="success">/webapp/register.jsp?num=1</result>
        </action>
        <action name="register" class="com.aircom.zzy.action.LoginRegistAction" method="register">
            <result name="success">/webapp/index.jsp</result>
            <result name="input">/webapp/register.jsp?num=1</result>
        </action>
 </package>
</struts>

结束了,如有什么不懂可以留言噢。呵呵。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • 在CentOS上搭建PHP服务器环境

    chkconfig --levels 235 httpd on 配置完毕,启动apache: /etc/init.d/httpd start 此时输入服务器的I...

    似水的流年
  • 开源世界大冒险 | 第 4 期:Git 基础

    在上一章中我们说到GitHub 并不等同于 Git,在这一篇文章中我们就来了解 Git 和它的基本使用。

    江不知
  • 实战|我们又来了,一次授权渗透测试的记录

    有点东西,2008的服务器,MS17-010和CVE-2019-0708这两个屌炸天的漏洞都不存在,管理员还可以,也是有一个打补丁的好习惯嘛,哈哈哈哈哈哈哈啊哈

    7089bAt@PowerLi
  • 使用wireshark抓取TCP包传输分析

    在我自己机子上安装的是wireshark2.2.6版本,随机查找了某个TCP连接,并跟踪流。

    用户6786055
  • 和重复搭建开发环境说 Bye Bye 之Vagrant

    每每新同事入职,都要在自己电脑上配置一堆环境,费神费力;每每开发测试都要重新配置开发环境,手工搭建,步骤很繁琐,极易出错。

    编程三分钟
  • 使用 gor 复制真实流量压测ES集群

    生产环境下, 我们一般使用 esrally来做es的基准测试。 但是毕竟和真实生产的请求场景可能有差异的。 

    二狗不要跑
  • 测试开发进阶(四十五)

    https://github.com/zx490336534/ApiTest/tree/master/DeployApiTest

    zx钟
  • 机器学习在网络安全中的正确打开方式,你学废了吗?

    机器学习模型被越来越多地应用到网络安全领域,如:恶意软件检测、恶意脚本检测、加密流量监控、钓鱼邮件检测等等,机器学习在网络安全中的应用看似越来越广,但实际应用到...

    绿盟科技研究通讯
  • 软件安全性测试(连载1)

    软件安全性包括软件功能安全性和软件信息安全性。软件功能安全性是指当软件发生故障的时候,会自动切换到安全模式。比如高铁在运行过程中遇到雷电袭击后,系统软件就应该...

    小老鼠
  • Hosts的作用

    顾翔老师开发的bugreport2script开源了,希望大家多提建议。文件在https://github.com/xianggu625/bug2testscr...

    小老鼠

扫码关注云+社区

领取腾讯云代金券