Joe*_*ley 3 python flask python-requests zapier hasura
我正在尝试以包含JSON的POST请求的形式将触发器发送到Zapier Webhook。如果我只是通过本地python脚本发送POST请求,则效果很好。
我想做的是创建一个RESTful API,当调用create-row-in-gs端点时,该触发器将触发Zapier Webhook。
如您所见,我正在向Hasura集群发送POST请求API调用。但是,我得到的不是“ 200 OK成功”,而不是“ 200 OK成功”,这意味着该请求被视为GET请求而不是POST请求。
test.py
#Python 3 Script to send a POST request containing JSON
import json
import requests
api_url = 'http://app.catercorner16.hasura-app.io/create-row-in-gs'
create_row_data = {'id': '1235','name':'Joel','created-on':'27/01/2018','modified-on':'27/01/2018','desc':'This is Joel!!'}
r = requests.post(url=api_url, data=create_row_data)
print(r.status_code, r.reason, r.text)
Run Code Online (Sandbox Code Playgroud)
server.py(在Hasura群集上运行)
from src import app
from flask import jsonify,request,make_response,url_for,redirect
from json import dumps
from requests import post
url = 'https://hooks.zapier.com/hooks/catch/xxxxx/yyyyy/'
@app.route('/create-row-in-gs', methods=['GET','POST'])
def create_row_in_gs():
if request.method == 'GET':
return make_response('failure')
if request.method == 'POST':
t_id = request.json['id']
t_name = request.json['name']
created_on = request.json['created_on']
modified_on = request.json['modified_on']
desc = request.json['desc']
create_row_data = {'id': str(t_id),'name':str(t_name),'created-on':str(created_on),'modified-on':str(modified_on),'desc':str(desc)}
response = requests.post(
url, data=json.dumps(create_row_data),
headers={'Content-Type': 'application/json'}
)
return response
Run Code Online (Sandbox Code Playgroud)
已经为此努力了数周。我究竟做错了什么?将不胜感激。
好的,我检查了本地脚本,发现了两个问题。两者都在您的客户端脚本中。
1)r = requests.post(url=api_url, data=create_row_data)应该r = requests.post(url=api_url, json=create_row_data)
2)您在Flask应用中寻找created_on和modified_on,但发送created-on和modified-on。
下面的工作本地代码:
客户:
import json
import requests
api_url = 'http://localhost:5000/create-row-in-gs'
create_row_data = {'id': '1235','name':'Joel','created_on':'27/01/2018','modified_on':'27/01/2018','desc':'This is Joel!!'}
print(create_row_data)
r = requests.post(url=api_url, json=create_row_data)
print(r.status_code, r.reason, r.text)
Run Code Online (Sandbox Code Playgroud)
服务器:
from flask import Flask,jsonify,request,make_response,url_for,redirect
import requests, json
app = Flask(__name__)
url = 'https://hooks.zapier.com/hooks/catch/xxxxx/yyyyy/'
@app.route('/create-row-in-gs', methods=['GET','POST'])
def create_row_in_gs():
if request.method == 'GET':
return make_response('failure')
if request.method == 'POST':
t_id = request.json['id']
t_name = request.json['name']
created_on = request.json['created_on']
modified_on = request.json['modified_on']
desc = request.json['desc']
create_row_data = {'id': str(t_id),'name':str(t_name),'created-on':str(created_on),'modified-on':str(modified_on),'desc':str(desc)}
response = requests.post(
url, data=json.dumps(create_row_data),
headers={'Content-Type': 'application/json'}
)
return response.content
if __name__ == '__main__':
app.run(host='localhost',debug=False, use_reloader=True)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
14346 次 |
| 最近记录: |