RestSharp简单使用

RestSharp

RestSharp是一个轻量的,不依赖任何第三方的模拟Http的组件或者类库。RestSharp具体以下特性;支持net4.0++,支持HTTP的GET, POST, PUT, HEAD, OPTIONS, DELETE等操作,支持oAuth 1, oAuth 2, Basic, NTLM and Parameter-based Authenticators等授权验证等。截止当前目前是github最高stars的http类库。
image-20230221155842184

GitHub仓库

restsharp/RestSharp: Simple REST and HTTP API Client for .NET (github.com)

官方文档

RestSharp Next (v107) | RestSharp

使用介绍

NuGet包

image-20230221160021187

请求类型

  • Method.Get
  • Method.Post
  • Method.Put
  • Method.Delete
  • Method.Patch
  • Method.Head
  • Method.Options
  • Method.Merge
  • Method.Copy
  • Method.Search

Http标头

AddObject
var obj = new {
    status = 1,
    priority = "high",
    ids = new [] { "123", "456" }
};
request.AddObject(obj);

//或者 AddParameter(key, value);
request.AddParameter("status", 1);
request.AddParameter("priority", "high");
request.AddParameter("ids", "123,456");

AddUrlSegment
var request = new RestRequest("health/{entity}/status").AddUrlSegment("entity", "s2");
//请求地址会转换为 health/s2/status
AddStringBody

如果您有预序列化的有效负载(如 JSON 字符串),则可以使用它将其添加为正文参数。需要指定内容类型,以便远程终结点知道如何处理请求正文

var json = "{ data: { foo: \"bar\" } }";
request.AddStringBody(json, ContentType.Json);
JsonBody
  • 指示 RestClient 在发出请求时将对象参数序列化为 JSON
  • 将内容类型设置为application/json
  • 将请求正文的内部数据类型设置为DataType.Json

不要将 JSON 字符串或某种实例发送到

var param = new MyClass { IntData = 1, StringData = "test123" };
request.AddJsonBody(param);

简单例子

        private async Task<RestResponse> RestSharpTest(string requestUrl,Method apiMethod)
        {
            var client = new RestClient(requestUrl);
            client.AcceptedContentTypes = new[] { "application/json", "text/json", "text/x-json", "text/javascript", "text/plain", "*/*" };
            var request = new RestRequest();
            switch (apiMethod)
            {
                case RequestTypeEnum.Get:
                    request = new RestRequest("", Method.Get);
                    break;

                case RequestTypeEnum.Post:
                    request = new RestRequest("", Method.Post);
                    break;

                case RequestTypeEnum.Put:
                    request = new RestRequest("", Method.Put);
                    break;

                case RequestTypeEnum.Patch:
                    request = new RestRequest("", Method.Patch);
                    break;

                case RequestTypeEnum.Delete:
                    request = new RestRequest("", Method.Delete);
                    break;

                default:
                    break;
            }
            request.AddHeader("Content-Type", "application/json");
            var response = await client.ExecuteAsync(request);
            return response;
        }
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值