Python Flask应用程序获取OPTIONS而不是POST

时间:2015-05-20 03:11:15

标签: python json flask

我有一个python Flask监听器在端口8080上等待。我希望另一个进程对该端口进行一系列POST。监听器的代码如下。

#!/usr/bin/env python2
from __future__ import print_function
from flask import Flask, request
from werkzeug import secure_filename
from datetime import datetime
import os, traceback, sys 
import zlib
import ssl 
import json
import os
import base64

app = Flask('__name__')

@app.route('/',methods=['GET','POST','OPTIONS'])                                                                                                                                         
def recive_fe_events():
    try:
        data = request.get_data()

        if request.content_length < 20000 and request.content_length != 0:
            filename = 'out/{0}.json'.format(str(datetime.now()))
            with open(filename, 'w') as f:
                 f.write(data)

            print('Wrote', filename)
        else:
            print("Request too long", request.content_length)
            content = '{{"status": 413, "content_length": {0}, "content": "{1}"}}'.format(request.content_length, data)
            return content, 413 
    except:
        traceback.print_exc()
        return None, status.HTTP_500_INTERNAL_SERVER_ERROR

    return '{"status": 200}\n'

if __name__ == '__main__':
    app.run(host='0.0.0.0',debug=False,port=8080)

但是每当我尝试触发一个事件被推送到上面的监听器时。我似乎得到OPTIONS而不是POST

192.168.129.75 - - [20/May/2015 14:33:45] "OPTIONS / HTTP/1.1" 200 -
192.168.129.75 - - [20/May/2015 14:33:45] "OPTIONS / HTTP/1.1" 200 -
192.168.129.75 - - [20/May/2015 14:33:51] "OPTIONS / HTTP/1.1" 200 -
192.168.129.75 - - [20/May/2015 14:33:51] "OPTIONS / HTTP/1.1" 200 -

我在烧瓶文件中读到了。 (从Flask 0.6开始,OPTIONS被标准请求处理隐式添加和处理。)

为什么我在预期OPTIONS时会看到POST。似乎POST似乎因某种原因而丢失。我在POST发生时使用了tcpdump并捕获了流量使用wireshark进行分析。迹线的相关部分附在此处。 Wireshark decode output

在我看来,尝试执行POST的来源是使用SSL加密数据。我的理解是否正确?

1 个答案:

答案 0 :(得分:1)

除非您明确处理OPTOINS方法,否则请不要将其放入您的方法中。

请改为尝试:

@app.route('/',methods=['GET','POST'])