您好,欢迎访问一九零五行业门户网

JS实现Ajax跨域请求flask响应内容

ajax方法好,网站感觉跟高大上,但由于js的局限,跨域ajax无法实现,这里,讲一下解决办法,前提是需要能够自己可以控制flask端的响应。本文主要为大家详细介绍了js实现ajax跨域请求flask响应内容,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能帮助到大家。
主要技术:
修改服务器相应的相应头,使其可以相应任意域名。and设置响应头,使其能够相应post方法。
实现代码:
这里先放flask代码:
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完成,post,无能为力。
大家学会了吗?赶紧动手尝试一下吧。
相关推荐:
ajax跨域请求cookie无法带上的完美解决办法
实例详解ajax跨域请求的原理
实例讲解ajax跨域请求数据的四种方法
以上就是js实现ajax跨域请求flask响应内容的详细内容。
其它类似信息

推荐信息