怎么说,单请求封装多请求,这句话确实有点绕了,但还是要看清楚,想明白这到底是怎么一回事,单请求即一次请求(get,post,put,delete),封闭多请求,即在客户端发送的一个请求中可能包含多个子请求(真实的请求,接口),这种设计确实看着很灵活,客户端可以根据自己的需要去拿服务器的数据,确实不错!

首先我们要定义一套自己的请求和响应对象

 
#region 请求对象
/// <summary>
/// 参数对象
/// </summary>
[DataContractAttribute]
public class RequestParam
{
public RequestParam(string name, string value)
{
this.ParamName = name;
this.ParamValue = value;
}
[DataMemberAttribute]
public string ParamName { get; private set; }
[DataMemberAttribute]
public string ParamValue { get; private set; }
}
/// <summary>
/// 数据包中的实体
/// </summary>
[DataContractAttribute]
public class RequestData
{
public RequestData()
{
this.HttpMethod = 0;
this.RequestParam = new Dictionary<string, string>();
}
/// <summary>
/// 本次通讯唯一标示
/// </summary>
[DataMemberAttribute]
public string GuidKey { get; set; }
/// <summary>
/// 请求方式0:get,1:Post
/// </summary>
public int HttpMethod { get; set; }
/// <summary>
/// 要调用的方法
/// </summary>
[DataMemberAttribute]
public string Url { get; set; }
/// <summary>
/// 方法的参数列表
/// </summary>
[DataMemberAttribute]
public IDictionary<string, string> RequestParam { get; set; }
}
/// <summary>
/// 请求数据包
/// </summary>
[DataContractAttribute]
public class RequestDataSegment
{
public RequestDataSegment()
{
this.RequestData = new List<RequestData>();
}
[DataMemberAttribute]
public List<RequestData> RequestData { get; set; }
}
#endregion
 

再来看一下响应对象

 
#region 响应对象
/// <summary>
/// 数据包实体
/// </summary>
[DataContractAttribute]
public class ResponseData
{
/// <summary>
/// 本次传输过程中唯一标识
/// </summary>
[DataMemberAttribute]
public string GuidKey { get; set; }
/// <summary>
/// 状态:100失败,200成功
/// </summary>
[DataMemberAttribute]
public int Status { get; set; }
/// <summary>
/// 数据包:Json对象
/// </summary>
[DataMemberAttribute]
public string Data { get; set; }
}
/// <summary>
/// 响应数据包
/// </summary>
[DataContractAttribute]
public class ResponseDataSegment
{
public ResponseDataSegment()
{
this.ResponseData = new List<ResponseData>();
}
[DataMemberAttribute]
public List<ResponseData> ResponseData { get; set; }
}
#endregion
 

而我们服务器对客户端开放的是一个大接口,或者叫入口接口,它负责把客户端传来的请求进行解析,然后代理客户端,处理多请求,并将结果进行组装,返回给客户端,在mvc和web api里,我们为了让程序扩展性更强,通常把这个核心逻辑写在attribute里

下面看一下代码的实现 

 
    /// <summary>
/// Api代理过滤器(api多任务请求的入口)
/// </summary>
[AttributeUsage(AttributeTargets.Method)]
public class ApiProxyFilter : ActionFilterAttribute
{
public override void OnActionExecuting(ActionExecutingContext filterContext)
{
var Request = filterContext.HttpContext.Request;
var responseDataSegment = new ResponseDataSegment();
var data = VCommons.SerializeMemoryHelper.DeserializeFromJson<RequestDataSegment>(Request.Form["dataSeg"]);
if (data != null && data.RequestData.Any())
{
foreach (var item in data.RequestData)
{
try
{
HttpResponseMessage response;
var handler = new HttpClientHandler() { AutomaticDecompression = DecompressionMethods.GZip };
using (var http = new HttpClient(handler))
{ if (item.HttpMethod == 0)
{
if (item.RequestParam != null)
{
item.Url += "?";
foreach (var p in item.RequestParam)
item.Url += p.Key + "=" + p.Value + "&";
item.Url = item.Url.Remove(item.Url.Length - 1, 1);
}
response = http.GetAsync(item.Url).Result;
}
else
{
var content = new FormUrlEncodedContent(item.RequestParam);
response = http.PostAsync(item.Url, content).Result;
} response.EnsureSuccessStatusCode();
responseDataSegment.ResponseData.Add(new ResponseData
{
GuidKey = item.GuidKey,
Status = 200,
Data = response.Content.ReadAsStringAsync().Result
});
}
}
catch (Exception ex)
{ responseDataSegment.ResponseData.Add(new ResponseData
{
GuidKey = item.GuidKey,
Status = 100,
Data = ex.Message
});
} } }
filterContext.HttpContext.Response.ContentType = "applicatin/json";
filterContext.HttpContext.Response.Write(VCommons.SerializeMemoryHelper.SerializeToJson(responseDataSegment));
base.OnActionExecuting(filterContext);
}
}

对于你的具体项目,选个主入口,在它上面添加上ApiProxy特性即可

     /// <summary>
/// Api统一处理的入口
/// </summary>
/// <returns></returns>
[ApiProxyFilter]
public JsonResult Index()
{
return null;
}

现在你就可以去测试你的客户端了,哈哈,看是否把你的单个请求里的(三个请求)转发并为你返回了,呵呵.

