Global.asax.cs防注入问题

如果对参数没做处理,可以用下面的放在Global中防注入

 

  1. protected void Application_BeginRequest(Object sender, EventArgs e)  
  2. {  
  3.     //SQL防注入  
  4.     string Sql_1 = "exec ¦insert+ ¦select+ ¦delete ¦update ¦count ¦chr ¦mid ¦master+ ¦truncate ¦char ¦declare ¦drop+ ¦drop+table ¦creat+ ¦creat+table";  
  5.     string Sql_2 = "exec+ ¦insert+ ¦delete+ ¦update+ ¦count( ¦count+ ¦chr+ ¦+mid( ¦+mid+ ¦+master+ ¦truncate+ ¦char+ ¦+char( ¦declare+ ¦drop+ ¦creat+ ¦drop+table ¦creat+table";  
  6.     string[] sql_c = Sql_1.Split('¦');  
  7.     string[] sql_c1 = Sql_2.Split('¦');  
  8.   
  9.     if (Request.QueryString != null)  
  10.     {  
  11.         foreach (string sl in sql_c)  
  12.         {  
  13.             if (Request.QueryString.ToString().ToLower().IndexOf(sl.Trim()) >= 0)  
  14.             {  
  15.                 Response.Write("警告!你的IP已经被记录!");//  
  16.                 Response.Write(sl);  
  17.                 Response.Write(Request.QueryString.ToString());  
  18.                 Response.End();  
  19.                 break;  
  20.             }  
  21.         }  
  22.     }  
  23.   
  24.     if (Request.Form.Count > 0)  
  25.     {  
  26.         string s1 = Request.ServerVariables["SERVER_NAME"].Trim();//服务器名称  
  27.         if (Request.ServerVariables["HTTP_REFERER"] != null)  
  28.         {  
  29.             string s2 = Request.ServerVariables["HTTP_REFERER"].Trim();//http接收的名称  
  30.             string s3 = "";  
  31.             if (s1.Length > (s2.Length - 7))  
  32.             {  
  33.                 s3 = s2.Substring(7);  
  34.             }  
  35.             else  
  36.             {  
  37.                 s3 = s2.Substring(7, s1.Length);  
  38.             }  
  39.             if (s3 != s1)  
  40.             {  
  41.                 Response.Write("你的IP已被记录!警告!");//  
  42.                 Response.End();  
  43.             }  
  44.         }  
  45.     }  
  46. }   
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 MVC5 中使用 Autofac 进行配置文件注入,需要按照以下步骤进行操作: 1. 安装 Autofac 和 Autofac.Mvc5 NuGet 包。 2. 创建一个类来注册依赖项。例如,可以创建一个名为 AutofacConfig 的类。 3. 在 AutofacConfig 类中创建一个静态方法来注册依赖项。该方法应该接受一个 IContainerBuilder 对象作为参数。 4. 在 Register 方法中,使用 RegisterControllers 方法注册控制器。 5. 使用 RegisterAssemblyModules 方法注册程序集中的所有模块。 6. 使用 RegisterModelBinders 方法注册模型绑定器。 7. 使用 RegisterFilterProvider 方法注册筛选器提供程序。 8. 在 Global.asax.cs 文件中的 Application_Start 方法中,调用 AutofacConfig 类的 Register 方法,并将其传递给一个新的 ContainerBuilder 对象。 9. 在 Global.asax.cs 文件中的 Application_EndRequest 方法中,调用 AutofacDependencyResolver 类的 Dispose 方法以清理依赖项。 下面是一个示例 AutofacConfig 类,用于在 MVC5 中实现配置文件注入: ```csharp using Autofac; using Autofac.Integration.Mvc; using System.Web.Mvc; public class AutofacConfig { public static void Register(ContainerBuilder builder) { builder.RegisterControllers(typeof(MvcApplication).Assembly); builder.RegisterAssemblyModules(typeof(MvcApplication).Assembly); builder.RegisterModelBinders(typeof(MvcApplication).Assembly); builder.RegisterFilterProvider(); // 注册依赖项 builder.Register(c => new MyService(c.Resolve<MyDependency>())).As<IMyService>().InstancePerRequest(); builder.RegisterType<MyDependency>().As<IMyDependency>().SingleInstance(); } } ``` 在 Global.asax.cs 文件中,可以像这样调用 AutofacConfig 类的 Register 方法: ```csharp protected void Application_Start() { var builder = new ContainerBuilder(); AutofacConfig.Register(builder); var container = builder.Build(); DependencyResolver.SetResolver(new AutofacDependencyResolver(container)); // ... } ``` 然后,在 Global.asax.cs 文件中的 Application_EndRequest 方法中,可以像这样调用 AutofacDependencyResolver 类的 Dispose 方法: ```csharp protected void Application_EndRequest() { var resolver = DependencyResolver.Current as AutofacDependencyResolver; if (resolver != null) { resolver.Dispose(); } } ``` 以上就是在 MVC5 中使用 Autofac 进行配置文件注入的步骤。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值