我正在尝试制作一个可以让我从discogs查询数据库的应用。
根据Api documentation,我可以仅凭一个令牌就可以做到这一点。 所以我注册并获得了用户令牌。
现在当我将邮递员与https://api.discogs.com/database/search?release_title=nevermind&artist=nirvana&per_page=3&page=1&token=<my_user_token>
一起使用时
我收到了我期望的json。
但是当我用令牌在c#中创建一个httpclient
public string token = <my_user_token>;
public static HttpClient client { get; set; }
public static async Task InitilizeClient()
{
await GetAccesToken();
}
private static async Task GetAccesToken()
{
client = new HttpClient();
client.DefaultRequestHeaders.Accept.Clear();
client.BaseAddress = new Uri(@"https://api.discogs.com");
//client.DefaultRequestHeaders.Authorization=new AuthenticationHeaderValue("Discogs", "token="+token);
client.DefaultRequestHeaders.TryAddWithoutValidation("Authorization","Discogs token=" + token);
client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json"));
}
然后像这样使用客户端
public static async Task QueryDataBaseAsync(string query)
{
if (query == null)
{
throw new Exception("query is empty");
}
string url = "";
url = @"https://api.discogs.com/database/search?release_title="+query;
if (client == null)
{
await InitilizeClient();
}
using (HttpResponseMessage response = await client.GetAsync(url))
{
if (response.IsSuccessStatusCode)
{
}
else
{
throw new Exception(response.ReasonPhrase + " \n" + response.RequestMessage.ToString());
}
}
}
那我总是得到一个ReasonPhrase“ forbidden”,“状态码:403”
当我在HttpResponseMessage response
上设置一个断点时,我可以看到在“ headers” =>“ responsemessage” =>“ headers” =>“ authorization”下有我的令牌。
我在做什么错了?
ps,抱歉英语不好,不是我的母语
ps2,我是编程新手,所以如果您能消除我做错的事情,我将不胜感激
答案 0 :(得分:1)
您可能需要在标题中提供用户代理。遵循以下原则:
client.DefaultRequestHeaders.Add("User-Agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.120 Safari/537.36");
像这样:
public class DiscConsumer
{
//https://www.discogs.com/developers#page:authentication,header:authentication-discogs-auth-flow
//curl "https://api.discogs.com/database/search?q=Nirvana" -H "Authorization: Discogs key=foo123, secret=bar456"
private const string _urlQuery = "https://api.discogs.com/database/search?q={query}";
private const string _key = "<....your key....>";
private const string _secret = "<....your secret...>";
private System.Net.Http.HttpClient _httpClient;
public async Task InitilizeClient()
{
//ServicePointManager.SecurityProtocol = SecurityProtocolType.Ssl3 | SecurityProtocolType.Tls | SecurityProtocolType.Tls11 | SecurityProtocolType.Tls12;
var sslhandler = new HttpClientHandler()
{
//...in System.Security.Authentication.SslProtocols
SslProtocols = SslProtocols.Tls12 | SslProtocols.Tls11 | SslProtocols.Tls
};
_httpClient = new System.Net.Http.HttpClient(sslhandler);
string authorization = $"Discogs key={_key}, secret={_secret}";
_httpClient.DefaultRequestHeaders.Add("Authorization", authorization);
_httpClient.DefaultRequestHeaders.Add("User-Agent", "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/77.0.3865.120 Safari/537.36");
}
public async Task QueryDataBaseAsync(string query)
{
if (String.IsNullOrWhiteSpace( query ))
{
throw new Exception("query is empty");
}
string url = "";
url = _urlQuery.Replace("{query}", query);
if (_httpClient == null)
{
await InitilizeClient();
}
using (HttpResponseMessage response = await _httpClient.GetAsync(url))
{
if (response.IsSuccessStatusCode)
{
string s = await response.Content.ReadAsStringAsync();
Console.WriteLine(s);
}
else
{
throw new Exception(response.ReasonPhrase + " \n" + response.RequestMessage.ToString());
}
}
}
}
对于每个https://www.discogs.com/developers#page:authentication,header:authentication-discogs-auth-flow,您可以在每个请求以及搜索中提供密钥和秘密。