data:image/s3,"s3://crabby-images/6ab4c/6ab4c31506f7c90118f45b0b9fa298fb834ea24c" alt="ThinkCMF 解决xss攻击问题 ThinkCMF 解决xss攻击问题"
最近使用ThinkCMF给某*开发的一个平台,因为他们需要通过国家二级信息安全等级测试
所以自己先使用Appscan测试了一下,结果扫描出一个xss安全问题
可以看到这是一个通过编码的字符串,解码后的字符串为:
http://www.xxxx.com/portal/list/index/id/1/p/index.php?>'"><script>alert(81998)<%2Fscript>=123"
data:image/s3,"s3://crabby-images/6cc11/6cc11047f2f3f5d39b42d810d7081710c21468ec" alt="ThinkCMF 解决xss攻击问题 ThinkCMF 解决xss攻击问题"
正确的效果
data:image/s3,"s3://crabby-images/ff6d6/ff6d6c9631c28bacb3e9b0f4239e01dce19c4a42" alt="ThinkCMF 解决xss攻击问题 ThinkCMF 解决xss攻击问题"
注入后的效果
data:image/s3,"s3://crabby-images/9f895/9f8955b5586887d7d604560a42f22919d0a26ce9" alt="ThinkCMF 解决xss攻击问题 ThinkCMF 解决xss攻击问题"
而ThinkPhp里\simplewind\Lib\Util\Page.class.php文件在分页时并没有对字符串进行处理,从而导致将URL中的script代码成功注入到页面中
data:image/s3,"s3://crabby-images/f9be5/f9be5b5b510fd59ea006baf1b36602f492fe027a" alt="ThinkCMF 解决xss攻击问题 ThinkCMF 解决xss攻击问题"
解决办法:
修改\application\Common\Controller\AppframeController.class.php 文件在_initialize方法里添加自定义xss检测方法
当URL中含有非法字符时就停止继续访问并提示
data:image/s3,"s3://crabby-images/82e73/82e73417926296a0b14dad158fb201715407fb2c" alt="ThinkCMF 解决xss攻击问题 ThinkCMF 解决xss攻击问题"
/**
* [xss 检测]
* @Author HTL
* @DateTime 2016-10-25T15:36:30+0800
* @return [type] [description]
*/
private function _xss_check() {
$temp = strtoupper(urldecode(urldecode($_SERVER['REQUEST_URI'])));
if(strpos($temp, '<') !== false || strpos($temp, '"') !== false || strpos($temp, 'CONTENT-TRANSFER-ENCODING') !== false) {
die('您当前的访问请求当中含有非法字符,已经被系统拒绝');
}
return true;
}
再次访问后的效果
data:image/s3,"s3://crabby-images/d1c81/d1c81df5e04b61891677de3689cff85ec69611d2" alt="ThinkCMF 解决xss攻击问题 ThinkCMF 解决xss攻击问题"
参考: