准备技术:
    1.简单的WebService编写;
    2.了解Asp.net Ajax 客户端访问WebService


内容:
    asp.net ajax框架在去年看过,只是些基本的使用,并没有过多的去研究它的原理。最近在一个项目中要实现客户端访问WebService并返回DataTable类型的数据,当我调用一个返回DataTable的方法时,不能返回成功,在错误的回调函数中告诉我DataTable是一个循环应用类型,不能序列化。当是想过把DataTable替换成其他类型的数据如ArrayList或则Array等,可是有点心不甘,所以查过各个方面的资料,告诉我微软已经提供了一个解决DataTable的JavaScriptConverter的dll文件,当我在web.config中添加了对这个JavascriptConverter引用即可以将DataTable序列化成Json字符串了。
    好了,废话不多说了。下面就自己来做个循环应用的实例,并通过自定义JavascriptConverter来解决循环引用的问题。本文只会简单的介绍下服务器端序列化数据类型到Json的过程,不会太深入。

    首先先来定义两个类,想了半天最好的实例就是一对夫妻,一个老公只有一个老婆,这是婚姻法规定的,所以老公类型跟老婆类型就可以达到实例中的循环引用。看下两个类型的类试图:
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
其实两个类里面的内容都很简单,Husband.cs:

Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)using System;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Web;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Web.Services;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Web.Services.Protocols;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.ComponentModel;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
public class Husband
Wife.cs:
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)using System;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Web;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Web.Services;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Web.Services.Protocols;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.ComponentModel;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
public class Wife

然后我定义了个Webservice类用来提供Client的访问,HusbandService.cs:
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)using System;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Collections;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Linq;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Web;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Web.Services;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Web.Services.Protocols;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Xml.Linq;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Web.Script.Services;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)

我在一个asp.net 页面中通过asp.net ajax对GetHusband()的应用的,JavascriptConverter.aspx:
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)<%@ Page Language="C#" AutoEventWireup="true"  CodeFile="JavascriptConverter.aspx.cs" Inherits="_Default" %>
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
<html xmlns="http://www.w3.org/1999/xhtml">
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
<head runat="server">
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)    
<title>JavaScriptConverter Demo</title>
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
</head>
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
<body>
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)    
<form id="form1" runat="server">
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)    
<div>
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)        
<asp:ScriptManager ID="scriptManager" runat="server">
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)            
<Services>
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)                
<asp:ServiceReference Path="~/HusbandService.asmx" />
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)            
</Services>
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)        
</asp:ScriptManager>
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)        
<script language="javascript" type="text/javascript">
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)          function getServiceHasband()
运行后当我们点击按钮是,会弹出出错的信息,告诉我们Husband是一个循环引用类型,不能序列化。这时我们可以通过编写对应的JavascriptConverter来告诉服务器端如何去序列化。

我们自定的JavascriptConverter必须继承于JavascriptConverter(JavascriptConverter参考文档),然后去重写里面的两个方法跟一个属性:
1.Deserialize:如何反序列化一个Jason到这个Converter类型;
2.Serialize:如何序列化支持的对象到一个Jason;
3.SupportedTypes:这个Converter支持的类型。
好了下面我们定义下一个Converter来支持循环引用,现在我们先定义如何将去序列化,HusbandConverter.cs:
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)using System;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Data;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Configuration;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Linq;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Web;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Web.Security;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Web.UI;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Web.UI.HtmlControls;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Web.UI.WebControls;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Web.UI.WebControls.WebParts;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Xml.Linq;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Web.Script.Serialization;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)
using System.Collections.Generic;
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)

然后我们在web.config中注册这样一段对这个Converter的引用:

 

Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)<system.web.extensions>
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)        
<scripting>
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)            
<webServices>
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)                
<jsonSerialization>
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)                    
<converters>
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)                        
<add name="HusbandConvert" type="HusbandConverter,App_Code"/>
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)                    
</converters>
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)                
</jsonSerialization>
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)            
</webServices>
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)        
</scripting>
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)    
</system.web.extensions>

这下我们再运行时,去点击按钮就能返回“Henllyee”。
在上面中我们首先重写了SupportedTypes属性去告诉系统我这个Converter支持那些类型的数据。然后我们去重写了Serialize方法,其实我们在这里只是把husband.Wife.Husband设置为了null,让它不去循环引用了,所以这样就破坏原来的类的本意。但是我们可以在客户端再去完善它,再在客户端设置husband.Wife.Husband=husband即可了。
下面我们再看如何进行反序列化了。首先我们在webservice中先添加一个方法,来传入Husband对象

Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter) [WebMethod]
Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)    
public string GetHusbandInfo(Husband hansband)
    }

然后我们再去把反序列化实现下:

Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)public override object Deserialize(IDictionary<stringobject> dictionary, Type type, JavaScriptSerializer serializer)
    }

最后我们在客户端进行调用:

Asp.net Ajax WebService 实现循环引用(自定义JavascriptConverter)  function getHusbandInfo()
          }

具体的前台的脚本就不在给出,通过运行我们会发现反序列化是成功的。
程序下载地址:https://files.cnblogs.com/henllyee/JavascriptConverter.rar

相关文章:

  • 2021-07-12
  • 2022-02-18
  • 2022-12-23
  • 2021-09-16
  • 2022-12-23
  • 2022-01-19
  • 2021-12-05
  • 2021-12-15
猜你喜欢
  • 2021-12-04
  • 2021-05-02
  • 2021-12-14
  • 2022-01-01
  • 2021-09-27
  • 2022-02-21
  • 2021-09-03
相关资源
相似解决方案