原文WebService使用JSON格式传递笔记+JQuery测试

  • 因为一些因素,必须改写WebService,很传统,但是很多公司还在用.. 因为XML 的关系,不想让他传递数据的时候过度肥大,所以我必须要尽量干净的JSON.. 于是开始我的改写旅程..   首先,网络上好多好多好多文件,可能因为状况不同,测试过许多也让我搞混很多次.. 最后有找到答案..笔记一下..   首先我开了三个不同的WebMethod 来测试三种不同的输出..   GetUserInfoString –取得字符串 GetOneUserInfo - 取得一个对象 GetUsers - 取得对象们

    01.using System.Collections.Generic;
    02.using System.Web.Script.Services;
    03.using System.Web.Services;
    04. 
    05.namespace JsonServiceSample
    06.{
    07. 
    08.public class User
    09.{
    10.public string Name { getset; }
    11.public int Age { getset; }
    12.}
    13. 
    14. 
    15.[WebService(Namespace = "", Description = "For Donma Test")]
    16.[System.ComponentModel.ToolboxItem(false)]
    17.[ScriptService]
    18.public class Service1 : WebService
    19.{
    20. 
    21. 
    22.[WebMethod]
    23.[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
    24.public string GetUserInfoString(string name, int age)
    25.{
    26.return name + "," + age;
    27.}
    28. 
    29. 
    30.[WebMethod]
    31.[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
    32.public User GetOneUserInfo(string name, int age)
    33.{
    34.return (new User { Name = name, Age = age });
    35. 
    36.}
    37. 
    38. 
    39.[WebMethod]
    40.[ScriptMethod(ResponseFormat = ResponseFormat.Json)]
    41.public User[] GetUsers(string name, int age)
    42.{
    43.List<User> res = new List<User>();
    44.res.Add(new User { Name = name + "1", Age = age });
    45.res.Add(new User { Name = name + "2", Age = age });
    46. 
    47.return res.ToArray();
    48.}
    49. 
    50.}
    51.}

    再来一个重点,在每一个Method 上方我都会加上www.it165.net

    [WebMethod] [ScriptMethod(ResponseFormat = ResponseFormat.Json)]

    因为基于有时候我会需要使用GET 方式传递 所以我在Web Config 中加入 在system.web 中加入

    <webServices> <protocols> <add name="HttpGet"/> <add  name="HttpPost" /> <add name="Documentation" /> </protocols> </webServices>   Web.Config 全文:

    01.<?xml version="1.0"?>
    02. 
    03.<!--
    04.For more information on how to configure your <a href="http://www.it165.net/pro/webasp/" target="_blank" class="keylink">ASP</a>.NET application, please visit
    06.-->
    07. 
    08.<configuration>
    09.<configSections>
    10.<sectionGroup name="applicationSettings" type="System.Configuration.ApplicationSettingsGroup, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" >
    11.<section name="JsonServiceSample.Properties.Settings" type="System.Configuration.ClientSettingsSection, System, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089" requirePermission="false" />
    12.</sectionGroup>
    13.</configSections>
    14.<system.web>
    15.<compilation debug="true" targetFramework="4.0" />
    16.<httpHandlers>
    17.</httpHandlers>
    18. 
    19.<webServices>
    20.<protocols>
    21.<add name="HttpGet"/>
    22.<add  name="HttpPost" />
    23.<add name="Documentation" />
    24.</protocols>
    25.</webServices>
    26.</system.web>
    27. 
    28.<applicationSettings>
    29.<JsonServiceSample.Properties.Settings>
    30.<setting name="JsonServiceSample_JTestService_Service1" serializeAs="String">
    31.<value>http://localhost:5403/Service1.asmx</value>
    32.</setting>
    33.</JsonServiceSample.Properties.Settings>
    34.</applicationSettings>
    35.</configuration>

    这样试跑一下

    奇怪为什么不是JSON ,别紧张…我们继续使用 JQuery 来呼叫看看.. JQuery Code :

    01.<input type="button" id="ipt1" value="test" />
    02. 
    03.<script type="text/javascript">
    04. 
    05.function GetInfo() {
    06.var $res;
    07.$.ajax({
    08.type: "POST",
    09.url: "Service1.asmx/GetOneUserInfo",
    10.contentType: "application/json; charset=utf-8",
    11.async: false,
    12.cache: false,
    13.dataType: 'json',
    14.data: "{name:'当麻',age:29}",
    15.success: function (data) {
    16.if (data.hasOwnProperty("d")) {
    17.$res = data.d;
    18.}
    19.else
    20.$res = data;
    21.}
    22.});
    23.return $res;
    24.}
    25. 
    26. 
    27.$('#ipt1').click(function () {
    28.var res = GetInfo();
    29.alert(res.Name);
    30.});
    31. 
    32. 
    33.</script>

    按钮按下去之后 我让他呼叫 GetOneUserInfo 这 method 并且使用POST 看下结果..

    恩恩..的确是JSON, 但是多了一个 d  跟 __type 基本上  __type 不要去动他是不影响,但是  d 这东西必须得处理.. 进行改写..实测过上面三种不同的回传值..都 OK~~ 这样对于传统的 WebService Reference 呼叫  WebService 不会有影响.. 也可以透过JQuery 呼叫传递透过JSON…

WebService使用JSON格式传递笔记+JQuery测试的更多相关文章

  1. C#开发的WebService使用JSON格式传递数据+Ajax测试

    [C#]  WebService 使用 JSON 格式傳遞筆記 + JQuery 測試 0 2 因為一些因素,必須改寫WebService,很傳統,但是很多公司還在用.. 因為XML 的關係,不想讓他 ...

  2. SpringMVC中使用Ajax POST请求以json格式传递参数服务端通过request.getParameter("name")无法获取参数值问题分析

    SpringMVC中使用Ajax POST请求以json格式传递参数服务端通过request.getParameter("name")无法获取参数值问题分析 一:问题demo展示 ...

  3. WebService返回json格式数据供苹果或者安卓程序调用

    1.新建一个WebService. 2. /// <summary> /// DemoToJson 的摘要说明 /// </summary> [WebService(Names ...

  4. Java Servlet生成JSON格式数据并用jQuery显示

    1.Servlet通过json-lib生成JSON格式的数据 import java.io.IOException;import java.io.PrintWriter;import java.uti ...

  5. jquery json 格式教程

    介绍 我们知道AJAX技术能够使得每一次请求更加迅捷,对于每一次请求返回的不是整个页面,也仅仅是所需要返回的数据.通常AJAX通过返回XML格式的数据,然后再通过客户端复杂的JavaScript脚本解 ...

  6. Ajax datatype:'JSON'的error问题Status1:200,JSON格式

    转自:http://blog.sina.com.cn/s/blog_6e001be701017rux.html <script src="../js/jquery-1.8.0-vsdo ...

  7. ASP.net jQuery调用webservice返回json数据的一些问题

    之前寒假时,试着使用jQuery写了几个异步请求demo, 但是那样是使用的webform普通页面,一般应该是用 webservice 居多. 最近写后台管理时,想用异步来实现一些信息的展示和修改, ...

  8. jquery ajax调用返回json格式数据处理

    Ajax请求默认的都是异步的 如果想同步 async设置为false就可以(默认是true) var html = $.ajax({ url: "some.php", async: ...

  9. jQuery中使用Ajax获取JSON格式数据示例代码

    JSON(JavaScript Object Notation)是一种轻量级的数据交换格式.JSONM文件中包含了关于“名称”和“值”的信息.有时候我们需要读取JSON格式的数据文件,在jQuery中 ...

随机推荐

  1. Linux-2.6.32内核编译流量计数器nfacct

    最近一直想看到一本书<一个Jiegeng华>.而技术不依赖书.但是,这并不表示我IT技术没有兴趣.事实证明,,当我无法理解的沧桑.肮脏的领导者无法理解的心理.自我可惜无法理解它处处感受到脏 ...

  2. 播放视频的框架Vitamio的使用问题

    曾经用过这个牛逼的框架,后来又任意搞了下.发现播放不了视频了.搞了老半天才搞好,今天又随便整了下,发现又不行了.我勒个插! 如今最终又搞出来了,发现我总是把步骤搞错或少写了些东西 总的步骤: 一:导入 ...

  3. 使用live delegate on解决js后装html故障问题

    今天写一个前端的东西.每学到更多的知识.几下就能写几行代码.代码行数十个.代码几个文件量--这是真的.一直以来研究的前端遇到的问题仍然在实践百度谷歌问答. 我今天遇到这样的问题:已经写js代码,正确a ...

  4. ecshop广告调用方法

    在简单地概括ecshop广告调用该方法,已发表在博客上,在这里,我们总结了以下 :就是官方默认的方法.先加入广告位,然后加入模板的广告位区域,再在将两者相应上. 1.后台 > 广告管理 > ...

  5. 了解大数据的技术生态系统 Hadoop,hive,spark(转载)

    首先给出原文链接: 原文链接 大数据本身是一个很宽泛的概念,Hadoop生态圈(或者泛生态圈)基本上都是为了处理超过单机尺度的数据处理而诞生的.你能够把它比作一个厨房所以须要的各种工具. 锅碗瓢盆,各 ...

  6. 批量创建采购订单 BAPI_PO_CREATE1

    *&---------------------------------------------------------------------* *& REPORT  ZMM_PO_C ...

  7. ocp认证考试指南第一章

    数据库存储结构: 物理数据库存储结构: 必须的三类文件: 控制文件(controlFile):multiplexing the controfile 多路复用控制文件,指向其它关键文件,存储序列号和时 ...

  8. USACO maze1 BFS

    不写了很长的时间bfs该,很长一段时间的中间失误,当延期一次延伸成功的新节点的节点应该被标记为参观.否则,在某些情况下无限期延长队列. 输入一个小坑爹处理称号,能够进来当字符串被读取.然后用周围的墙上 ...

  9. ssis 到别的表查找临时变量值

    原文:ssis 到别的表查找临时变量值 etl过程过,往一个数据库表插入数据,插入的值往往需要到另外一个数据库读取.例如下面的客户跟踪,需要一个"项目ID",这个ID需要到另一个数 ...

  10. [SignalR]Self-Host

    原文:[SignalR]Self-Host SignalR 的Self-Host,可以将客户端脚本需要调用的服务端后台代码寄宿在诸如控制台应用程序中,作为寄宿端需要.NET 4.5以及jquery.s ...