最近在修改维护以前的webform项目(维护别人开发的.....)整个aspx没有用到任何的控件,这个我也比较喜欢不用控件
所以在提交信息的时候需要自己手动的去Request.QueryString[]或者Request.Form[]去获取,转型,判定等等
觉得这样子的代码写多了不甚其烦,就在想能不能自动获取,解析这些参数成我需要的数据实体呢,当然是可以的
这里我用反射根据参数的Key与实体的PropertyName进行对比,类型转换赋值给实体

public static T NameValues2Entity<T>(NameValueCollection NVS)
{
if (!NVS.HasKeys()) return default(T);
T entity = Activator.CreateInstance<T>();
PropertyInfo[] attrs = entity.GetType().GetProperties();
foreach (PropertyInfo p in attrs)
{
foreach (string key in NVS.AllKeys)
{
if (string.Compare(p.Name, key, true) == 0)
{
p.SetValue(entity, Convert.ChangeType(NVS[key], p.PropertyType), null);
}
}
}
return entity;
}

获取的时候直接调用NameValues2Entity<Model.Article>(Request.Form)即可获取Model.Article的数据实体,当然反射里面我没有做数据类型转化失败的判定,也只是简单的数据类型验证,如果需要复杂的数据类型验证,这里自己递归一下。
同时这里可以自行扩展,做个数据验证,神马必填,范围,正则等等,通过AOP来实现(通过对实体字段定义自定义属性达到数据验证)!

传递数据的搞定了,现在我们来做做读取数据的
如果你还是用的ADO.NET读取数据的时候全部是DataSet,DataTable
你需要得到其实体(ViewModel)或者需要对其实体进行序列化,(默认情况下DataTable无法进行Json序列化)
可以自己根据DataTable的数据类型定义一个实体,但是自己手动转换还得判定DbNull的情况
这里我们也通过反射实现一个

public static List<T> DataTable2Entities<T>(DataTable table)
{
if (null == table || table.Rows.Count <= 0) return default(List<T>);
List<T> list = new List<T>();
List<string> keys = new List<string>();
foreach (DataColumn c in table.Columns)
{
keys.Add(c.ColumnName.ToLower());
}
for (int i = 0; i < table.Rows.Count; i++)
{
T entity = Activator.CreateInstance<T>();
PropertyInfo[] attrs = entity.GetType().GetProperties();
foreach (PropertyInfo p in attrs)
{
if (keys.Contains(p.Name.ToLower()))
{
if (!DBNull.Value.Equals(table.Rows[i][p.Name]))
{
p.SetValue(entity, Convert.ChangeType(table.Rows[i][p.Name], p.PropertyType), null);
}
}
}
list.Add(entity);
}
return list;
}

这个里面已经自动对DBNull的情况做了判定
调用时候直接var model=DataTable2Entities<Model.Article>(dt);即可

