条带订阅 checkout.session.completed 资源缺少 invalid_request_error 类型的错误

时间:2021-04-28 02:50:50

标签: python django stripe-payments stripe-subscriptions dj-stripe

我试图了解为什么 checkout.session.completed 的 webhook 在使用 Stripe CLI 本地测试时崩溃。我正在使用 djstripe。我的 customer.subscription.created 网络钩子成功了。使用 CLI 时,stripe trigger checkout.session.completed 命令出现以下错误:

Request failed, status=404, body={
  "error": {
    "code": "resource_missing",
    "doc_url": "https://stripe.com/docs/error-codes/resource-missing",
    "message": "No such payment_page: 'ppage_1Il33eAyVjQjzOsRERzYQSbK'",
    "param": "payment_page",
    "type": "invalid_request_error"
  }

是success url路由的问题吗? views.py

def create_checkout_session(request):
    """Create a checkout session for Stripe."""
    data = json.loads(request.body)
    priceId = data.get("priceId")
    if not Price.objects.filter(id=priceId).exists():
        messages.add_message(request, messages.ERROR,
                             "That plan price is not available. Please contact support for help.", )
        return HttpResponseRedirect(reverse("users:index"))
    request.account = OrgMembership.objects.filter(my_identity=request.user).first()
    sessionId = stripegateway.create_checkout_session(priceId, request)
    return JsonResponse({"sessionId": sessionId})

stripegateway.py

class StripeGateway:
    """Gateway interacts with the APIs required by Stripe. Credit: Matt Layman"""
    def create_checkout_session(self, priceId, request):
        """Create a checkout session based on the subscription price."""
        site = Site.objects.get_current()
        subscription_success = reverse("users:success")
        stripe_cancel = reverse("users:stripe_cancel")
        request.account = OrgMembership.objects.get(my_identity=request.user.id)
        request.org = request.account.my_org
        # session_parameters = {
        #     "customer_email": request.org.billing_email,
        #     "success_url": f"http://{site}{subscription_success}",
        #     "cancel_url": f"https://{site}{stripe_cancel}",
        #     "payment_method_types": ["card"],
        #     "mode": "subscription",
        #     "line_items": [{"price": priceId, "quantity": 1}],
        #     "client_reference_id": str(request.account.id),
        # }
        # checkout_session = stripe.checkout.Session.create(**session_parameters)
        # return checkout_session["id"]
        checkout_session = stripe.checkout.Session.create(
            customer_email = request.org.billing_email,
            client_reference_id = str(request.account.id),
            payment_method_types=['card'],
            line_items=[{
                'price': priceId,
                'quantity': 1,
            }],
            mode='subscription',
            success_url=request.build_absolute_uri(reverse('users:success')) + '?session_id={CHECKOUT_SESSION_ID}',
            cancel_url=request.build_absolute_uri(reverse('users:index')),
        )
        return checkout_session["id"]

注释掉的部分是使用的原始代码,然后尝试替代以尝试解决问题。非常感谢任何指导。

2 个答案:

答案 0 :(得分:1)

我遇到了同样的问题。 stripe trigger checkout.session.completed 将返回以下内容:

Trigger failed: Request failed, status=404, body={
  "error": {
    "code": "resource_missing",
    "doc_url": "https://stripe.com/docs/error-codes/resource-missing",
    "message": "No such payment_page: 'ppage_1IryQdFE8p8XoGx4OJLXOv4p'",
    "param": "payment_page",
    "type": "invalid_request_error"
  }
}

我通过将我的条带 CLI 版本从 v1.5.4 更新到 v1.5.14 修复了错误。

答案 1 :(得分:1)

确保将 webhook 事件转发到正确且有效的端点。

使用 forward-to 命令行参数将 stripe-cli 指向您的开发服务器:

stripe listen \
--skip-verify \
--forward-to https://localhost:8000/payments/webhook/ \
--log-level debug

使用 HTTPS 端点时,自签名证书或其他无效证书需要 skip-verify。 Django 对 URL 末尾的斜线也很挑剔。