我正在尝试将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>
答案 0 :(得分:2)
页面加载后失败的原因是因为加载页面是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)
,您会发现调试应用程序错误要容易得多。当发生应用程序错误时,这将为您提供交互式回溯调试程序。
答案 1 :(得分:0)
您想要request.form.get('stripeToken', None)