跳到主要內容

在ASP.Net防止 SQL Injection和參數篡改

看到保哥貼了 Hacking is child's play ,就算有參數化SQL指令,但使用者輸入資料(例如討論區等)還是很難防,所以小小做個筆記。

今年的MSDN Magazine有一篇保護 ASP.NET 應用程式的安全,裡頭就提到AntiXSS,其實AntiXSS是Microsoft Web Protection Library的一部份。

原本AntiXSS包含了Sanitizer 物件,在4.x後分成兩個DLL,但是目前微軟網站的Microsoft Anti-Cross Site Scripting Library V4.2並未包含Sanitizer 進去,因此必須自己下載Source Code編譯。

我編好後,把HtmlSanitizationLibrary.dll 加到專案,就有Sanitizer可用;另一方面編譯出來的AntiXSSLibrary.dll 是4.1.0版,下載的AntiXSSLibrary.dll 是4.2.0版,所以我沿用官方版。

這樣一來,只要在 .cs 加上 using Microsoft.Security.Application; 就可以用 string cleanData = Sanitizer.GetSafeHtmlFragment(wysiwygData); 把一些script或編碼資料去除。

同時也可以在 web.conf裡的 <system.web>區塊加上
 <httpRuntime encoderType=   "Microsoft.Security.Application.AntiXssEncoder, AntiXssLibrary"/>
,改用較安全版本。
因為這個屬性只能出現一次,所以像我有加大Request的,就必須寫成一行
 <httpRuntime maxRequestLength="2097151" encoderType=   "Microsoft.Security.Application.AntiXssEncoder, AntiXssLibrary"/>

留言

這個網誌中的熱門文章

Personal Bookmark

Java SE 6 + Firefox 2 UI 問題 As I do . Google拋棄了了SOAP API,浮想聯翩 https://www.gandi.net/ VS 2005 SP1中文版推出 Windows Vista中文版下載 ASP.NET 2.0網頁執行管線與快取原理 Cache 2.0快取架構與快取資料自動移除架構圖 flickr sync 分享與試用 SUN Looking Glass 3D圖形介面發布1.0 雅虎勵精圖治推動改革 Wait and see 國內某SOC疑遭駭客入侵 大砲開講 Very Important! 微軟公佈Vista安全程式介面草案 一窺Google開原碼庫房乾坤 qing is writing a dig girl net... wait and see

DBeaver 介面語言

DBeaver是我個人頗常用的一套跨平台Database管理工具,最近升級後發現Windows版本居然變成簡體中文,而且無法切換為英文。

自然人憑證讀卡機驅動程式

鳥毅用的是第一代的自然人憑證讀卡機,EZ100PU(後來有同事買EZmini可以讀SIM卡似乎更好),每年報稅時用一次。 本來只是要申請些政府業務,一時之間找不到光碟,沒想到在 驅動程式下載 居然看到Linux和Mac的驅動程式,剩下的就是政府單位的網頁和程式應該改版了吧!!!