过滤器和拦截器

过滤器
package com.xy.filter;
import java.io.IOException;
import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

public class IsLoginFilter implements Filter
{

    public void destroy()
    {

    }

    public void doFilter(ServletRequest req, ServletResponse resp, FilterChain
                     chain)throws IOException, ServletException
    {
        HttpServletRequest request = (HttpServletRequest) req;
        HttpServletResponse response = (HttpServletResponse) resp;
        HttpSession session = request.getSession();
        if (null == session.getAttribute("uinfo"))
        {
            request.setAttribute("msg", "您未登录或者离线时间过长,请重新登录");
            request.getRequestDispatcher("/ToLoginAction")
                                 .forward(request, response);
        }
        else
        {
            chain.doFilter(request, response);
        }
    }

    public void init(FilterConfig arg0) throws ServletException
    {

    }

}


login.jsp

<input type="hidden" value="${requestScope.msg}" id="msg" />
<script type="text/javascript">
var msg = document.getElementByIdx_x("msg").value;
if ("" != msg) {
    alert(msg);
}
</script>
当然可以在js中直接获取${requestScope.msg}。


web.xml
<filter>
    <filter-name>login</filter-name>
        <filter-class>com.xy.filter.IsLoginFilter</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>login</filter-name>
        <url-pattern>/logined/*</url-pattern>
    </filter-mapping>
</filter>






下面是拦截器

package com.xy.interceptor;

import javax.servlet.http.HttpSession;

import org.apache.struts2.ServletActionContext;

import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.AbstractInterceptor;
import com.xy.pojo.Manager;

public class AuthInterceptor extends AbstractInterceptor
{
    @Override
    public String intercept(ActionInvocation invocation) throws Exception
    {
        HttpSession session = ServletActionContext.getRequest().getSession();
        ServletActionContext.getRequest()
                       .setAttribute("loginMsg", "您未登录或者离线时间过长,请重新登录");
        Manager login = (Manager) session.getAttribute("manager");
        if (login != null) return invocation.invoke();
        else return "mustlogin";
    }
}



login.jsp

<script type="text/javascript">
$(function (){
        
var loginMsg ='<s:property value="#request.loginMsg" escape="false"/>';
if(""!=loginMsg)
{
    alert(loginMsg);
}
});
</script>

struts.xml

<package name="default" namespace="/" extends="struts-default">

        <interceptors>
            <!-- 权限控制拦截器 -->
            <interceptor name="login"  class="com.xy.interceptor.AuthInterceptor"></interceptor>

            <!-- 定义一个包含权限控制的拦截器 -->
            <interceptor-stack name="mydefault">
                <interceptor-ref name="defaultStack"></interceptor-ref>
                <interceptor-ref name="login"></interceptor-ref>
            </interceptor-stack>
        </interceptors>

        <default-action-ref name="tomain"></default-action-ref>

        <!-- 定义全局处理结果 -->
        <global-results>
            <result name="mustlogin">/login.jsp</result>
        </global-results>

        <action name="tomain" class="com.xy.action.ToMainAction">
            <result name="success">/main.jsp</result>
        </action>

        <action name="toLogin" class="com.xy.action.ToLoginAction">
            <result>/login.jsp</result>
        </action>

        <action name="loginVerify" class="com.xy.action.LoginVerifyAction">
            <result name="success" type="chain">tomain</result>
            <result name="error">/login.jsp</result>
        </action>

        <action name="stu_*" class="com.xy.action.StudentAction"
            method="{1}">
            <interceptor-ref name="mydefault" />
            <result name="tomodify">/modify.jsp</result>
            <result name="toadd">/add.jsp</result>
            <result name="success" type="chain">tomain</result>
        </action>
</package>

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值