ASP.NET 2.0 WebService中传递DataTable参考

asp.net|web|参考

  在2.0正式版发布之前,就满天的看到关于DataTable支持序列化的新特性宣传,满以为从此以后使用DataTable就和DataSet一样方便了,结果在应用项目的时候才发现并非那么回事。
  DataTable是支持序列化了,但是微软并没有把他做的特别方便,还需要我们自己来做一些工作之后才能够在WebService里面传递DataTable,否则在引用DataTable的时候会发现DataTable变成了一个什么Proxy类型。
  首先编写类DataTableSchemaImporterExtension,代码如下:
using System;
using System.Collections.Generic;
using System.Text;
using System.Xml.Serialization.Advanced;
using System.Collections;
using System.Xml.Schema;
using System.Xml.Serialization;
using System.CodeDom;
using System.CodeDom.Compiler;
using System.Xml;
using System.Data;

namespace Xrinehart.Tools.WebService.SchemaImporter
{
    class DataTableSchemaImporterExtension : SchemaImporterExtension
    {

        // DataTableSchemaImporterExtension is used for WebServices, it is used to recognize the schema for DataTable within wsdl

        Hashtable importedTypes = new Hashtable();

        public override string ImportSchemaType(string name, string schemaNamespace, XmlSchemaObject context, XmlSchemas schemas, XmlSchemaImporter importer, CodeCompileUnit compileUnit, CodeNamespace mainNamespace, CodeGenerationOptions options, CodeDomProvider codeProvider)
        {

            IList values = schemas.GetSchemas(schemaNamespace);

            if (values.Count != 1)
            {

                return null;

            }

            XmlSchema schema = values[0] as XmlSchema;

            if (schema == null)

                return null;

            XmlSchemaType type = (XmlSchemaType)schema.SchemaTypes[new XmlQualifiedName(name, schemaNamespace)];

            return ImportSchemaType(type, context, schemas, importer, compileUnit, mainNamespace, options, codeProvider);

        }

        public override string ImportSchemaType(XmlSchemaType type, XmlSchemaObject context, XmlSchemas schemas, XmlSchemaImporter importer, CodeCompileUnit compileUnit, CodeNamespace mainNamespace, CodeGenerationOptions options, CodeDomProvider codeProvider)
        {

            if (type == null)
            {

                return null;

            }

            if (importedTypes[type] != null)
            {

                mainNamespace.Imports.Add(new CodeNamespaceImport(typeof(DataSet).Namespace));

                compileUnit.ReferencedAssemblies.Add("System.Data.dll");

                return (string)importedTypes[type];

            }

            if (!(context is XmlSchemaElement))

                return null;

            if (type is XmlSchemaComplexType)
            {

                XmlSchemaComplexType ct = (XmlSchemaComplexType)type;

                if (ct.Particle is XmlSchemaSequence)
                {

                    XmlSchemaObjectCollection items = ((XmlSchemaSequence)ct.Particle).Items;

                    if (items.Count == 2 && items[0] is XmlSchemaAny && items[1] is XmlSchemaAny)
                    {

                        XmlSchemaAny any0 = (XmlSchemaAny)items[0];

                        XmlSchemaAny any1 = (XmlSchemaAny)items[1];

                        if (any0.Namespace == XmlSchema.Namespace && any1.Namespace == "urn:schemas-microsoft-com:xml-diffgram-v1")
                        {

                            string typeName = typeof(DataTable).FullName;

                            importedTypes.Add(type, typeName);

                            mainNamespace.Imports.Add(new CodeNamespaceImport(typeof(DataTable).Namespace));

                            compileUnit.ReferencedAssemblies.Add("System.Data.dll");

                            return typeName;

                        }

                    }

                }

            }

            return null;

        }

    }

}
  为此类添加进一个项目中,并将此项目进行强命名后编译。

  然后,把该Assembly程序集加入到GAC中。

  最后修改本机的machine.config,代码如下:
      <sectionGroup name="system.xml.serialization" type="System.Xml.Serialization.Configuration.SerializationSectionGroup, System.Xml, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089">
      <section name="schemaImporterExtensions" type="System.Xml.Serialization.Configuration.SchemaImporterExtensionsSection, System.Xml, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
      <section name="dateTimeSerialization" type="System.Xml.Serialization.Configuration.DateTimeSerializationSection, System.Xml, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" />
      <section name="xmlSerializer" type="System.Xml.Serialization.Configuration.XmlSerializerSection, System.Xml, Version=2.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
      </sectionGroup> 
  <system.xml.serialization>
     <schemaImporterExtensions>
            <add name="dataTableSchemaImporterExtension" type="Xrinehart.Tools.WebService.SchemaImporter.DataTableSchemaImporterExtension, Xrinehart.Tools.WebService.SchemaImporter,Version=1.0.0.0,Culture=neutral,PublicKeyToken=5a627ce15fb94702" />
    </schemaImporterExtensions>
 </system.xml.serialization>

  完成以上的步骤后,再编译WebService,重新引用(或者更新Web引用),就可以正确的识别DataTable类型了。
  其实DataTable只实现了序列化,但WebService并不能自己反序列化为可识别的格式,所以需要自己手动增加。由此可以衍生为各种业务实体BussinessEntity类对象也可以通过以上方式实现直接传递。

  希望对大家有所帮助。

时间: 2024-12-27 08:13:32

