最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

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

来源:动视网 责编:小采 时间:2020-11-27 22:27:22
文档

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

原生JS实现Ajax跨域请求flask响应内容:Ajax方法好,网站感觉跟高大上,但由于Js的局限,跨域Ajax无法实现,这里,讲一下解决办法,前提是需要能够自己可以控制flask端的响应。 主要技术: 修改服务器相应的相应头,使其可以相应任意域名。and设置响应头,使其能够相应POST方法。 实现代码: 这里
推荐度:
导读原生JS实现Ajax跨域请求flask响应内容:Ajax方法好,网站感觉跟高大上,但由于Js的局限,跨域Ajax无法实现,这里,讲一下解决办法,前提是需要能够自己可以控制flask端的响应。 主要技术: 修改服务器相应的相应头,使其可以相应任意域名。and设置响应头,使其能够相应POST方法。 实现代码: 这里


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,无能为力。目前前后端均我一人编写,暂不考虑虑此情况。

文档

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

原生JS实现Ajax跨域请求flask响应内容:Ajax方法好,网站感觉跟高大上,但由于Js的局限,跨域Ajax无法实现,这里,讲一下解决办法,前提是需要能够自己可以控制flask端的响应。 主要技术: 修改服务器相应的相应头,使其可以相应任意域名。and设置响应头,使其能够相应POST方法。 实现代码: 这里
推荐度:
标签: js 响应 ajax
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top