我试图按照这里的说明https://stripe.com/docs/payments/accept-a-payment?integration=checkout在node中集成Stripe结账(Checkout)功能。
我完全按照他们的说明进行操作,并将示例中的API密钥更新为我的帐户中的实际(测试)密钥。
我在前端使用React,在后端使用express,并启用了cors。
来自React到后端的请求成功,并触发了一个预检请求(preflight request)到Stripe。 Stripe的预检响应是403,实际请求因CORS错误被阻止 -PreflightMissingAllowOriginHeader
后端代码(最小化)
const express = require("express");
const app = express();
const cors = require("cors");
const stripe = require("stripe")(
process.env.STRIPE_SECRET_KEY
);
app.use(
cors({
origin: ["http://localhost:8000", "https://checkout.stripe.com"],
})
);
app.post("/create-checkout-session", async (req, res) => {
console.log('getting here 1')
const session = await stripe.checkout.sessions.create({
payment_method_types: ["card"],
line_items: [
{
price_data: {
currency: "usd",
product_data: {
name: "T-shirt",
},
unit_amount: 2000,
},
quantity: 1,
},
],
mode: "payment",
success_url: "http://localhost:4242/success.html",
cancel_url: "http://localhost:4242/cancel.html",
});
console.log('getting here 2')
res.redirect(303, session.url);
});
app.listen(4242, () => console.log(`Listening on port ${4242}!`));
前端代码
handleClick = () => {
const res = fetch(`${process.env.BACKEND_API_URL}/create-checkout-session`, {
method: 'POST',
headers: {
"Content-Type": 'text/html'
}
})
}
fetch
执行Ajax POST调用。在POST请求中,res.redirect
不起作用。相反,你有两个选择:选项1:在/create-checkout-session
中返回JSON,在获取结果后,在前端重定向;选项2:执行一个“表单提交POST”,而不是使用fetch
。 - wsw