<acronym id="s8ci2"><small id="s8ci2"></small></acronym>
<rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
<acronym id="s8ci2"></acronym>
<acronym id="s8ci2"><center id="s8ci2"></center></acronym>

電子發燒友App

硬聲App

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示
電子發燒友網>電子資料下載>電子資料>White HTML Filter基于PHP的白名單過濾器

White HTML Filter基于PHP的白名單過濾器

2022-05-09 | zip | 0.01 MB | 次下載 | 免費

資料介紹

授權協議 Apache
開發語言 PHP
操作系統 跨平臺
軟件類型 開源軟件
所屬分類 Web應用開發、 常用JavaScript包

軟件簡介

White HTML Filter

簡介

XSS是什么就不介紹了,很多時候因為老板的需求之類的,必須用到UEditor之類的HTML富文本編輯器,這時候XSS防御就很重要了。

很多人會選擇用strip_tags()之類的來去除HTML標記,但是去除了標簽,還有onclick之類的危險屬性。而且過濾了屬性,對于必須通過iframe插入HTML5視頻的情況,還要過濾屬性的值。

一個常見做法是用正則表達式來切分HTML字符串,然后得到多個多維數組,利用黑名單過濾完后再拼接回HTML,這種方法因為解析HTML的方式跟瀏覽器不同,所以很容易被繞過。

這款工具應運而生,使用基于與瀏覽器解析HTML方式一致的標記化算法(The Tokenization Algorithm)的DOMDocument來解析HTML,然后利用白名單來過濾HTML標簽、屬性、乃至屬性值。

使用方法

1、引入

composer?require?lincanbin/white-html-filter

2、使用

use?lincanbin\WhiteHTMLFilter;
?
//跨站腳本白名單過濾
function?XssEscape($html)
{
???$filter?=?new?WhiteHTMLFilter();
???$urlFilter?=?function($url)?{
??????$token?=?parse_url($url);
??????if?(empty($token['scheme'])?||?in_array($token['scheme'],?array('http',?'https'))?===?false)?{
?????????return?'';
??????}
??????$hostWhiteList?=?array(
?????????'www.youtube.com',?'youtube.com',?'www.youtu.be',?'youtu.be',
?????????'player.youku.com',?'v.youku.com',
?????????'video.tudou.com',?'www.tudou.com',
?????????'player.video.qiyi.com',?'open.iqiyi.com',
?????????'imgcache.qq.com',?'v.qq.com',
?????????'static.hdslb.com',
?????????//'www.le.com',
?????????'share.vrs.sohu.com',?'tv.sohu.com',
?????????'player.pptv.com',
?????????'cdn.aixifan.com',
?????????'v.ifeng.com',
?????????'video.sina.com.cn',
?????????'galaxy.bjcathay.com'//CNTV
??????);
??????if?(empty($token['host'])?||?in_array($token['host'],?$hostWhiteList)?===?false)?{
?????????return?'';
??????}
??????return?$url;
???};
?
???$iframeRule?=?array(
??????'iframe'?=>?array(
?????????'src'?=>?$urlFilter,
?????????'width',
?????????'height',
?????????'frameborder',
?????????'allowfullscreen'
??????)
???);
???$filter->config->modifyTagWhiteList($iframeRule);
???$filter->loadHTML($html);
???$filter->clean();
???return?$filter->outputHtml();
}

以上這段代碼表示在默認白名單列表后追加配置,允許iframe標簽的使用,只允許iframe的src、width、height、frameborder、allowfullscreen屬性。

并對src的屬性值進行過濾,使得當iframe的src屬性值的URL的域屬于以上域名列表中的其中之一時,才允許該值出現,否則令src屬性值為空。

更多示例

你可以在這里使用GitHub帳號登錄 https://www.94cb.com/t/5280 ,并這個帖子下面回帖對這個庫進行測試。

?
下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1山景DSP芯片AP8248A2數據手冊
  2. 1.06 MB  |  532次下載  |  免費
  3. 2RK3399完整板原理圖(支持平板,盒子VR)
  4. 3.28 MB  |  339次下載  |  免費
  5. 3TC358743XBG評估板參考手冊
  6. 1.36 MB  |  330次下載  |  免費
  7. 4DFM軟件使用教程
  8. 0.84 MB  |  295次下載  |  免費
  9. 5元宇宙深度解析—未來的未來-風口還是泡沫
  10. 6.40 MB  |  227次下載  |  免費
  11. 6迪文DGUS開發指南
  12. 31.67 MB  |  194次下載  |  免費
  13. 7元宇宙底層硬件系列報告
  14. 13.42 MB  |  182次下載  |  免費
  15. 8FP5207XR-G1中文應用手冊
  16. 1.09 MB  |  178次下載  |  免費

本月

  1. 1OrCAD10.5下載OrCAD10.5中文版軟件
  2. 0.00 MB  |  234315次下載  |  免費
  3. 2555集成電路應用800例(新編版)
  4. 0.00 MB  |  33566次下載  |  免費
  5. 3接口電路圖大全
  6. 未知  |  30323次下載  |  免費
  7. 4開關電源設計實例指南
  8. 未知  |  21549次下載  |  免費
  9. 5電氣工程師手冊免費下載(新編第二版pdf電子書)
  10. 0.00 MB  |  15349次下載  |  免費
  11. 6數字電路基礎pdf(下載)
  12. 未知  |  13750次下載  |  免費
  13. 7電子制作實例集錦 下載
  14. 未知  |  8113次下載  |  免費
  15. 8《LED驅動電路設計》 溫德爾著
  16. 0.00 MB  |  6656次下載  |  免費

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935054次下載  |  免費
  3. 2protel99se軟件下載(可英文版轉中文版)
  4. 78.1 MB  |  537798次下載  |  免費
  5. 3MATLAB 7.1 下載 (含軟件介紹)
  6. 未知  |  420027次下載  |  免費
  7. 4OrCAD10.5下載OrCAD10.5中文版軟件
  8. 0.00 MB  |  234315次下載  |  免費
  9. 5Altium DXP2002下載入口
  10. 未知  |  233046次下載  |  免費
  11. 6電路仿真軟件multisim 10.0免費下載
  12. 340992  |  191187次下載  |  免費
  13. 7十天學會AVR單片機與C語言視頻教程 下載
  14. 158M  |  183279次下載  |  免費
  15. 8proe5.0野火版下載(中文版免費下載)
  16. 未知  |  138040次下載  |  免費
亚洲欧美日韩精品久久_久久精品AⅤ无码中文_日本中文字幕有码在线播放_亚洲视频高清不卡在线观看
<acronym id="s8ci2"><small id="s8ci2"></small></acronym>
<rt id="s8ci2"></rt><rt id="s8ci2"><optgroup id="s8ci2"></optgroup></rt>
<acronym id="s8ci2"></acronym>
<acronym id="s8ci2"><center id="s8ci2"></center></acronym>