asp.net MVC利用自定义ModelBinder过滤关键字的方法(附demo源码下载)
2016-03-31 00:00
926 查看
本文实例讲述了MVC利用自定义ModelBinder过滤关键字的方法。分享给大家供大家参考,具体如下:
前面一篇主要讲解了如何利用ActionFilter过滤关键字,这篇主要讲解如何利用自己打造的ModelBinder来过滤关键字。
首先,我们还是利用上一篇《asp.net MVC利用ActionFilterAttribute过滤关键字的方法》中的实体类,但是我们需要加上DataType特性,以便于我们构造的ModelBinder通过DataTypeName识别出来:
然后我们新建一个FilterModelBinder的类,其中内容如下:
第13行,主要是获取我们需要验证的DataTypeName.
第15行,获取需要验证的值,然后替换,最后返回即可.
上面做完后,在Global.asax中,我们需要指定一下:
这样,我们就能使用我们自己的ModelBinder了,下面开始测试:
我们输入的内容如上图所示,当点击”添加”按钮的时候,确弹出如下的错误提示:
看来,系统会自动检测我们的输入值,发现有非法字符,会弹出错误提示,还好我们可以通过web.config配置一下,让其通过验证:
打开最外层的Web.config,输入以下节点:
然后保存,运行,我们看到,系统成功跑了起来,最后的结果如下:
我们可以看到,通过我们自定义的ModelBinder,系统自动将非法字符进行了替换,非常方便。
MVC中处处AOP,现在我们就可以利用现有的知识做一个全局过滤器了。是不是感觉很方便呢?
完整实例代码点击此处本站下载。
希望本文所述对大家asp.net程序设计有所帮助。
使用Nopcommerce为商城添加满XX减XX优惠券功能
NopCommerce架构分析(一)Autofac依赖注入类生成容器
NopCommerce架构分析之(三)EntityFramework数据库初试化及数据操作
NopCommerce架构分析之(四)基于路由实现灵活的插件机制
NopCommerce架构分析之(五)Model绑定Action参数
前面一篇主要讲解了如何利用ActionFilter过滤关键字,这篇主要讲解如何利用自己打造的ModelBinder来过滤关键字。
首先,我们还是利用上一篇《asp.net MVC利用ActionFilterAttribute过滤关键字的方法》中的实体类,但是我们需要加上DataType特性,以便于我们构造的ModelBinder通过DataTypeName识别出来:
using System.ComponentModel.DataAnnotations; using System.Web.Mvc; namespace MvcApplication1.Models { public class TestModel { public int TID { get; set; } [DataType("TName")] public string TName { get; set; } [DataType("TSite")] public string TSite { get; set; } } }
然后我们新建一个FilterModelBinder的类,其中内容如下:
using System; using System.Collections.Generic; using System.Linq; using System.Web; using System.Web.Mvc; namespace MvcApplication1 { public class FilterModelBinder:DefaultModelBinder { public override object BindModel(ControllerContext controllerContext, ModelBindingContext bindingContext) { var valueShouldFilter = bindingContext.ModelMetadata.DataTypeName; if (valueShouldFilter == "TName" || valueShouldFilter == "TSite") { var resultProvider = bindingContext.ValueProvider.GetValue(bindingContext.ModelName); if (resultProvider != null) { string result = resultProvider.AttemptedValue; result = result.Replace("<", "<").Replace(">", ">"); return result; } } return base.BindModel(controllerContext, bindingContext); } } }
第13行,主要是获取我们需要验证的DataTypeName.
第15行,获取需要验证的值,然后替换,最后返回即可.
上面做完后,在Global.asax中,我们需要指定一下:
protected void Application_Start() { AreaRegistration.RegisterAllAreas(); WebApiConfig.Register(GlobalConfiguration.Configuration); FilterConfig.RegisterGlobalFilters(GlobalFilters.Filters); RouteConfig.RegisterRoutes(RouteTable.Routes); BundleConfig.RegisterBundles(BundleTable.Bundles); ModelBinders.Binders.DefaultBinder = new FilterModelBinder(); }
这样,我们就能使用我们自己的ModelBinder了,下面开始测试:
我们输入的内容如上图所示,当点击”添加”按钮的时候,确弹出如下的错误提示:
看来,系统会自动检测我们的输入值,发现有非法字符,会弹出错误提示,还好我们可以通过web.config配置一下,让其通过验证:
打开最外层的Web.config,输入以下节点:
<configuration> <system.web> <httpRuntime requestValidationMode="2.0" /> </system.web> <pages validateRequest="false"> </pages> </configuration>
然后保存,运行,我们看到,系统成功跑了起来,最后的结果如下:
我们可以看到,通过我们自定义的ModelBinder,系统自动将非法字符进行了替换,非常方便。
MVC中处处AOP,现在我们就可以利用现有的知识做一个全局过滤器了。是不是感觉很方便呢?
完整实例代码点击此处本站下载。
希望本文所述对大家asp.net程序设计有所帮助。
您可能感兴趣的文章:
使用jQuery向asp.net Mvc传递复杂json数据-ModelBinder篇使用Nopcommerce为商城添加满XX减XX优惠券功能
NopCommerce架构分析(一)Autofac依赖注入类生成容器
NopCommerce架构分析之(三)EntityFramework数据库初试化及数据操作
NopCommerce架构分析之(四)基于路由实现灵活的插件机制
NopCommerce架构分析之(五)Model绑定Action参数
相关文章推荐
- 分享微信开发Html5轻游戏中的几个坑
- 过滤淘宝网弹出窗口
- 星外ASP.Net的安全设置相关说明
- C#、ASP.NET通用扩展工具类之TypeParse
- C#实现简单过滤非法字符实例
- dedecms采集过滤常用代码集合
- C#敏感词过滤实现方法
- 实现ASP.NET无刷新下载并提示下载完成的开发思路
- C#、ASP.NET通用扩展工具类之LogicSugar
- 使用位运算实现网页中的过滤、筛选功能实例
- Windows Powershell过滤管道结果
- C#、ASP.NET通用工具类IsWhat?(可以判断数字、身份证、数据类型等等)
- 程序中常用的种代码
- ASP.NET、ASP、PHP、JSP之间有什么区别?
- ASP.NET页面间的传值的几种方法
- C#实现过滤sql特殊字符的方法集合
- 入侵ASP.net网站的经验附利用代码
- Zend的MVC机制使用分析(二)
- 盘点PHP和ASP.NET的10大对比!
- 华为防火墙过滤策略