ASP.NET 2.0 WebService中传递DataTable参考的相关文章

ASP.NET 2.0 AJAX中Webservice调用方法示例

ajax|asp.net|web|示例 ASP.NET 2.0 AJAX中能够在客户端js中很方便地调用服务器Webservice,以下为一些调用的示例.笔者安装的ASP.NET 2.0 AJAX 版本为AJAX November CTP. 三个示例分别为:1 带参数的WS方法2 不带参数的WS方法3 参数类型为DataTable的WS方法 一.WebMethod注意要点:1 WebMethod类需要添加命名空间 Microsoft.Web.Script.Services,此空间需要引用Micr

在WebService中传递SortedList, ListDictionary 和 Hashtable 参数

问题描述 在WebService中传递SortedList,ListDictionary和Hashtable参数,如果直接传递,就会报错:System.NotSupportedException:ThetypeSystem.Collections.SortedListisnotsupportedbecauseitimplementsIDictionary.通过集合类的CopyTo方法将其转化成DictionaryEntry数组,再进行传递:客户端接收后,再将其转化成SortedList,List

ASP.NET 2.0 Beta2 中特殊文件夹名称的改变

asp.net 微软的Web平台开发组最近发布了一个新消息,据称在Visual Studio 2005 Beta2中,ASP.NET2.0中的一些特殊文件夹的名称将有所改变.这些改变主要是为了避免和应用程序命名的不协调,以及在进行XCopy部署时保护相关系统资料. ASP.NET 2.0 (Beta2)中最新的特殊文件夹的名称改变如下: /Bin 改变为 /Application_Assemblies * /Code 改变为 /Application_Code /Resources 改变为 /A

ASP.NET 2.0应用中定制安全凭证之理论篇

阅读提要 在缺省状况下,你只能使用Visual Studio 2005的一个本机实例来 管理与ASP.NET 2.0一同发行的SQL Server数据库中的安全凭证.本文将向你展 示怎样用一个Web服务来包装ASP.NET 2.0提供者并通过使用一个Windows表单应 用程序来管理凭证存储从而扩展这种管理能力. 如今,无论是互联网还是企业内部局域网程序一般都要求使用定制的方式来 存储和管理用户帐户和角色.为此,ASP.NET 2.0提供了一个现成的提供者模型 和一个SQL Sever数据库.不

ASP.NET 2.0应用中定制安全凭证之实践篇

一.方案架构 本方案架构很简单--它用一个Web服务来包装ASP.NET 2.0提供者并且为远 程客户暴露该凭证管理,你甚至还能在该架构中加上一些失去的功能.然后,在 提供一个丰富的用户接口和全面凭证管理经验的同时,使用一个Windows表单应 用程序来消费该Web服务.该Web服务配置文件将包含特定于该凭证存储的指令. 然而,这的确意味着所有由该Web服务管理的应用程序都将可以共享这些指令. 尽管你能够从头到尾地构建该Web服务,也就是说,首先用静态方法Roles和 Membership来包装

在ASP.NET 2.0开发中实现站点地图的本地化

本文中,我们首先简要地介绍了ASP.NET 2.0提供的新的站点导航机制,并注意到这个新的导航功能的核心是通过XML文件来详细描述网站的导航框架.显然,这种新导航机制的强大功能可以大大节省程序员的编码时间.接下来,我们通过一个简单的例子分析了本地化Web.sitemap的一般思路. 一.基于XML的站点地图 以前在Web应用程序中建立导航的方法是在页面上散布大量的超级链接.但当开发大型Web工程时,这种简单而原始的方法显得极为臃肿而且力不从心.为此,ASP.NET 2.0引入了一个新的导航系统来

asp.net 2.0 Webconfig中连接串的加密

ASP.NET 2.0 允许用户对配置文件的单个节进行加密本文.通过示例,演示如何以编程方式对配置节进行加密,配置API如何自动处理加密的节. ASP.NET 2.0 现在允许您对配置文件的单个节进行加密,这样,几乎不可能使用文本编辑器来读取这些配置节. ASP.NET 包括两个内置的受保护配置提供程序:RSA和DPAPI DPAPI提供程序使用特定于计算机的密钥,因此您必须在每台计算机上实际加密配置设置.默认使用的RSA提供程序允许您选择创建RSA密钥并将其安装在其他计算机上,这样您就可以在这

ASP.NET 4.0 AJAX 中无法使用自定义函数的疑问

问题描述 我的开发环境是vs2010sp1+asp.net4.0,我使用了scriptmanager控件,但是在aspx页面里我自己编写的javascript无法饮用.请问是什么原因?谢谢.PS:我之前一直是用ASP.NET2.0+AJAX,那时候是可以使用这些自定义的函数的,但是现在在ASP.NET4.0里就是提示我的函数没有定义. 解决方案 解决方案二:你是怎么使用你的函数的?解决方案三:在别的按钮的onClientClick里引用

asp.net 2.0主表中lookup字段的输入问题

问题描述 提供了dropdownlist这个控件,但这个功能实在太弱,无法输入,只能选择,有设计经验的朋友说说,是选择类似dropdownlist这类的webcombo这种控件呢,还是跳出模式窗口选择后返回赋值? 解决方案 解决方案二:up解决方案三:http://www.codeproject.com/aspnet/combobox.asphttp://www.codeproject.com/aspnet/CustomComboBox.asp解决方案四:如果combo需要多列应该怎么办