Taurus.MVC 2.2 开源发布:WebAPI 功能增强(请求跨域及Json转换)

简介:

背景:

1:有用户反馈了关于跨域请求的问题。

2:有用户反馈了参数获取的问题。

3:JsonHelper的增强。

在综合上面的条件下,有了2.2版本的更新,也因此写了此文。

开源地址:

https://github.com/cyq1162/taurus.mvc

下面对增强的功能进行介绍:

1:跨域请求

除了常规的的JsonP跨域,Html5开始支持增强跨域,则变得更为方便,只需要服务端请求头输出:

1  if (context.Request.UrlReferrer != null && context.Request.Url.Host != context.Request.UrlReferrer.Host)2  {3     //跨域访问4     context.Response.AppendHeader("Access-Control-Allow-Origin", "*");5     context.Response.AppendHeader("Access-Control-Allow-Credentials", "true");6  }

如上代码:

?
1
2
3
4
5
1:可以通过检测来源的主机和请求的主机不一致判断是否跨域,如果是,则返回允许跨域标识。
 
2:第一个*表示允许任意请求,当然你也可以指定多个“http://a.com,http://b.com”.
 
3:第二个true表示允许跨域操作cookie,反之,则一行都不要出现,而不是设置为false。

另外,网上有文章介绍说,跨域时,浏览器会发出一个OPTIONS的预请求,于是框架也做出了处理:

1 if (context.Request.HttpMethod == "OPTIONS")2 {3   context.Response.StatusCode = 204;4   context.Response.AppendHeader("Access-Control-Allow-Method", "GET,POST,PUT,DELETE");5   context.Response.AppendHeader("Access-Control-Allow-Origin", "*");6   context.Response.AppendHeader("Access-Control-Allow-Headers", context.Request.Headers["Access-Control-Allow-Headers"]);7   context.Response.End();8 }

状态码204,比起200的好处,是不需要返回Conent内容,只返回请求头。

在Demo的时候,测试了一下Get请求,没发现浏览器发出预请求,可能场景或环境不同。

下面是一个简单的测试:

在控制台(aries.cyqdata.com)发起一个跨域请求(http://localhost:13508/home/index):

如果把跨域关闭:

<add key="IsAllowCORS" value="false"/>

结果是:

于是:框架默认是支持跨域请求的,如果不想支持,可以关闭!

2:常规请求参数的获取

发现有用户在使用Taurus.MVC时,思维还在停留ASP.NET WebAPI。

比如请求:

?
1
http: //localhost:13508/api/default?id=1

对方法定义的方法是:

?
1
2
3
4
public   void  Default( int  id)
{
           
}

结果当然抛异常,找不到方法了,框架默认收集的都是无参数的方法名。

于是用户就懵了,不知道怎么拿参数,我也懵了,怎么能不知道的,至少也应该知道Request吧。

下面介绍框架封装的获取参数的方法:

1:Query<T>("字段") (封装自Request)

针对:a=1&b=2这种Get或Post的参数,用Query<T>("字段")拿。

?
1
2
3
4
  public  override  void  Default()
  {
     int  id = Query< int >( "id" );
  }

2:Para参数

针对:/api/user/3这种参数,可以直接拿Action参数(user)、Para参数就是3了(按:Controller/Action/Para这么个分隔方式)

?
1
2
3
4
public  override  void  Default()
{
    string  para3 = Para;

3:增强型的参数获取:GetJson方法

1:有些场景,对方Post的数据,并不是key=value这种格式,而是:

直接就是一串Json:({a:"1","b":"2"})过来,这时候,常规的方法是拿不到数据。

原生的可以通过HttpInputStream流拿到,但框架进行了人性化的封装:

通过GetJson()方法,可以获取:

 public override void Default()
 {
    Write(GetJson());
 }

执行输出的结果:

2:变态的GetJson():支持Get与Post的参数转Json

该方法不仅可以拿到直接Post的Json,还可以将a=1&b=2这种方式直接转Json返回,如:

发起请求:

请求结果:

对于Post请求处理结果一致,就不重复截图了!

4:增强型的GetEntity<T>()方法

1:对于Post或Get的常规参数:a=1&b=2这种类型的,除转json,也可以转实体:

发起请求:

请求结果:

演示为Get、Post的结果一致,不另截图!

2:GetEntity支持无限级复杂嵌套

你可以Post复杂的Json:{a:{b:2,c:3},f:['1','2']}之类的,只要实体对应上,即可转换,不另外截图。

3:GetList<T>方法

暂未提供:对于Post的[{},{}]的Json数组转换,可以用:

?
1
List<AB> list = JsonHelper.ToList<AB>(GetJson());

以上为获取参数转Json的相关方法,非常实用!!!

对于输出Json,用Write方法,可将复杂对象转换成Json。

上节:http://www.cnblogs.com/cyq1162/p/6069020.html  已介绍,不重复了。

总结:

Taurus.MVC,在处理为WebAPI方面,仍遵行着简单实用高效的原则。

欢迎加入金牛的行列!







     本文转自cyq1162 51CTO博客,原文链接:http://blog.51cto.com/cyq1162/1880762,如需转载请自行联系原作者






相关文章
|
22天前
|
JSON JavaScript 数据格式
jwt-auth插件实现了基于JWT(JSON Web Tokens)进行认证鉴权的功能。
jwt-auth插件实现了基于JWT(JSON Web Tokens)进行认证鉴权的功能。
35 1
|
4月前
|
JSON 数据格式
SpringMVC-接收请求中的json数据及日期类型参数传递
SpringMVC-接收请求中的json数据及日期类型参数传递
50 0
|
3月前
|
XML JSON 前端开发
Ajax技术【Ajax技术详解、 Ajax 的使用、Ajax请求、 JSON详解、JACKSON 的使用 】(一)-全面详解(学习总结---从入门到深化)
Ajax技术【Ajax技术详解、 Ajax 的使用、Ajax请求、 JSON详解、JACKSON 的使用 】(一)-全面详解(学习总结---从入门到深化)
58 1
|
28天前
|
JSON 数据格式
糊涂工具类(hutool)post请求设置body参数为json数据
糊涂工具类(hutool)post请求设置body参数为json数据
19 1
|
1月前
|
JSON JavaScript 前端开发
优化你的 HTTP 请求:JSON 与 Form-data 比较
在讨论现代网络开发与API设计的语境下,理解客户端和服务器间如何有效且可靠地交换数据变得尤为关键。这里,特别值得关注的是两种主流数据格式:JSON与Form-data。尽管它们的终极目标一致,即数据传输的高效性和可靠性,但它们各自所具备的特点和应用情境却大相径庭,构成了数据传输的两个主要途径。
|
3月前
|
JSON fastjson 数据库
字符编码导致Rapidjson(腾讯开源的json解析库)到Fastjson(阿里开发的Java json解析库)转换失败的原因分析
最近在客户端的开发的过程中,使用到了RapidJson,公司的开发是客户端和数据库端都由不同的人进行开发,我负责的客户端的逻辑开发(使用c++),开发工具同时使用了VS2017和QT的编译环境,使用QT主要是为了客户端界面开发方便,而使用了VS环境主要是维护公司开发的数据库接口库,这个库的唯一作用就是作为一个中间桥梁,使用Rapidjson将数据库接口的json数据格式解析为结构体数据,从而在客户端界面进行展示,或者接收客户端的数据,使用Rapidjson将其转换为json数据,发送给数据库接口以保存数据使用 。不太明白的可以参考我上一篇文章说明Rapidjson的使用过程-Parse解析数组
48 0
|
3月前
|
JSON 安全 算法
JSON Web Token(缩写 JWT) 目前最流行、最常见的跨域认证解决方案
JSON Web Token(缩写 JWT) 目前最流行、最常见的跨域认证解决方案
129 0
|
4月前
|
JSON 前端开发 Java
(简易详细)spring boot 使用拦截器 实现拦截前端请求并返回json到前端页面
(简易详细)spring boot 使用拦截器 实现拦截前端请求并返回json到前端页面
99 0
|
4月前
|
XML JSON API
Json实现根据关键词搜索请求唯品会商品列表数据方法,唯品会商品列表数据接口,唯品会API接口申请指南,支持全站
Json实现根据关键词搜索请求唯品会商品列表数据方法,唯品会商品列表数据接口,唯品会API接口申请指南,支持全站
113 1
|
4月前
|
JSON API 数据格式
Json实现根据关键词搜索请求1688商品列表数据方法,1688商品列表数据接口,1688API接口申请指南
Json实现根据关键词搜索请求1688商品列表数据方法,1688商品列表数据接口,1688API接口申请指南
117 0