webapi基于单请求封装多请求的设计【转】的更多相关文章

  1. WebApi系列~基于单请求封装多请求的设计

    回到目录 怎么说,单请求封装多请求,这句话确实有点绕了,但还是要看清楚,想明白这到底是怎么一回事,单请求即一次请求(get,post,put,delete),封闭多请求,即在客户端发送的一个请求中可能 ...

  2. drf:restful概念,类继承关系,drf请求封装,drf请求流程,版本控制组件,认证组件(token),权限组件

    1.restful规范 resfful规范的概念最重要: 是一套规范,规则,用于程序之间进行数据交换的约定. 他规定了一些协议,对我们感受最直接的就是,以前写增删改查的时候需要些四个视图寒素,rest ...

  3. WebApi系列~基于单请求封装多请求的设计~请求的安全性设计与实现

    回到目录 对于一个Http请求如何保证它的安全,这已经不是一个新的话题,对于请求的安全我们通常考虑的无非就是"请求的被篡改性"和"请求的被复制性",第一个问题我们很容易实现,可以通过参数+密钥的方式, ...

  4. Flutter 实际开发常用工具类(全局提示,请求封装,token缓存,验证码倒计时、常用窗帘动画及布局)

    介绍: 一星期从入门到实际开发经验分享及总结           代码传送门github Flutter是谷歌的移动UI框架,可以快速在iOS和Android上构建高质量的原生用户界面.未来App开发 ...

  5. 简单的基于Vue-axios请求封装

    具体实现思路=>封装之前需要用npm安装并引入axios,使用一个单独的js模块作为接口请输出对象,然后export dafult 这个对象. 1.首先我们需要在Vue实例的原型prototyp ...

  6. uniapp 基于 flyio 的 http 请求封装

    之前写请求都是用别人封装好的,直接 import request 完事,自己第一次写还是一头雾水,学习了一波搞清楚了些,可以写简单的封装了. 首先要搞清楚为什么封装请求,同其他的封装一样,我们把不同请 ...

  7. 基于 fetch 的请求封装

    原生 fetch 请求失败后(如无网络)状态会变成 reject 走 .catch .绝大多数情况下业务场景只需要给个 toast 等简单处理.每个请求都 .catch 会显得格外繁琐,并且如果不 . ...

  8. iOS开发--Swift 基于AFNetworking 3.0的网络请求封装

    Swift和OC基于AFNetworking的网络请求流程相同, 就是语法不同, 对于Swift语法不是很清楚的同学, 建议多看看API文档, 自己多多尝试. 写过OC的应该都明白每句话做什么的, 就 ...

  9. 转-封装网络请求库,统一处理通用异常 (基于volley网络请求库)

    http://blog.csdn.net/kroclin/article/details/40540761 一.前言 volley的发布让网络请求也变得十分便利,但是我们通常懒得很想用一两句代码实现一 ...

随机推荐

  1. ORB-SLAM2 地图保存

    一.简介 在ORB-SLAM2的System.h文件中,有这样一句话:// TODO: Save/Load functions,让读者自己实现地图的保存与加载功能.其实在应用过程中很多场合同样需要先保 ...

  2. Unity 2018 Cookbook (Matt Smith 著)

    1. Displaying Data with Core UI Elements (已看) 2. Responding to User Events for Interactive UIs (已看) ...

  3. Go Modules使用教程(3分钟学会)

    前言 随着Go 1.13发布,GOPROXY默认值proxy.golang.org在中国大陆不能被访问. 七牛云顺势推出goproxy.cn,以利于中国开发者更好使用Go Modules,它是非盈利性 ...

  4. pytest 常见用法

    前言 之前一篇文章简单介绍了 pytest 以及 fixture :https://www.cnblogs.com/shenh/p/11572657.html .实际在写自动化测试脚本中,还会有一些很 ...

  5. RMI初体验--第一次错处理java.rmi.UnmarshalException&ClassNotFoundException

    今天参考了一下网上Rhello示例,搞了一下RMI测试. server端是 java8 client 段是java6 然后 运行报错: java.rmi.UnmarshalException: err ...

  6. PHP高级进阶梳理

    基础篇 1.深入理解计算机系统 2.现代操作系统 3.C程序设计语言 4.C语言数据结构和算法 5.Unix环境高级编程 6.TCP/IP网络通信详解 7.Java面向对象编程 8.Java编程思想 ...

  7. 2019-3-20-UWP-How-to-custom-RichTextBlock-right-click-menu

    原文:2019-3-20-UWP-How-to-custom-RichTextBlock-right-click-menu title author date CreateTime categorie ...

  8. 2019-11-29-win10-uwp-列表模板选择器

    原文:2019-11-29-win10-uwp-列表模板选择器 title author date CreateTime categories win10 uwp 列表模板选择器 lindexi 20 ...

  9. [转载].NET ASP.NET 中web窗体(.aspx)利用ajax实现局部刷新

    之前开发的一套系统中用到了大量的 checkboxList 控件,但是每次选定之后都会刷新整个页面,用户体验很差,百度了之后查到这篇文章,尝试了一下可以实现,所以转载了过来,记录一下,也给其他有相同困 ...

  10. CSS3特效之转化(transform)和过渡(transition)

    CSS3特效之转化(transform)和过渡(transition) 在对动画深入之前,我们需要先了解它的一些特性,CSS3的转化(transform)和过渡(transition).有人可能会有疑 ...