访问权限过滤器

<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);">一、创建过滤器的类,并实现</span><span style="font-family: Calibri; background-color: rgb(255, 255, 255);">Filter</span><span style="font-family: 宋体; background-color: rgb(255, 255, 255);">(</span><span style="font-family: Calibri; background-color: rgb(255, 255, 255);">javax.servlet.Filter</span><span style="font-family: 宋体; background-color: rgb(255, 255, 255);">)接口</span>

package com.am.utils;

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;

/**
 * 访问权限过滤器
 * @author A.m
 *
 */
public class AuthFilter implements Filter{

	public void destroy() {
		// TODO Auto-generated method stub
		
	}

	public void doFilter(ServletRequest arg0, ServletResponse arg1,
			FilterChain arg2) throws IOException, ServletException {
		
		//转为http请求
		HttpServletRequest request=(HttpServletRequest)arg0;
		HttpServletResponse response=(HttpServletResponse)arg1;
		
		//获取请求的路径:/ssmModel/page/login.jsp
		String currentUrl=request.getRequestURI();
		//截取文件名:/login.jsp
		String targetURL = currentUrl.substring(currentUrl.lastIndexOf("/"),  
				currentUrl.length());
		
		//判定不是登录页面且不是登录接口
		if(!"/login.jsp".equals(targetURL)&&!"/login.html".equals(targetURL)){
			Object user=request.getSession().getAttribute("user");
			if(user==null){
			    response.sendRedirect("/ssmModel/page/login.jsp");  
			    // 如果session为空表示用户没有登录就重定向到login.jsp页面  
			    return;
			}
		}
		
		//使请求继续向下执行
		arg2.doFilter(arg0, arg1);
	}

	public void init(FilterConfig arg0) throws ServletException {
		// TODO Auto-generated method stub
		
	}
	
}

二、web.xml中配置过滤器

 <!-- 定义filter -->
	<filter>
		 <!-- filter的名字 -->
		<filter-name>AuthFilter</filter-name>
		 <!-- filter的路径 -->
		<filter-class>com.am.utils.AuthFilter</filter-class>
	</filter>
	 <!-- 定义filter过滤的地址 -->
	 <!-- 可有多个filter-mapping,则可过滤多个URL -->
	<filter-mapping>
		 <!-- filter的名字 -->
		<filter-name>AuthFilter</filter-name>
		 <!-- filter需要过滤的URl -->
		<url-pattern>/page/*</url-pattern>
		 <!-- 请求类型:REQUEST,FORWARD,INCLUDE,ERROR -->
		 <!-- 默认REQUEST -->
		<dispatcher>REQUEST</dispatcher>
		<dispatcher>FORWARD</dispatcher>
	</filter-mapping>



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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值