J'essaie d'envoyer des données à Google Cloud Functions à partir d'une application ionique mais j'obtiens toujours l'erreur suivante :
L'accès à XMLHttpRequest sur 'https://xxxxxxxxxxxxxxx.cloudfunctions.net/upload_data' depuis l'origine 'http://localhost:8100' a été bloqué par la politique CORS : l'accès interdit le type de contenu du champ d'en-tête de demande - dans la réponse de contrôle en amont Contrôle- Autoriser les en-têtes.
La même erreur s'affiche même si l'en-tête de la requête est supprimé. Toute aide serait grandement appréciée, merci.
Mon code dactylographié :
var httpheader = new HttpHeaders(); httpheader.append('Accept','application/json'); httpheader.append('Content-Type','application/json'); let data = {"testbody":"this is test data"}; await this.http.post('https://xxxxxxxxxxxxxxxx.cloudfunctions.net/upload_data',data ,{headers:httpheader}).subscribe((resp)=>{ console.log(resp); });
Fonction cloud python :
def hello_world(request): """Responds to any HTTP request. Args: request (flask.Request): HTTP request object. Returns: The response text or any set of values that can be turned into a Response object using `make_response <http://flask.pocoo.org/docs/1.0/api/#flask.Flask.make_response>`. """ if request.method == 'OPTIONS': headers={'Access-Control-Allow-Origin':'*', 'Access-Control-Allow-Methods':'GET', 'Access-Control-Allow-Headrs':'Content-Type', 'Access-Control-Max-Age':'3600' } return ('',204,headers) headers={'Access-Control-Allow-Origin':'*'} request_json = request.get_json(silent=True) request_args = request.args if request_json and 'testbody' in request_json: testname = request_json['testbody'] elif request_args and 'testbody' in request_args: testname = request_args['testbody'] else: testname = 'Nothing sent' return (jsonify(testname),200,headers)
CORS
相关配置需要在服务器端
代码中完成。从您的问题中,我看到您在Python
中使用Flask
框架。所以需要在Flask中配置CORS
est la suivante :Installez flask-cors en exécutant -
Considérez l'exemple de code de point de terminaison suivant :
Mise à jour
Dans
Production
环境中,请禁止禁止
使用Access-Control-Allow-Origin':'*'
。相反,您应该whitelist
votre nom de domaine. En savoir plus à ce sujet ici et ici.De plus, si vous utilisez
réseauIonic with Capacitor
, je vous recommande d'utiliser le plugin HTTPIonic 与 Capacitor
一起使用,我建议使用 Http 插件。如果可能,您还可以编写自己的自定义插件
来使用底层操作系统平台特定的
API 实现网络调用natively
. Si possible, vous pouvez également écrire votre propreplugin personnalisé
pour utiliser l'implémentation de l'APIspécifique à la plate-forme
du système d'exploitation sous-jacentappelle
nativement
car ceci empêche tout problème lié à CORS de se produire.Lien de référence :
Configuration du flacon CORS