我正在尝试将Stripe与Flask集成,但是页面加载后会出现以下错误。
The browser (or proxy) sent a request that this server could not understand.
为什么会出现此错误,我该如何解决?
@store.route('/payment',methods=['GET', 'POST'])
def payment():
stripe.api_key = "test_key"
token = request.form['stripeToken']
try:
charge = stripe.Charge.create(
amount=1000,
currency="cad",
source=token,
description="Example charge"
)
except stripe.error.CardError, e:
pass
return render_template("payment_form.html")
<script type="text/javascript" src="https://js.stripe.com/v2/"></script>
<script type="text/javascript">
Stripe.setPublishableKey('test_key');
jQuery(function($) {
$('#payment-form').submit(function(event) {
var $form = $(this);
$form.find('button').prop('disabled', true);
Stripe.card.createToken($form, stripeResponseHandler);
return false;
});
});
function stripeResponseHandler(status, response) {
var $form = $('#payment-form');
if (response.error) {
$form.find('.payment-errors').text(response.error.message);
$form.find('button').prop('disabled', false);
} else {
var token = response.id;
$form.append($('<input type="hidden" name="stripeToken" />').val(token));
$form.get(0).submit();
}
};
</script>
页面加载后立即失败的原因是因为加载页面是一个GET
请求。request.form
会根据POST
要求填写,只有在您提交表格时才会出现。request.form
是一种特殊的字典,它引发400错误而不是KeyError
。
仅在POST
请求期间处理表单数据。还请记住,之后进行重定向,POST
以使浏览器不会停留在过时的表单数据上。
from flask import request, redirect, flash, render_template
stripe.api_key = 'test_key'
@store.route('/payment', methods=['GET', 'POST'])
def payment():
if request.method == 'POST':
token = request.form['stripeToken']
try:
charge = stripe.Charge.create(amount=1000, currency="cad", source=token, description="Example charge")
return redirect(request.path)
except stripe.error.CardError, e:
flash('Error processing payment.', 'error')
return render_template('payment_form.html')
如果在开发期间启用调试模式,您会发现调试应用错误会容易得多:app.run('localhost', debug=True)
。当出现应用错误时,这将在浏览器中为您提供交互式回溯调试器。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句