WebForm获取GET或者POST参数到实体的转换,ADO.NET数据集自动转换实体的更多相关文章

  1. Objective-C中ORM的运用:实体对象和字典的相互自动转换

    http://blog.csdn.net/cooldragon/article/details/18991973 iOS开发中基于ORM的框架很多,如SQLitePersistentObject,实际 ...

  2. NodeJs获取不到POST参数

    NodeJs报错,从网页端获取不到POST参数,提示错误类似如下 TypeError: Cannot read property 'username' of undefined     at C:\U ...

  3. 如何获取url中的参数并传递给iframe中的报表

    在使用报表软件时,用户系统左边一般有目录树,点击报表节点就会在右侧网页的iframe中显示出报表,同时点击的时候也会传递一些参数给网页,比如时间和用户信息等.如何使网页中的报表能够获取到传递过来的参数 ...

  4. 使用JS,获取URL中指定参数的值

    /** * 获取URL中指定参数的值 * * @param name 参数名称 * @returns */ function getQueryString(name) { var reg = new ...

  5. APPCAN开发笔记:html页面之间的参数传递:使用js获取url中的参数,以及在APPCAN中不能使用的解决方法

    用PHP的GET/POST方式来传递方式已经是司空见惯了,但是如果我的页面是一个静态的html的页面,想传递参数的时候要怎么办呢?在APPCAN的开发中我们会经常遇到这样的问题,因为所有的页面都是静态 ...

  6. javaScript获取url中的参数

    var urlTools = { //获取RUL参数值 getUrlParam: function(name) { /*?videoId=identification */ var params = ...

  7. js通过location.search来获取页面传来的参数

    这篇文章主要介绍了通过window.location.search来获取页面传来的参数,经测试是OK的 ? 1 2 3 4 5 function GetQueryString(name) { var ...

  8. CI框架获取post和get参数 CodeIgniter

    请参考:CI文档的输入类部分: $this->input->post() $this->input->get() ------------------------------- ...

  9. vue中如何不通过路由直接获取url中的参数

    前言:为什么要不通过路由直接获取url中的参数? vue中使用路由的方式设置url参数,但是这种方式必须要在路径中附带参数,而且这个参数是需要在vue的路由中提前设置好的. 相对来说,在某些情况下直接 ...

随机推荐

  1. mysql每秒最多能插入多少条数据 ? 死磕性能压测

    前段时间搞优化,最后瓶颈发现都在数据库单点上. 问DBA,给我的写入答案是在1W(机械硬盘)左右. 联想起前几天infoQ上一篇文章说他们最好的硬件写入速度在2W后也无法提高(SSD硬盘) 但这东西感 ...

  2. .NET 串口通信

    这段时间做了一个和硬件设备通信的小项目,涉及到扫描头.输送线.称重机.贴标机等硬件.和各设备之间通信使用的是串口或网络(Socket)的方式.扫描头和贴标机使用的网络通信,输送线和称重机使用的是串口通 ...

  3. 工厂方法模式——创建型模式02

    1. 简单工厂模式     在介绍工厂方法模式之前,先介绍一下简单工厂模式.虽然简单工厂模式不属于GoF 23种设计模式,但通常将它作为学习其他工厂模式的入门,并且在实际开发中使用的也较为频繁. (1 ...

  4. 9、 Struts2验证(声明式验证、自定义验证器)

    1. 什么是Struts2 验证器 一个健壮的 web 应用程序必须确保用户输入是合法.有效的. Struts2 的输入验证 基于 XWork Validation Framework 的声明式验证: ...

  5. HDU1671——前缀树的一点感触

    题目http://acm.hdu.edu.cn/showproblem.php?pid=1671 题目本身不难,一棵前缀树OK,但是前两次提交都没有成功. 第一次Memory Limit Exceed ...

  6. OpenLiveWriter代码插件

    1.OpenLiveWriter安装 Windows Live Writer在2012年就停止了更新,Open Live Writer(以下简称OLW)是由Windows Live WriterWri ...

  7. springmvc+mybatis+spring 整合 bootstrap html5

    A 调用摄像头拍照,自定义裁剪编辑头像 [新录针对本系统的视频教程,手把手教开发一个模块,快速掌握本系统]B 集成代码生成器 [正反双向](单表.主表.明细表.树形表,开发利器)+快速构建表单;  技 ...

  8. http status code

    属于转载 http status code:200:成功,服务器已成功处理了请求,通常这表示服务器提供了请求的网页 404:未找到,服务器未找到 201-206都表示服务器成功处理了请求的状态代码,说 ...

  9. 深入理解javascript函数定义与函数作用域

    最近在学习javascript的函数,函数是javascript的一等对象,想要学好javascript,就必须深刻理解函数.本人把思路整理成文章,一是为了加深自己函数的理解,二是给读者提供学习的途径 ...

  10. Android—基于微信开放平台v3SDK,开发微信支付填坑。

    接触微信支付之前听说过这是一个坑,,,心里已经有了准备...我以为我没准跳坑出不来了,没有想到我填上了,调用成功之后我感觉公司所有的同事都是漂亮的,隔着北京的大雾霾我仿佛看见了太阳~~~好了,装逼结束 ...