jquery html方法xss,jQuery使用中可能被XSS攻击的一些危险环节提醒

$我们经常使用向 $ 内传入一个字符串的方式来选择或生成 DOM 元素,但如果这个字符串是来自用户输入的话,那么这种方式就是有风险的。

先看一个 DEMO:http://jsbin.com/duwuzonife/1/edit?html,js,output

$("");

当用户输入的字符串是像这样的时,虽然这个 元素不会马上被插入到网页的 DOM 中,但这个 DOM 元素已经被创建了,并且暂存在内存里。而对于 元素,只要设置了它的 src 属性,浏览器就会马上请求 src 属性所指向的资源。我们也可以利用这个特性做图片的预加载。在上面的示例代码中,创建元素的同时,也设置了它的属性,包括 src 属性和 onerror 事件监听器,所以浏览器会马上请求图片资源,显然请求不到,随机触发 onerror 的回调函数,也就执行了 JavaScript 代码。

推荐阅读 $ 的官方文档:http://api.jquery.com/jQuery/

类似的其他方法

.after()

.append()

.appendTo()

.before()

.html()

.insertAfter()

.insertBefore()

.prepend()

.prependTo()

.replaceAll()

.replaceWith()

.unwrap()

.wrap()

.wrapAll()

.wrapInner()

.prepend()

以上这些方法不仅创建 DOM 元素,并且会马上插入到页面的 DOM 树中。如果使用 标签插入了内联 JS 会立即执行。

不安全的输入来源

document.URL *

document.location.pathname *

document.location.href *

document.location.search *

document.location.hash

document.referrer *

window.name

document.cookie

document 的大多数属性都可以通过全局的 window 对象访问到。加 * 的属性返回的时编码 (urlencode) 后的字符串,需要解码才可能造成威胁。

不安全的操作把可以被用户编辑的字符串,用在以下场景中,都是有隐患的。总体来说,任何把字符串作为可执行的代码的操作,都是不安全的。

1.通过字符串创建函数

(1)eval

(2)new Function

(3)setTimeout/setInterval

2.跳转页面

location.replace/location.assign

修改 标签的 src 属性

修改事件监听器

总结如果发生在用 jQuery 时被 DOM-XSS 攻击的情况,大多是因为忽视了两个东西:

1. 在给$传参数时,对参数来源的把控。

2. 用户的输入途径不只有表单,还有地址栏,还可以通过开发者工具直接修改 DOM ,或者直接在控制台执行 JS 代码。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
jQuery本身并不会直接导致跨站脚本攻击(XSS)。然而,当使用jQuery或其他JavaScript库执行用户输入时,必须小心处理用户提供的数据以防止XSS攻击。 以下是一些避免jQueryXSS攻击的最佳实践: 1. 避免使用eval()函数:eval()函数可以执行任意的JavaScript代码,包括潜在的恶意脚本。尽量避免使用该函数,而选择更安全的替代方法。 2. 使用.text()而不是.html():当将用户输入作为页面的内容插入时,使用.text()方法而不是.html()方法。这样可以确保用户输入被视为纯文本而不是HTML代码。 3. 对动态创建的元素进行适当的转义:如果通过用户输入动态创建了新的HTML元素或属性,确保适当地转义所有特殊字符。可以使用jQuery的$.text()或$.html()方法进行转义。 4. 过滤和验证用户输入:在接受用户输入之前,要对其进行过滤和验证。移除或转义所有可能包含恶意脚本的特殊字符。可以使用JavaScript的内置函数(如encodeURIComponent())或其他库来实现。 5. 使用安全的选择器:当使用jQuery选择器时,避免将用户输入直接传递给选择器。这可能导致选择器注入攻击。始终对用户输入进行适当的验证和转义。 6. 避免使用不受信任的插件:当使用第三方jQuery插件时,确保只使用受信任的插件,并及时更新插件以修复任何已知的安全漏洞。 这些是一些常用的最佳实践,但请记住,安全是一个复杂的问题,最好结合其他安全措施来确保站点的安全性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值