我正在使用Discogs API开发Aurelia.io的应用程序。嗯,这是Javascript,对于那些可能不了解Aurelia的人(我不知道它是否有名)。
我正在写这个(当然xxx是真正的价值):
import {HttpClient} from 'aurelia-http-client';
let client = new HttpClient()
.configure(x => {
x.withHeader('User-Agent', 'myApp/0.1'),
x.withHeader('Authorization', 'Discogs key=xxxxx, secret=xxxxx'),
x.withHeader('Access-Control-Allow-Origin', '*')
});
client.get('https://api.discogs.com/releases/'+value.discogsReference)
.then(data => {
console.log(data.tracklist[value.releasePosition]);
});
实际上,我的要求不起作用。 以下是Firefox发送的标题,而我想发送其他的标题,如我在代码中所见:
Host: api.discogs.com
User-Agent: Mozilla/5.0 (X11; Ubuntu; Linux x86_64; rv:52.0) Gecko/20100101 Firefox/52.0
Accept: text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8
Accept-Language: en-US,en;q=0.5
Accept-Encoding: gzip, deflate, br
Access-Control-Request-Method: GET
Access-Control-Request-Headers: access-control-allow-origin,authorization,user-agent
Origin: http://localhost:9000
Connection: keep-alive
显然,我想强制使用的标题不会被考虑在内。
以下是我在控制台中收到的法语消息(我在网上找不到翻译):
Blocage d’une requête multiorigines (Cross-Origin Request) : la politique « Same Origin » ne permet pas de consulter la ressource distante située sur https://api.discogs.com/releases/2275022. Raison : jeton « access-control-allow-origin » manquant dans l’en-tête CORS « Access-Control-Allow-Headers » du canal de pré-vérification des requêtes CORS.
我做错了什么? 感谢
塞萨尔
答案 0 :(得分:0)
试试这个。
let client = new HttpClient()
.configure(x => {
x.withInterceptor({
request(request) {
request.headers.append('User-Agent', 'myApp/0.1');
request.headers.append('Authorization', 'Discogs key=xxxxx, secret=xxxxx');
request.headers.append('Access-Control-Allow-Origin', '*');
}
}
});
答案 1 :(得分:0)
好的我用错误的方法处理了问题。 实际上我不可能像我一样联系Discogs API。您必须使用访问Discogs API的Web服务。 所以,我使用libcurl(https://www.npmjs.com/package/node-libcurl)创建了一个自定义本地节点webservice。我的aurelia称之为web服务,libcurl允许我使用适当的头文件调用Discogs API。 Phew,我做到了,但我遇到了其他问题,我将在stackoverflow上发布...