过滤器权限校验

package com.web.study;

import java.io.IOException;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.RequestDispatcher;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.Filter;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

public class PermissionFilter implements Filter {

	public PermissionFilter() {
		
	}

	private FilterConfig filterConfig;

	public void init(FilterConfig filterConfig) throws ServletException {
		
	}

	public void doFilter(ServletRequest req, ServletResponse res, FilterChain filterChain) throws IOException,ServletException {

		HttpServletRequest request = (HttpServletRequest)req;
		HttpServletResponse response = (HttpServletResponse)res;
		
		String servletPath = request.getServletPath();
		HttpSession session = request.getSession();
		String flag = (String)session.getAttribute("flag");
		
		if (servletPath.equals("/Jsp/logon.jsp")||servletPath.equals("/Jsp/index.jsp")||servletPath.equals("/LoginServlet")) {
			filterChain.doFilter(req, res);
		}
		else {
			if(flag!=null&&flag.equals("login_success")){
				filterChain.doFilter(req, res);
			}
			else if (flag!=null && flag.equals("login_error")) {
				request.setAttribute("return_uri", servletPath);
				RequestDispatcher rd = request.getRequestDispatcher("/Jsp/login.jsp");
				rd.forward(request, response);
			}
			else {
				request.setAttribute("return_uri", servletPath);
			    RequestDispatcher rd = request.getRequestDispatcher("/Jsp/login.jsp");
			    rd.forward(request, response);
			}
			
		}
		
		
	}

	public void destroy() {

	}
}

  

转载于:https://www.cnblogs.com/wzz1020/p/4687343.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值