DocuSign授权码授予访问令牌端点每次都返回错误请求

时间:2020-08-31 14:30:19

标签: c# asp.net-core-webapi docusignapi .net-core-2.1

我尝试了不同的方式来传递headercontent,但是每次从bad request获取docusign来获取访问令牌。

下面是回调Web API方法,该方法在请求authorization code之后被调用:

[HttpGet]
 [AllowAnonymous]
 [Route("CallBack")]
 public string Callback()
 {
     string accessToken = "";
     try
     {
         var response = Request.Query;
         if (Request.Query != null && Request.Query.Keys != null && Request.Query.Keys.Count > 0)
         {
             var authorizationCode = Request.Query["code"];

             /*                    
                     Request => POST https://account-d.docusign.com/oauth/token
                     Content-Type: application/x-www-form-urlencoded
                     Header => Authorization: Basic BASE64_COMBINATION_OF_INTEGRATOR_AND_SECRET_KEYS
                     Data => grant_type=authorization_code&authorization_code=YOUR_AUTHORIZATION_CODE
             */

             //Body
             var keyValues = new Dictionary<string, string>();
             keyValues.Add("grant_type", "authorization_code");
             keyValues.Add("authorization_code", authorizationCode);
             var bodyContent = new FormUrlEncodedContent(keyValues);

             //Header
             //Content-Type: application/x-www-form-urlencoded
             //Authorization: Basic BASE64_COMBINATION_OF_INTEGRATOR_AND_SECRET_KEYS 
             string base64Decoded = configuration.IntegrationKey + ":" + configuration.SecretKey;
             string base64Encoded;
             byte[] data = System.Text.ASCIIEncoding.ASCII.GetBytes(base64Decoded);
             base64Encoded = System.Convert.ToBase64String(data);

             var client = new System.Net.Http.HttpClient();
             client.BaseAddress = new Uri("https://account-d.docusign.com");
             var request = new System.Net.Http.HttpRequestMessage(HttpMethod.Post, "https://account-d.docusign.com/oauth/token");
             request.Content = bodyContent;

             request.Content.Headers.ContentType = new MediaTypeHeaderValue("application/x-www-form-urlencoded");
             request.Headers.Authorization = new AuthenticationHeaderValue("Basic", base64Encoded);

             var accessTokenresponse = client.SendAsync(request).Result;

             //Set access token
             //accessToken
         }
     }
     catch (Exception ex)
     {

     }

     return accessToken;
 }

1 个答案:

答案 0 :(得分:1)

一些适合您的想法:

  1. 最好使用OAuth2客户端库。这是InfoSec专家和DocuSign的高度建议。
  2. 如果您决定采用自己的实现方式:请通过Postman或类似工具尝试OAuth2流程,以确保您确切了解该流程的工作原理。
  3. 请记住,授权码是有时间限制的。您需要在一分钟左右的时间内将其交换为访问令牌(可能更少,我没有确切的数据)。
  4. 使用wireshark或类似工具来准确查看要发送到DocuSign的内容。
  5. 重要的InfoSec问题:在state参数中发送一个现时值,然后在从DocuSign收到第一个响应时检查它是否相同。