【发布时间】:2022-01-03 08:05:49
【问题描述】:
我正在尝试从 PayPal 获取访问令牌。
我已将其设置为 PayPal 中的应用程序,我可以看到我的客户 ID 和密码
我假设我不想在 javascript 前端公开我的秘密,所以我试图从 C# 获取访问代码,将令牌传递到前端,以便我可以进行 AJAX 发布/获取。
但是,它总是以未经授权的方式返回
这是我的努力
var url = "https://api.paypal.com/v1/oauth2/token";
var clientId = "myClientId";
var pwrd = "mySecret";
var client = new WebClient();
client.Credentials = new NetworkCredential(clientId, pwrd);
client.Headers.Add("Content-Type", "application/x-www-form-urlencoded");
client.Headers.Add("Accept: application/json");
var result = "";
using (var httpClient = new HttpClient())
{
var response = await httpClient.PostAsync(url, null);
result = response.StatusCode.ToString();
}
return View(model: result);
我不明白为什么,当我从我的实时应用程序中运行它时,它会失败
编辑
我换了
using (var httpClient = new HttpClient())
{
var response = await httpClient.PostAsync(url, null);
result = response.StatusCode.ToString();
}
与
var clientId = "myClientId";
var seceret = "mySecret";
var client = new HttpClient();
client.DefaultRequestHeaders.Authorization = new AuthenticationHeaderValue(
"Basic", Convert.ToBase64String(
System.Text.ASCIIEncoding.ASCII.GetBytes(
$"{clientId}:{seceret}")));
var dict = new Dictionary<string, string>();
dict.Add("Content-Type", "application/x-www-form-urlencoded");
var req = new HttpRequestMessage(HttpMethod.Post, url) { Content = new FormUrlEncodedContent(dict) };
var response = await client.SendAsync(req);
同样的问题仍然存在。我得到一个 401
【问题讨论】:
-
object httpClient 对您的凭据/标头一无所知。请改用客户端。
-
这能回答你的问题吗? Setting Authorization Header of HttpClient
-
不,很遗憾 - 我已经走了那条路,同样的问题仍然存在@MarkusSafar。谢谢你的帮助:)