Aspx/Asp.net 防注入程序 V1.0 |
本文标签:Asp.net,防注入 虽然说ASP.NET属于安全性高的脚本语言,但是也经常看到ASP.NET网站由于过滤不严造成注射.由于ASP.NET基本上配合MMSQL数据库架设 如果权限过大的话很容易被攻击. 再者在网络上找不到好的ASP.NET防注射脚本,所以就自己写了个. 在这里共享出来旨在让程序员免除SQL注入的困扰. 我写了两个版本,VB.NET和C#版本方便不同程序间使用. 描述: 1. XP + IIS5.1 + Access + MSSQL2000 下测试通过 。 2. 由于考虑到ASPX大多数和MSSQL数据库配合使用,在此增加了MSSQL关键字 。 3. 放到数据库连接代码处即可,和ASP用法类似 。 复制代码 代码如下: public void JK1986_CheckSql() { string jk1986_sql = "exec夢select夢drop夢alter夢exists夢union夢and夢or夢xor夢order夢mid夢asc夢execute夢xp_cmdshell夢insert夢update夢delete夢join夢declare夢char夢sp_oacreate夢wscript.shell夢xp_regwrite夢夢;夢--夢%"; string[] jk_sql = jk1986_sql.Split(夢); foreach (string jk in jk_sql) { // -----------------------防 Post 注入----------------------- if (Page.Request.Form != null) { for (int k = 0; k < Page.Request.Form.Count; k++) { string getsqlkey = Page.Request.Form.Keys[k]; string getip; if (Page.Request.Form[getsqlkey].ToLower().Contains(jk) == true) { Response.Write("<script Language=JavaScript>alert(ASP.NET( C#版本 )站长网提示您,请勿提交非法字符!↓\\n\\nBloghttp://www.safe5.com [url=file://\\n\\nBy]\\n\\nBy[/url]:Jack);</" + "script>"); Response.Write("非法操作!系统做了如下记录 ↓" + "<br>"); if (Request.ServerVariables["HTTP_X_FORWARDED_FOR"] != null ) { getip = this.Page.Request.ServerVariables["HTTP_X_FORWARDED_FOR"]; } else { getip = Page.Request.ServerVariables["REMOTE_ADDR"]; } Response.Write("操 作 I P :" + getip + "<br>"); Response.Write("操 作 时 间:" + DateTime.Now.ToString() + "<br>"); Response.Write("操 作 页 面:" + Page.Request.ServerVariables["URL"] + "<br>"); Response.Write("提 交 方 式:P O S T " + "<br>"); Response.Write("提 交 参 数:" + jk + "<br>"); Response.Write("提 交 数 据:" + Page.Request.Form[getsqlkey].ToLower() + "<br>"); Response.End(); } } } // -----------------------防 GET 注入----------------------- if (Page.Request.QueryString != null) { for (int k = 0; k < Page.Request.QueryString.Count; k++) { string getsqlkey = Page.Request.QueryString.Keys[k]; string getip; if (Page.Request.QueryString[getsqlkey].ToLower().Contains(jk) == true) { Response.Write("<script Language=JavaScript>alert(ASP.NET( C#版本 )站长安全网提示您,请勿提交非法字符!↓\\n\\nBloghttp://www.safe5.com [url=file://\\n\\nBy]\\n\\nBy[/url]:Jack);</" + "script>"); Response.Write("非法操作!系统做了如下记录 ↓" + "<br>"); if (Request.ServerVariables["HTTP_X_FORWARDED_FOR"] != null ) { getip = this.Page.Request.ServerVariables["HTTP_X_FORWARDED_FOR"]; } else { getip = Page.Request.ServerVariables["REMOTE_ADDR"]; } Response.Write("操 作 I P :" + getip + "<br>"); Response.Write("操 作 时 间:" + DateTime.Now.ToString() + "<br>"); Response.Write("操 作 页 面:" + Page.Request.ServerVariables["URL"] + "<br>"); Response.Write("提 交 方 式:G E T " + "<br>"); Response.Write("提 交 参 数:" + jk + "<br>"); Response.Write("提 交 数 据:" + Page.Request.QueryString[getsqlkey].ToLower() + "<br>"); Response.End(); } } } // -----------------------防 Cookies 注入----------------------- if (Page.Request.Cookies != null) { for (int k = 0; k < Page.Request.Cookies.Count; k++) { string getsqlkey = Page.Request.Cookies.Keys[k]; string getip; if (Page.Request.Cookies[getsqlkey].Value.ToLower().Contains(jk) == true) { Response.Write("<script Language=JavaScript>alert(ASP.NET( C#版本 )站长安全网提示您,请勿提交非法字符!↓\\n\\nBloghttp://www.safe5.com [url=file://\\n\\nBy]\\n\\nBy[/url]:Jack);</" + "script>"); Response.Write("非法操作!系统做了如下记录 ↓" + "<br>"); if (Request.ServerVariables["HTTP_X_FORWARDED_FOR"] != null ) { getip = this.Page.Request.ServerVariables["HTTP_X_FORWARDED_FOR"]; } else { getip = Page.Request.ServerVariables["REMOTE_ADDR"]; } Response.Write("操 作 I P :" + getip + "<br>"); Response.Write("操 作 时 间:" + DateTime.Now.ToString() + "<br>"); Response.Write("操 作 页 面:" + Page.Request.ServerVariables["URL"] + "<br>"); Response.Write("提 交 方 式: Cookies " + "<br>"); Response.Write("提 交 参 数:" + jk + "<br>"); Response.Write("提 交 数 据:" + Page.Request.Cookies[getsqlkey].Value.ToLower() + "<br>"); Response.End(); } } } } } |