为了账号安全,请及时绑定邮箱和手机立即绑定

当资料里含有JavaScript,在向页面输出时如何禁止其执行

当资料里含有JavaScript,在向页面输出时如何禁止其执行

慕虎7371278 2019-03-20 19:14:51
我们用jquery-datatable渲染一张table,拿到的资料,其中有一列的内容会碰到类似:8080::HTTP/1.1 200 OK | <script>window.location.href = "http://example:8080/a.asp";</script>在渲染的时候浏览器就会执行脚本,页面发生跳转。要如何做可以防止运行JavaScript,解决安全隐含?
查看完整描述

3 回答

?
汪汪一只猫

TA贡献1898条经验 获得超8个赞

function xssText(str) {

    var s = "";

    if (str.length == 0) return "";

    s = str.replace(/&/g, "&amp;");

    s = s.replace(/</g, "&lt;");

    s = s.replace(/>/g, "&gt;");

    s = s.replace(/ /g, "&nbsp;");

    s = s.replace(/\'/g, "&#39;");

    s = s.replace(/\"/g, "&quot;");

    s = s.replace(/\n/g, "<br>");

    return s;

}

xssText('<script>window.location.href = "http://example:8080/a.asp";</script>')


查看完整回答
反对 回复 2019-04-03
?
慕田峪4524236

TA贡献1875条经验 获得超5个赞

常见的安全问题,专业术语XSS,可以搜一下相关文章。


这里简单解决就是做html转义,把&<>等特殊字符转掉。


& -> &amp;

< -> &lt;

> -> &gt;


查看完整回答
反对 回复 2019-04-03
?
慕码人8056858

TA贡献1803条经验 获得超6个赞

在向页面输出时如何禁止其执行

尽量在输入的时候做字符串转义或者直接验证不通过,一份资料添加只有一次,而访问就不知道多少次了。


查看完整回答
反对 回复 2019-04-03
  • 3 回答
  • 0 关注
  • 654 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信