前言

即时通信项目中初次调用OA接口遇到了一些问题,因为本人从业后几乎一直做CS端项目,一个简单的WebAPI调用居然浪费了不少时间,特此记录。

 

接口描述

首先说明一下,基于Http协议的Get、Post请求,网上有很多例子,其实方法都是一样的,这块没什么好说的,我也测试过我的代码,正常的调用是没问题的。问题不是在请求方法上,而是在如何取出数据上。
因为对应我需求接口的开发是个实习生,对于如何提供接口,他并不熟悉,其中我还帮了一些忙,但我毕竟不是很熟BS端那块,纠结了1天多才调通接口。
描述一下需求接口:
OA方需要提供头像下载的接口供即时通信初次登陆时下载头像。
思路如下:
1.接口内将OA头像文件夹打包压缩成zip文件
2.将zip文件,转成字节流byte[]
3.将字节流byte[]序列化成json格式 返回

 

问题

思路1、2他按照我的要求做了,我测试接口后遇到的问题是取出的byte[]顺序不对,我本地反序列化后转成zip文件没法解压,多次测试后我又让他按照思路3来做。

测试接口,遇到了个问题,我反序列化出来的json字符串,包含了d,如下:

WebAPI调用笔记

 

解决

因为不熟悉这块,我不知道如何取出d中的数据,上网查也不好查,因为几乎没有问这块的,后来我问OA做手机端的同事,才知道他们提供的接口方法都是void,不在返回值的,都是通过http的Context.Response返回的,在调用的时候不会出现这个d字符。然而他也不知道如何取出d中的数据,没办法只能在网上再找,后来在一篇CSDN的博客中的评论里找到了办法,将json转换成hash表的格式,然后直接取出来d的数据,然后反序列化json成对象,如下:

string headjson = WebAPIHelper.HttpPost(OAAddress, null);
JavaScriptSerializer json = new JavaScriptSerializer();
Hashtable table = (Hashtable)json.Deserialize(headjson, typeof(Hashtable));
string d = table["d"].ToString();//取出d中的数据
HeadByte h1 = JsonConvert.DeserializeObject<HeadByte>(d);

到此为止,问题终于解决。

 

拓展

因为比较在意普通的接口是如何提供返回结果的,我特意看一下OA中的WebAPI方法,同事说过,不带d的方法无需返回值,使用void即可,请求返回的结果都在Response中,json字符串出现d的原因是方法的返回值是string类型,特附上不需要另外取json中d的方法:

 1         [ScriptMethod(ResponseFormat = ResponseFormat.Json)]
 2         [WebMethod(Description = " 获取筛选条件", EnableSession = true)]
 3         public void GetTestList(string Type,string UserID)
 4         {
 5             Context.Response.ContentType = "text/plain";
 6             Context.Response.Charset = "UTF-8";
 7             Context.Response.ContentEncoding = System.Text.Encoding.UTF8;
 8             Dictionary<string, object> dicReturn = new Dictionary<string, object>();
 9             Dictionary<string, object> dic = new Dictionary<string, object>();
10             string jsonStr = string.Empty;//保存返回的json字符串
11             try
12             {
13                   //将返回的结果放到dic中
14                   //可以放到list里也可以放到DataTable中
15                   List<SortModel> list = xxx.GetXXXXXList(parames1, parames2);
16                  dic.Add("Count", xxx.GetXXXXXCount(parames1, parames2));
17                  dic.Add("List", list);
18                  //或者
19                  DataTable dt = xxx.GetXXXXX(parames1, parames2);
20                  dic.Add("Count", xxx.GetXXXXXCount(parames1, parames2);
21                  dic.Add("List2", dt);
22                  //获取成功
23                 dicReturn.Add("State", "1");
24                 dicReturn.Add("ErrorMsg", "获取成功");
25                 dicReturn.Add("Data", dic);
26                 dicReturn.Add("ErrCode", "0");
27           }
28           catch (Exception ex)
29           {
30                dicReturn.Add("State", "0");
31                dicReturn.Add("ErrorMsg", ex.Message);
32                dicReturn.Add("Data", "");
33                dicReturn.Add("ErrCode", "1");
34           }
35           //序列化 json字符串
36           jsonStr = JsonConvert.SerializeObject(dicReturn);
37           Context.Response.Write(jsonStr);
38           Context.Response.End();
39 
40 }          
View Code

相关文章:

  • 2021-06-07
  • 2021-10-18
  • 2021-07-06
  • 2021-09-04
  • 2021-09-09
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2021-11-23
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2021-12-15
  • 2022-12-23
  • 2021-12-17
相关资源
相似解决方案