首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 其他教程 > 其他相关 >

java 应用过滤器控制用户访问权限

2012-10-27 
java 使用过滤器控制用户访问权限控制器类package com.crm.filterimport java.io.IOExceptionimport jav

java 使用过滤器控制用户访问权限
控制器类

package com.crm.filter;   
  
import java.io.IOException;   
import java.io.PrintWriter;   
  
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 LoginFilter implements Filter {   
  
private static final String LOGON_URI = "LOGON_URI";   
  
private static final String HOME_URI = "HOME_URI";   
  
private String logon_page;   
  
private String home_page;   
  
public void destroy() {   
}   
  
public void doFilter(ServletRequest request, ServletResponse response,   
   FilterChain chain) throws IOException, ServletException {   
  HttpServletRequest req = (HttpServletRequest) request;   
  HttpServletResponse resp = (HttpServletResponse) response;   
  resp.setContentType("text/html;");   
  resp.setCharacterEncoding("utf-8");   
  HttpSession session = req.getSession();   
  PrintWriter out = resp.getWriter();   
  // 得到用户请求的URI   
  String request_uri = req.getRequestURI();   
  // 得到web应用程序的上下文路径   
  String ctxPath = req.getContextPath();   
  // 去除上下文路径,得到剩余部分的路径   
  String uri = request_uri.substring(ctxPath.length());   
  // 判断用户访问的是否是登录页面   
  if (uri.equals(logon_page) || uri.equals(home_page)) {   
   chain.doFilter(request, response);   
   return;   
  } else {   
   // 如果访问的不是登录页面,则判断用户是否已经登录   
   if (null != session.getAttribute("curUser")   
     && "" != session.getAttribute("curUser"))    
  
{   
    chain.doFilter(request, response);   
    return;   
   } else {   
    out.println("<script language="javaScript">"  
      + "parent.location.href='" +    
  
ctxPath + logon_page + "'"  
      + "</script>");   
    return;   
   }   
  }   
}   
  
public void init(FilterConfig config) throws ServletException {   
  // TODO Auto-generated method stub   
  // 从部署描述符中获取登录页面和首页的URI   
  logon_page = config.getInitParameter(LOGON_URI);   
  home_page = config.getInitParameter(HOME_URI);   
  // System.out.println(logon_page);   
  if (null == logon_page || null == home_page) {   
   throw new ServletException("没有找到登录页面或主页");   
  }   
}   
  
}   

web.xml


<filter>  
   <filter-name>loginFilter</filter-name>  
   <filter-class>com.crm.filter.LoginFilter</filter-class>  
   <init-param>  
         <param-name>LOGON_URI</param-name>  
         <param-value>/login.jsp</param-value>  
   </init-param>  
   <init-param>  
         <param-name>HOME_URI</param-name>  
         <param-value>/index.jsp</param-value>  
   </init-param>  
</filter>  
<filter-mapping>  
  <filter-name>loginFilter</filter-name>  
  <url-pattern>*.jsp</url-pattern>  
</filter-mapping>  

热点排行