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

Ajax大法好,网站感觉跟高大上,但由于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,无能为力。目前前后端均我一人编写,暂不考虑虑此情况。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值