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

精贴 置顶
1500 0

控制器类


   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("");
  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
  
  loginFilter
  com.crm.filter.LoginFilter
  
  LOGON_URI
  /login.jsp
  
  
  HOME_URI
  /index.jsp
  
  
  
  loginFilter
  *.jsp

  • 没有任何评论
今日天气 ···

···

···

···

热门排行
CSS cursor鼠标样式一览表 2012-06-25
.NET后台写JS代码 2011-11-03
网站地址多出jdfwkey的问题解析及... 2010-08-25
数据库xxx的日志已满,请备份该数... 2013-07-19
百度、google、Yahoo网站地图制作... 2011-01-30
<a>标签的伪类书写顺序问题... 2010-09-04
什么是长尾关键词? 2010-09-24
CEO名言 2010-08-31
Mysql 主从数据库同步 2010-09-12
用ASP实现网页BBS 2010-11-01
博主推荐
本个人博客微信公众平台上线啦~~... 2013-10-13
饼哥网络互联上线啦~~要买域名空... 2013-09-20
网站title标题如何正确修改不会被... 2013-08-26
饼哥通讯录系统上线啦,欢迎大家... 2013-08-24
ASP .NET MYSQL 的简单分页 并不... 2013-08-19
网站有弹窗广告这样的站点,百度... 2013-08-17
做淘宝SEO优化需要注意的8大问题 2013-08-17
淘宝网怎么做SEO优化 2013-08-17
站长们要学习的“苍井空精神” 2013-08-17
苹果公司今日发布了iOS 7第五个开... 2013-08-07
随便看看
递归计算子节点的个数 2010-10-12
避免系统重装遇病毒攻击的九招 2010-09-07
同一IP的网站友情链接对SEO的影响... 2010-08-30
Unicode的一些类型转换问题 2013-11-11
好消息!好消息!各位朋友们看过... 2013-06-25
.net将IP转换为10进制 2013-07-18
sql注入语句 2010-12-06
ADO 存取数据库时如何分页显示 2010-10-19
网站降权的原因和表现 2013-06-23
用cssText批量修改样式 2010-09-05
RSS新闻
传媒新闻
CSDN
八卦新闻
女性新闻
台湾新闻
互联网
军事-新浪博客
IT-新浪博客
汽车新闻
游戏新闻
国际新闻
国内新闻
体育新闻
我的微博
北京 上海 杭州 深圳 广州 成都