聊两句XSS(跨站脚本攻击)
XSS(跨站脚本攻击),聊两句,五毛的。
XSS的危害:
- 窃取Cookie,盗用用户身份信息
这玩意儿是大多数XSS的目标,也好解决,可以先治个标,直接设置HttpOnly=true
,即不允许客户端脚本访问,设置完成后,通过js去读取cookie,你会发现document.cookie
无法读取到被标识为HttpOnly的Cookie内容了。
- 配合其他漏洞,如CSRF(跨站请求伪造)
这个其实就没那么好解决了,因为XSS利用用户身份构造的请求其实对于服务端来说是合法的。比如说咱在B站上传了一条视频,发现没几个人点赞,于是动了歪心思,打开控制台找到了投币点赞的接口,然后拿到了对应的请求参数。自己构造了一条投币请求,然后诱导其他人点击含有这个脚本的页面为咱的视频投币,这样就完成了一套攻击流程。
不用尝试了,没用的。别问我怎么知道的 =。=。
要是没做校验的话,那这就是一个高危漏洞,还传啥视频啊,赶紧发邮件给阿B领赏金去啊。
- 广告
只要能发起XSS,我就能往页面里插广告,啥权限都不要,但是能引发这个问题的原因主要有两个。
- XSS。
- 用户自己安装外部脚本。
使用外部脚本一定要保证脚本来源的可信性,脚本的安全性。如果脚本是恶意的,那么他所能做的可就不只是弹弹广告这么简单了,替换个按钮,诱导点击钓鱼页面,替换某一条搜索结果,这都是可能的。
XSS扫描及防范
XSS风险有些是可以通过code review发现的,比如:
let result = document.getElementById('test');
result.innerHTML = await getInfo();
这段代码很容易看到风险位置——innerHTML
,如果后端返回的数据中包含恶意的代码片段,那么就能够被攻击。所以在使用Vue和React框架时,需要评估是否真的需要使用v-html
和dangerouslySetInnerHTML
功能,在前端的render(渲染)阶段就避免innerHTML
和 outerHTML
[1]。
如果不使用框架,那就避免直接使用
innerHTML
就好了。
至于review时无法发现的风险,那就交给扫描器吧。
防范XSS,除了少使用、不使用innerHTML
外,还可以设置严格的CSP[2],限制用户的输入长度。
XSS是一个安全问题,它不只是前端的职责,这也是所有RD和QA的职责。
前端过滤用户输入后发给后端,后端如果不做处理存入数据库,那么这就是一个攻击点:直接抓前端的包,重新组装一下参数,发给后端,完成存储型XSS第一步,用户再访问这部分内容,就完成了一次XSS。
QA的总能搞出来一些奇奇怪怪的payload(亦称测试用例),这些可能都是RD未能考虑到的方面。
附一段白名单过滤用户输入的代码,点击GitHub查看。
本文首发于个人博客,欢迎来撩啊^-^。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY