首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Yii中的Purify html字符串

Yii中的Purify html字符串
EN

Stack Overflow用户
提问于 2015-07-20 13:06:14
回答 1查看 481关注 0票数 0

我正在尝试purify一个字符串以防止XSS,但是如果一个字符串没有脚本标记,而是具有html属性,那么这个字符串就不是purify。

示例:

代码语言:javascript
复制
$str = 'http://www.example.com/54f74"onmouseover%3d"alert(1)"style%3d"position%3aabsolute%3bwidth%3a100%25%3bheight%3a100%25%3btop%3a0%3bleft%3a0%3b"54f74';
$purifier = new CHtmlPurifier();
var_dump(
    $str,
    $purifier->purify($str)
);

结果:

代码语言:javascript
复制
string 'http://www.example.com/54f74"onmouseover%3d"alert(1)"style%3d"position%3aabsolute%3bwidth%3a100%25%3bheight%3a100%25%3btop%3a0%3bleft%3a0%3b"54f74' (length=145)
string 'http://www.example.com/54f74"onmouseover%3d"alert(1)"style%3d"position%3aabsolute%3bwidth%3a100%25%3bheight%3a100%25%3btop%3a0%3bleft%3a0%3b"54f74' (length=145)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-07-20 16:44:23

是的,因为该字符串是有效的XSS无关HTML。如果您计划在属性中使用它,则可以使用HTML的内部AttrDef类手动净化它。对于URL,您可能需要HTMLPurifier_AttrDef_URI

代码语言:javascript
复制
$def = new HTMLPurifier_AttrDef_URI();
$config = HTMLPurifier_Config::default();
$context = new HTMLPurifier_Context();
$pure_url = $def->validate($your_url, $config, $context);
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31517359

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档