从反应到烧瓶的发布请求

如何解决从反应到烧瓶的发布请求

我正在尝试使用以下代码将 post 请求从 react 发送到flask:

function App() {

  const [currentTime,setCurrentTime] = useState(0);
  const [accesstoken,setAccesstoken] = useState(null);
  const clicked = 'clicked';
  

  useEffect(() => {
    fetch('/time').then(res => res.json()).then(data => {
      setCurrentTime(data.time);
    });
  },[]);


  useEffect(() => {
    // POST request using fetch inside useEffect React hook
    const requestOptions = {
        method: 'POST',headers: { 'Content-Type': 'application/json' },body: JSON.stringify({ title: 'React Hooks POST Request Example',action: 'clicked' })
    };
    var myParams = {
      data: requestOptions
    }
    fetch('http://127.0.0.1:5000/login',myParams)
        .then(response => response.json())
        .then(data => setAccesstoken(data.access_token));

// empty dependency array means this effect will only run once (like componentDidMount in classes)
},[]);




  return (
    <div className="App">
      <div className="leftPane">
      
      <div className="joyStick"   >
        <Joystick  size={300} baseColor="gray" stickColor="black" ></Joystick>

        </div>
        <p>The current time is {currentTime}.</p>
        <p>The access token is {accesstoken}.</p>


      
      </div>

烧瓶代码

  from __future__ import print_function
from flask import Flask,jsonify,request
from flask_cors import CORS

import time
from flask import Flask
import sys


robotIP="10.7.4.109"
PORT=9559
app = Flask(__name__)

access_token='a'
action="d"


@app.route('/time')
def get_current_time():
    
    return {'time': time.time()}
    

@app.route('/login',methods=['POST'])
def nao():
    nao_json = request.get_json()



if not nao_json:
    return jsonify({'msg': 'Missing JSON'}),400

action = nao_json.get('action')
access_token= action+'s'

print(access_token,file=sys.stderr)


return jsonify({'access_token': access_token}),200

但是每次我同时运行它们时,我都会收到 'msg': 'Missing JSON' 消息我已经定义,并且来自 react 的数据在烧瓶中永远不可用,即使 get 请求有效。我不确定是什么我在这里做错了。

解决方法

问题实际上是服务器必须允许的跨域请求。

将此函数放在您的 Python 代码中:

@app.after_request
def set_headers(response):
    response.headers["Access-Control-Allow-Origin"] = "*"
    response.headers["Access-Control-Allow-Headers"] = "*"
    response.headers["Access-Control-Allow-Methods"] = "*"
    return response

注意:

  • 如果 react 是从同一台服务器提供的,则没有必要。

  • 您应该将这些标头的值设置为在生产中尽可能严格。上面的例子太宽容了。


您可以从 Flask 提供您的 React 应用程序,因此不需要设置这些标头。你可以使用这样的东西来提供主要的反应文件:

@app.route('/',defaults={'path': ''})
@app.route('/<string:path>')
@app.route('/<path:path>')
def index(path: str):
    current_app.logger.debug(path)
    return bp_main.send_static_file('path/to/dist/index.html')

path/to/dist/index.html 在静态文件夹中的位置。

查看更多信息:

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?