程序员吐槽之java编程xss的漏洞解析与防护

程序员吐槽之java编程xss的漏洞解析与防护

小熊吐槽之java编程xss的漏洞解析与防护

程序员吐槽之java编程xss的漏洞解析与防护

小熊吐槽之java编程xss的漏洞解析与防护

对于的用户输入中出现XSS漏洞的问题,主要是由于开发人员对XSS了解不足,安全的意识不够造成的。现在让我们来普及一下XSS的一些常识,以后在开发的时候,每当有用户输入的内容时,都要加倍小心。请记住两条原则:过滤输入和转义输出。

一、什么是XSS

XSS又叫CSS (Cross Site Script) ,跨站脚本攻击。它指的是恶意攻击者往Web页面里插入恶意html代码,当用户浏览该页之时,嵌入其中Web里面的html代码会被执行,从而达到恶意的特殊目的。XSS属于被动式的攻击,因为其被动且不好利用,所以许多人常呼略其危害性。

在WEB2.0时代,强调的是互动,使得用户输入信息的机会大增,在这个情况下,我们作为开发者,在开发的时候,要提高警惕。

程序员吐槽之java编程xss的漏洞解析与防护

小熊吐槽之java编程xss的漏洞解析与防护

二、XSS攻击的主要途径

XSS攻击方法只是利用HTML的属性,作各种的尝试,找出注入的方法。现在对三种主要方式进行分析。

第一种:对普通的用户输入,页面原样内容输出。

第二种:在代码区里有用户输入的内容

原则就是,代码区中,绝对不应含有用户输入的东西。

第三种:允许用户输入HTML标签的页面。

用户可以提交一些自定义的HTML代码,这种情况是最危险的。因为,IE浏览器默认采用的是UNICODE编码,HTML编码可以用ASCII方式来写,又可以使用”/”连接16进制字符串来写,使得过滤变得异常复杂,如下面的四个例子,都可以在IE中运行。

1,直接使用JS脚本。

2,对JS脚本进行转码。

3,利用标签的触发条件插入代码并进行转码。

4,使用16进制来写(可以在傲游中运行)

以上写法等于

程序员吐槽之java编程xss的漏洞解析与防护

小熊吐槽之java编程xss的漏洞解析与防护

三、XSS攻击解决办法

请记住两条原则:过滤输入和转义输出。

具体执行的方式有以下几点:

第一、在输入方面对所有用户提交内容进行可靠的输入验证,提交内容包括URL、查询关键字、http头、post数据等

第二、在输出方面,在用户输内容中使用

标签。标签内的内容不会解释,直接显示。<p>第三、严格执行字符输入字数控制。</p><p>四、在脚本执行区中,应绝无用户输入。</p><p><img class="lazy" data-original="//p2.ttnews.xyz/5bbd18b0bd3c314ce69799e2.jpg" img_width="639" img_height="116" alt="程序员吐槽之java编程xss的漏洞解析与防护" inline="0"/></p><p class="pgc-img-caption">小熊吐槽之java编程xss的漏洞解析与防护</p><blockquote><p>欢迎大家在下方积极吐槽,小编会一一进行查看并回复,期待你的答案哦……</p> <div class="lazy-load-ad"></div><p>小熊转载自 博客园,如果喜欢请转发,小小支持一下。</p></blockquote>


分享到:


相關文章: