仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 545|回复: 8
打印 上一主题 下一主题

[学习教程] 了解下JAVA的Servlet过滤器先容之有用过滤器

[复制链接]
跳转到指定楼层
楼主
发表于 2015-1-18 11:11:48 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

x
java主要分三块,j2se:java的基础核心语言。j2me:java的微型模块,专门针对内存小,没有持续电源等小型设备。j2ee:java的企业模块,专门针对企业数据库服务器的连接维护。
6.克制站点过滤器
假如你但愿在你的过滤器检测到不一般的非常而半途中止前面的过滤历程时,可如许做:
publicvoiddoFilter(ServletRequestrequest,ServletResponseresponse,
   FilterChainchain)throwsServletException,IOException{
  HttpServletRequestreq=(HttpServletRequest)request;
  HttpServletResponseres=(HttpServletResponse)response;
  if(isUnusualCondition(req)){
   res.sendRedirect("http://www.somesite.com");
  }else{
   chain.doFilter(req,res);
  }
}
下例是一个克制站点过滤器,假如不但愿某些站点会见你的网站,你能够在web.xml的param-value中列出它的站点,然后使用下面的道理跳出惯例过滤,给出克制会见的页面。
BannedAccessFilter.java
  1. packagecom.zj.sample;
  2. importjava.io.IOException;
  3. importjava.io.PrintWriter;
  4. importjava.net.MalformedURLException;
  5. importjava.net.URL;
  6. importjava.util.HashSet;
  7. importjava.util.StringTokenizer;
  8. importjavax.servlet.Filter;
  9. importjavax.servlet.FilterChain;
  10. importjavax.servlet.FilterConfig;
  11. importjavax.servlet.ServletException;
  12. importjavax.servlet.ServletRequest;
  13. importjavax.servlet.ServletResponse;
  14. importjavax.servlet.http.HttpServletRequest;
  15. publicclassBannedAccessFilterimplementsFilter{
  16. privateHashSet<String>bannedSiteTable;
  17. /**
  18. *Denyaccessiftherequestcomesfromabannedsiteorisreferredhere
  19. *byabannedsite.
  20. */
  21. publicvoiddoFilter(ServletRequestrequest,ServletResponseresponse,
  22. FilterChainchain)throwsServletException,IOException{
  23. System.out.println("WithinBannedAccessFilter:FilteringtheRequest...");
  24. HttpServletRequestreq=(HttpServletRequest)request;
  25. StringrequestingHost=req.getRemoteHost();
  26. StringreferringHost=getReferringHost(req.getHeader("Referer"));
  27. StringbannedSite=null;
  28. booleanisBanned=false;
  29. if(bannedSiteTable.contains(requestingHost)){
  30. bannedSite=requestingHost;
  31. isBanned=true;
  32. }elseif(bannedSiteTable.contains(referringHost)){
  33. bannedSite=referringHost;
  34. isBanned=true;
  35. }
  36. if(isBanned){
  37. showWarning(response,bannedSite);
  38. }else{
  39. chain.doFilter(request,response);
  40. }
  41. System.out.println("WithinBannedAccessFilter:FilteringtheResponse...");
  42. }
  43. /**
  44. *Createatableofbannedsitesbasedoninitializationparameters.
  45. *Rememberthatversion2.3oftheservletAPImandatestheuseofthe
  46. *Java2Platform.Thus,itissafetouseHashSet(whichdetermines
  47. *whetheragivenkeyexists)ratherthantheclumsierHashtable
  48. *(whichhasavalueforeachkey).
  49. */
  50. publicvoidinit(FilterConfigconfig)throwsServletException{
  51. bannedSiteTable=newHashSet<String>();
  52. StringbannedSites=config.getInitParameter("bannedSites");
  53. //Defaulttokenset:whitespace.
  54. StringTokenizertok=newStringTokenizer(bannedSites);
  55. while(tok.hasMoreTokens()){
  56. StringbannedSite=tok.nextToken();
  57. bannedSiteTable.add(bannedSite);
  58. System.out.println("Banned"+bannedSite);
  59. }
  60. }
  61. publicvoiddestroy(){}
  62. privateStringgetReferringHost(StringrefererringURLString){
  63. try{
  64. URLreferringURL=newURL(refererringURLString);
  65. return(referringURL.getHost());
  66. }catch(MalformedURLExceptionmue){//Malformedornull
  67. return(null);
  68. }
  69. }
  70. //Replacementresponsethatisreturnedtousers
  71. //whoarefromorreferredherebyabannedsite.
  72. privatevoidshowWarning(ServletResponseresponse,StringbannedSite)
  73. throwsServletException,IOException{
  74. response.setContentType("text/html");
  75. PrintWriterout=response.getWriter();
  76. StringdocType="<!DOCTYPEHTMLPUBLIC"-//W3C//DTDHTML4.0"
  77. +"Transitional//EN">
  78. ";
  79. out.println(docType+"<HTML>
  80. "
  81. +"<HEAD><TITLE>AccessProhibited</TITLE></HEAD>
  82. "
  83. +"<BODYBGCOLOR="WHITE">
  84. "+"<H1>AccessProhibited</H1>
  85. "
  86. +"Sorry,accessfromorvia"+bannedSite+"
  87. "
  88. +"isnotallowed.
  89. "+"</BODY></HTML>");
  90. }
  91. }
复制代码
<p>
什么时候上述的三种开发工具能和三为一,什么时候java的竞争力才更强,才有机会拉拢更多的程序员投入到对java的开发上,因为到时的开发工具将会比.net的更简单。还有一点也很关键,什么时候java推出的jsf能成为真正意义上的标准。
爱飞 该用户已被删除
沙发
发表于 2015-1-29 13:09:53 | 只看该作者
J2SE开发桌面应用软件比起 VC,VB,DEPHI这些传统开发语言来说,优势好象并不明显。J2ME对于初学者来说,好象又有点深奥,而且一般开发者很难有开发环境。
小魔女 该用户已被删除
板凳
发表于 2015-2-6 01:15:50 | 只看该作者
科学超级计算机、移动电话和互联网,同时拥有全球最大的开发者专业社群。
飘灵儿 该用户已被删除
地板
发表于 2015-2-7 02:24:23 | 只看该作者
《JAVA语言程序设计》或《JAVA从入门到精通》这两本书开始学,等你编程有感觉的时候也可以回看一下。《JAVA读书笔记》这本书,因为讲的代码很多,也很容易看懂,涉及到面也到位。是你学习技术巩固的好书,学完后就看看《JAVA编程思想》这本书,找找一个自己写的代码跟书上的代码有什么不一样。
活着的死人 该用户已被删除
5#
发表于 2015-2-9 18:27:51 | 只看该作者
在全球云计算和移动互联网的产业环境下,Java更具备了显著优势和广阔前景。
愤怒的大鸟 该用户已被删除
6#
发表于 2015-2-27 15:43:56 | 只看该作者
你就该学一学Servlet了。Servlet就是服务器端小程序,他负责生成发送给客户端的HTML文件。JSP在执行时,也是先转换成Servlet再运行的。虽说JSP理论上可以完全取代Servlet,这也是SUN推出JSP的本意,可是Servlet用来控制流程跳转还是挺方便的,也令程序更清晰。接下来你应该学习一下Javabean了,可能你早就看不管JSP在HTML中嵌Java代码的混乱方式了,这种方式跟ASP又有什么区别呢?
简单生活 该用户已被删除
7#
发表于 2015-3-9 08:23:49 | 只看该作者
当然你也可以参加一些开源项目,一方面可以提高自己,另一方面也是为中国软件事业做贡献嘛!开发者在互联网上用CVS合作开发,用QQ,MSN,E-mail讨论联系,天南海北的程序员分散在各地却同时开发同一个软件,是不是很有意思呢?
若相依 该用户已被删除
8#
发表于 2015-3-16 21:16:39 | 只看该作者
多重继承(以接口取代)等特性,增加了垃圾回收器功能用于回收不再被引用的对象所占据的内存空间,使得程序员不用再为内存管理而担忧。在 Java 1.5 版本中,Java 又引入了泛型编程(Generic Programming)、类型安全的枚举、不定长参数和自动装/拆箱等语言特性。
兰色精灵 该用户已被删除
9#
发表于 2015-3-23 01:55:09 | 只看该作者
关于设计模式的资料,还是向大家推荐banq的网站 [url]http://www.jdon.com/[/url],他把GOF的23种模式以通俗易懂的方式诠释出来,纯Java描述,真是经典中的经典。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2025-1-11 06:00

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表