asp.net core下的RequestBody和RequestForm提交

最近在开发asp.net core时,遇到RequestBody和RequestForm数据提交方式,整理了一下,把结果记录下来。

对于RequestForm一般是接收表单的信息,而RequestBody通常是来接收较为复杂的数据(集合或杂杂对象)在asp.net中很容易区分接收,在action用[FromBody]和[FromForm]来标识就可以,对于客户端来说,区别就要大一些,这里记录两种方式,RestSharp和JQuery的ajax请求两种方式。

  1. 服务端

1
2
3
4
5
6
7
8
9
10
11
[HttpPost( "additem" )]
public  IActionResult AddItem([FromBody]Item item)
{
     return  new  JsonResult( new  { Result = 0, Message =  "添加成功" ,Content=item.ToString() }, new  Newtonsoft.Json.JsonSerializerSettings ());
}
  
[HttpPost( "additem" )]
public  IActionResult AddItem([FromForm]Item item)
{
     return  new  JsonResult( new  { Result = 0, Message =  "添加成功"  ,Content=item.ToString()}, new  Newtonsoft.Json.JsonSerializerSettings ());
}

 

  1. RestSharp方式

    在项目中,用Nuget安装RestSharp类库,我用的是v105.2.3。

    用RestSharp提交RequestBody和RequestForm相对简单,代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
using  System; using  RestSharp; namespace  RestSharpTest
{
     class  Program    {
         static  void  Main( string [] args)
         {
             while  ( true )
             {
                 var  client =  new  RestClient( "http://localhost:5000" );
                 var  request =  new  RestRequest( "additem" , Method.POST);
                 request.RequestFormat = DataFormat.Json;
                 Console.WriteLine( "1、RequestBody  2、RequestForm" );
                 switch  (Console.ReadLine())
                 {
                     case  "1" :
                         request.AddJsonBody( new  { ID = 111, Name =  "张三" , Birthday = DateTime.Now });
                         break ;
                     case  "2" :
                         request.AddObject( new  { ID = 111, Name =  "张三" , Birthday = DateTime.Now });
                         break ;
                 }
                 var  response = client.Execute(request);
                 Console.WriteLine(response.Content);
               
             }
  
         }
     }
}


  1. JQuery中用ajax请求

    如果用jquery访问别的web,设置跨域访问(关于跨域访问,查看http://www.cnblogs.com/xishuai/p/aspnet-core-cors.html

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
<!DOCTYPE html>< html >< head >< meta  http-equiv = "Content-Type"  content = "text/html; charset=utf-8" />    < title ></ title >
     < meta  charset = "utf-8"  />    < script  src = "bower_components/jquery/dist/jquery.min.js" ></ script ></ head >< body >    < input  id = "sava1"  value = "保存RequestForm"  type = "button" />    < input  id = "sava2"  value = "保存RequestBody"  type = "button"  />    < script >        $("#sava1").click(function () {
             $.post("http://localhost:5000/additem", { ID: 112, Name: "李四", Birthday: "2017-01-23" }, function (result) {             
                 alert(result.Message+result.Content);
             },"json")
         })
  
         $("#sava2").click(function () {         
             $.ajax({
                 type: "POST",
                 url: "http://localhost:5000/additem",
                 contentType: "application/json",
                 dataType: "json",
                 async: true,
                 data: JSON.stringify({ "ID": 112, "Name": "李四", "Birthday": "2017-01-23 12:12:12" }),
                 success: function (result) {
                     alert(result.Message + result.Content);
                 }
             });
  
         })
     </ script ></ body ></ html >


一般情况下,web api是用[FromBody],因为一般web api是供app或DeskTop的应用访问,web页面请求用[FromForm],一般情况下web页面是通过表单向后台提交信息。


















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


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
wtforms-json是一个用于在Flask应用中处理JSON数据的扩展库。它允许你使用wtforms库来验证和处理复杂格式的JSON数据。通过使用wtforms-json,你可以定义一个新的基类JsonForm,该基类继承自wtforms的Form类,并且可以接受复杂格式的JSON数据进行校验。在JsonForm中,你可以使用wtforms_json.init()来初始化wtforms-json,并使用from_json()方法从请求中获取JSON数据并创建表单对象。然后,你可以使用validate()方法对表单进行验证,如果验证失败,可以抛出ParameterException异常。最后,你可以返回验证通过的表单对象。[1] 普通格式的JSON参数示例如下: { "name": "xiaowang", "age": 1, "address": "beijing" } 复杂格式的JSON参数示例如下: { "category": { "category_name": "电脑", "category_id": 2 }, "address_list": [ "beijing", "shanghai" ], "name": "xiaohong", "age": 1 } 在使用wtforms-json之前,使用普通的wtforms库无法接受复杂格式的JSON数据,只能接受普通格式的JSON数据和URL查询参数进行校验。[2] 为了处理不同类型的请求数据,可以使用自定义的RequestForm类。在RequestForm类中,可以根据请求的Content-Type来判断请求的数据类型。如果Content-Type为"application/json",则使用request.get_json()获取JSON数据,并使用super()方法初始化表单对象。如果Content-Type为"application/x-www-form-urlencoded"或"multipart/form-data",则使用request.form.to_dict()获取表单数据,并使用super()方法初始化表单对象。最后,可以使用validate()方法对表单进行验证,并在验证失败时返回错误信息。[3]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值