ホームページ >ウェブフロントエンド >jsチュートリアル >JS は Ajax クロスドメイン要求フラスコ応答コンテンツを実装します
Ajax 方式は優れており、Web サイトは高級感があります。ただし、Js の制限により、クロスドメイン Ajax は実装できません。ここでは、制御できる必要があるという前提で説明します。フラスコ側の反応。この記事では、主に Ajax のクロスドメイン リクエスト フラスコの応答コンテンツの JS 実装について詳しく紹介します。興味のある方は参考にしていただければ幸いです。
主な技術:
サーバーの対応するヘッダーを変更して、任意のドメイン名に対応できるようにします。そしてPOSTメソッドに対応できるようにレスポンスヘッダを設定します。
実装コード:
最初にフラスココードをここに置きます:
from flask import make_response @app.route('/test',methods=['get','post']) def Test(): if request.method=='GET': rst = make_response('aaa') rst.headers['Access-Control-Allow-Origin'] = '*' #任意域名 return rst else: rst = make_response('bbb') rst.headers['Access-Control-Allow-Origin'] = '*' rst.headers['Access-Control-Allow-Methods'] = 'POST' #响应POST return rst
html テストコード:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Title</title> </head> <body> <span id="ss">test get</span> <button onclick="getAjax()">click</button> <p id="time">test post</p> <input type="submit" value="click" onclick="getPostAjax()"> <script> function getPostAjax() { var xmlhttp = new XMLHttpRequest(); xmlhttp.onreadystatechange=function () { if(xmlhttp.readyState=4 && xmlhttp.status ==200 ) { document.getElementById("time").innerText = xmlhttp.responseText; } } xmlhttp.open("POST","http://localhost:5000/test",true); xmlhttp.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); #这句话可以发送post数据,没有此句post的内容无法传递 xmlhttp.send(); } function getAjax() { var xmlhttp = new XMLHttpRequest(); xmlhttp.onreadystatechange=function () { if(xmlhttp.readyState==4 && xmlhttp.status == 200){ document.getElementById("ss").innerHTML=xmlhttp.responseText; } } xmlhttp.open("GET","http://localhost:5000/test",true); xmlhttp.send(); } </script> </body> </html>
応答ヘッダーを制御できません
この状況では、get リクエストは jquery を使用して完了できます、ポスト、何もできません。
もう学びましたか?急いで試してみてください。
関連する推奨事項:
COOKIE では実現できない Ajax クロスドメイン リクエストの完璧なソリューション
AJAX クロスドメイン リクエストの 4 つの方法を説明する例データ
以上がJS は Ajax クロスドメイン要求フラスコ応答コンテンツを実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。