C# HttpClient Get Post简单封装

本文介绍了如何使用C#创建一个封装的HTTP客户端类(MyHttpHelper),用于简化GET和POST请求,并通过实例展示了如何在.NETCorewebapi中进行接口测试,包括GET、POST操作以及实体类的使用。
摘要由CSDN通过智能技术生成

前言

微软官方有Get和Post请求,我把他简单化处理一下

封装好的代码

 public class MyHttpHelper
 {

     private string baseUrl;
     

     /// <summary>
     /// 基础Api
     /// </summary>
     public string BaseUrl
     {
         get
         {
             return baseUrl;
         }

         set
         {
             baseUrl = value;
             MyHttpClient = new HttpClient()
             {
                 BaseAddress = new Uri(baseUrl)
             };
         }
     }


     public HttpClient MyHttpClient { get; set; }
     public MyHttpHelper()
     {

     }

     public MyHttpHelper(string baseUrl)
     {
         BaseUrl = baseUrl;
     }

     /// <summary>
     /// 序列化返回值
     /// </summary>
     /// <typeparam name="T"></typeparam>
     /// <param name="api"></param>
     /// <param name="strParams"></param>
     /// <returns></returns>
     public async Task<T> JsonHttpGet<T>(string api, Dictionary<string, string> strParams)
     {
         var res = await MyHttpGet(api, strParams);
         return await res.Content.ReadFromJsonAsync<T>();
     }


     /// <summary>
     /// 序列化返回值
     /// </summary>
     /// <typeparam name="T"></typeparam>
     /// <param name="api"></param>
     /// <param name="value"></param>
     /// <param name="strParams"></param>
     /// <returns></returns>
     public async Task<T> JsonHttpPost<T>(string api, object value, Dictionary<string, string> strParams)
     {
         var res = await MyHttpPost(api, value, strParams);
         return await res.Content.ReadFromJsonAsync<T>();
     }

     /// <summary>
     /// 序列化请求
     /// </summary>
     /// <param name="api"></param>
     /// <param name="param"></param>
     /// <returns></returns>
     public async Task<HttpResponseMessage> MyHttpGet(string api, Dictionary<string, string> param)
     {
         string paramStr = DictionaryToParams(param);
         return await MyHttpClient.GetAsync(api + paramStr);
     }

     /// <summary>
     /// 自定义的转发功能
     /// </summary>
     /// <param name="api"></param>
     /// <param name="dataname"></param>
     /// <param name="value"></param>
     /// <returns></returns>
     public Task<HttpResponseMessage> MyHttpPost(string api, object value, Dictionary<string, string> strParams)
     {
         return MyHttpClient.PostAsync(api + DictionaryToParams(strParams), new StringContent(JsonConvert.SerializeObject(value), Encoding.UTF8, "application/json"));
     }

     /// <summary>
     /// 字典转参数
     /// </summary>
     /// <param name="param"></param>
     /// <returns></returns>
     public string DictionaryToParams(Dictionary<string, string> param)
     {
         var res = "";
         if (param != null)
         {
             var list = param.ToList();
             if(list.Count != 0)
             {
                 for (var i = 0; i < list.Count; i++)
                 {

                     if (i != 0)
                     {
                         res += "&";
                     }
                     res += $"{list[i].Key}={list[i].Value}";
                 }
                 res = "?" + res;
             }
           
         }
         return res;
     }
 }

测试接口

不懂的可以自己去看一下我的这篇文章

.NET Core webapi 从零开始在IIS上面发布后端接口

在这里插入图片描述

实体类

    public class Person
    {
        public int Id { get; set; }
        public string Name { get; set; }
    }
  /// <summary>
  /// 测试类
  /// </summary>
  [Route("api/[controller]/[action]")]
  [ApiController]
  public class TestController : ControllerBase
  {

      /// <summary>
      /// 测试Num
      /// </summary>
      /// <param name="num"></param>
      /// <returns></returns>
      [HttpGet]
      public int TestNum(int num)
      {

          return num;
      }

      /// <summary>
      /// 测试Post
      /// </summary>
      /// <param name="num"></param>
      /// <returns></returns>
      [HttpPost]
      public Person TestPerson(Person person)
      {
          return person;
      }


      /// <summary>
      /// Person+Num
      /// </summary>
      /// <param name="num"></param>
      /// <param name="person"></param>
      /// <returns></returns>
      [HttpPost]
      public Person TestPersonNum(int num,Person person)
      {
          person.Id += num;
          return person;

      }
      
  }

测试代码

static void Main(string[] args)
{
    var httpHelper = new MyHttpHelper("https://localhost:7291/");
    Task.Run(async() =>
    {
        var res = await httpHelper.JsonHttpGet<int>("/api/Test/TestNum", new Dictionary<string, string> { { "num", "7" } });
        Console.WriteLine(res);
        var res2 = await httpHelper.JsonHttpPost<Person>("/api/Test/TestPerson", new Person() { Id = 4, Name = "小王" }, null);
        Console.WriteLine(JsonConvert.SerializeObject(res2));

        var res3 = await httpHelper.JsonHttpPost<Person>("/api/Test/TestPersonNum", new Person() { Id = 4, Name = "小王" }, new Dictionary<string, string>() { { "Num", "4" } });

        Console.WriteLine(JsonConvert.SerializeObject(res3));

    });
   


    Console.WriteLine("Hello, World!");

    Console.ReadKey();
}

在这里插入图片描述

  • 6
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值