V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
huahsiung
V2EX  ›  程序员

如果把评论提交的‘<’,‘"’,‘>’,‘&’都转码为&lt;&gt;%22&;&amp;之类的,是不是就可以防止 xxs。

  •  
  •   huahsiung · 2023-09-29 16:17:39 +08:00 · 2396 次点击
    这是一个创建于 419 天前的主题,其中的信息可能已经有所发展或是发生改变。
    博客的评论,如果过滤关键词 script,onerror 等等可能会误判。
    ‘<’,‘"’,‘>’,‘&’转码为
    &lt;&gt;%22;&amp;

    感觉转码这四个,应该就稳了。
    8 条回复    2023-09-29 22:16:15 +08:00
    vigossliao
        1
    vigossliao  
       2023-09-29 16:32:15 +08:00
    用现成库应该省事多了

    https://github.com/leizongmin/js-xss
    jsq2627
        2
    jsq2627  
       2023-09-29 16:38:43 +08:00   ❤️ 1
    agagega
        3
    agagega  
       2023-09-29 17:14:39 +08:00
    如果只需要展示纯文本的话,用 innerText 不就行了?
    hgc81538
        4
    hgc81538  
       2023-09-29 19:32:23 +08:00 via iPhone
    應該轉碼&<>"'去&amp;&lt;&gt;&quot;&#039;就穩了
    ysc3839
        5
    ysc3839  
       2023-09-29 19:34:56 +08:00 via Android
    可能不止这几个字符,建议直接使用现成的 html 转义库
    rabbbit
        6
    rabbbit  
       2023-09-29 19:41:09 +08:00
    xiangyuecn
        7
    xiangyuecn  
       2023-09-29 22:13:51 +08:00
    onclick='alert(1)'
    xiangyuecn
        8
    xiangyuecn  
       2023-09-29 22:16:15 +08:00
    不用白名单,直接全部 ASCII 字符除了换行字母数字全部用 &#123; 转义完事
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1084 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 39ms · UTC 18:52 · PVG 02:52 · LAX 10:52 · JFK 13:52
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.