J'essaie d'obtenir des données à partir de ce lien d'API github https://api.github.com/ utilisateurs / arif2009 . Cela fonctionne très bien avec posman get request.
Mais si j'essaie d'obtenir des données en utilisant .net HttpClient , alors il dit Forbidden
Code C # :
using (var client = new HttpClient()) { client.BaseAddress = new Uri("https://api.github.com/"); client.DefaultRequestHeaders.Accept.Clear(); client.DefaultRequestHeaders.Accept.Add(new MediaTypeWithQualityHeaderValue("application/json")); var response = await client.GetAsync("users/arif2009"); if (response.IsSuccessStatusCode) { var data = response.Content.ReadAsAsync<GithubUser>(); } }
Quelqu'un peut-il me dire où j'ai commis l'erreur?
3 Réponses :
J'ai jeté un coup d'œil à vos demandes en utilisant le Fiddler de Telerik et j'ai trouvé ce qui suit.
Demande avec votre code:
HTTP/1.1 200 OK Date: Wed, 17 Jul 2019 15:19:35 GMT Content-Type: application/json; charset=utf-8 Content-Length: 1249 Server: GitHub.com Status: 200 OK X-RateLimit-Limit: 60 X-RateLimit-Remaining: 52 X-RateLimit-Reset: 1563380375 Cache-Control: public, max-age=60, s-maxage=60 Vary: Accept ETag: "1df3e0be6e824ca684f27963806533da" Last-Modified: Tue, 16 Jul 2019 05:58:59 GMT X-GitHub-Media-Type: github.v3 Access-Control-Expose-Headers: ETag, Link, Location, Retry-After, X-GitHub-OTP, X-RateLimit-Limit, X-RateLimit-Remaining, X-RateLimit-Reset, X-OAuth-Scopes, X-Accepted-OAuth-Scopes, X-Poll-Interval, X-GitHub-Media-Type Access-Control-Allow-Origin: * Strict-Transport-Security: max-age=31536000; includeSubdomains; preload X-Frame-Options: deny X-Content-Type-Options: nosniff X-XSS-Protection: 1; mode=block Referrer-Policy: origin-when-cross-origin, strict-origin-when-cross-origin Content-Security-Policy: default-src 'none' Vary: Accept-Encoding X-GitHub-Request-Id: D5E0:8D63:8BE92C:A799AE:5D2F3C86 {"login":"arif2009","id":6396346,"node_id":"MDQ6VXNlcjYzOTYzNDY=","avatar_url":"https://avatars0.githubusercontent.com/u/6396346?v=4","gravatar_id":"","url":"https://api.github.com/users/arif2009","html_url":"https://github.com/arif2009","followers_url":"https://api.github.com/users/arif2009/followers","following_url":"https://api.github.com/users/arif2009/following{/other_user}","gists_url":"https://api.github.com/users/arif2009/gists{/gist_id}","starred_url":"https://api.github.com/users/arif2009/starred{/owner}{/repo}","subscriptions_url":"https://api.github.com/users/arif2009/subscriptions","organizations_url":"https://api.github.com/users/arif2009/orgs","repos_url":"https://api.github.com/users/arif2009/repos","events_url":"https://api.github.com/users/arif2009/events{/privacy}","received_events_url":"https://api.github.com/users/arif2009/received_events","type":"User","site_admin":false,"name":"Arif","company":"@BrainStation-23 ","blog":"https://arif2009.github.io/","location":"Bangladesh","email":null,"hireable":true,"bio":"Software Engineer | Full Stack | Web Developer | Technical Writer","public_repos":15,"public_gists":2,"followers":9,"following":7,"created_at":"2014-01-14T05:03:47Z","updated_at":"2019-07-16T05:58:59Z"}
Demande du facteur:
XXX
L'en-tête manquant évident semblait être "User-Agent", j'ai donc ajouté ceci:
GET https://api.github.com/users/arif2009 HTTP/1.1 Accept: application/json User-Agent: product/1 Host: api.github.com
Ce qui a produit la requête suivante:
client.DefaultRequestHeaders.UserAgent.Add(new ProductInfoHeaderValue("product", "1")); // set your own values here
Et a renvoyé la réponse suivante:
GET https://api.github.com/users/arif2009 HTTP/1.1 Host: api.github.com Connection: keep-alive Accept: application/json Cache-Control: no-cache User-Agent: Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/75.0.3770.142 Safari/537.36 Postman-Token: d560ee28-b1e8-ece5-2612-87371ddcb295 Accept-Encoding: gzip, deflate, br Accept-Language: en-GB,en;q=0.9,ja-JP;q=0.8,ja;q=0.7,en-US;q=0.6
Vous pouvez essayer de mettre l'URI complet dans GetAsync
à la place en utilisant BaseAddress
, car vous ne donnez pas d'URI à GetAsync
, mais seulement une chaîne.
Lors de l'envoi d'un HttpRequestMessage avec un Uri relatif, le message Uri sera ajouté à la propriété BaseAddress pour créer un Uri absolu.
cette référence de l'API de github indique que "User-Agent" est un en-tête obligatoire:
Toutes les demandes d'API DOIVENT inclure un en-tête User-Agent valide. Les demandes sans en-tête User-Agent seront rejetées.
Postman ajoute automatiquement son propre User-Agent à l'appel lorsque celui-ci n'est pas fourni par l'utilisateur. (Ceci est bien démontré par la réponse de @ John).
Le simple fait d'ajouter cet en-tête résoudra votre problème:
client.DefaultRequestHeaders.UserAgent.Add(new ProductInfoHeaderValue("yourAppName", "yourVersionNumber"));