0

0

在 Angular 14 中集成 Stripe 实现自定义支付流程

霞舞

霞舞

发布时间:2025-08-16 20:42:14

|

263人浏览过

|

来源于php中文网

原创

在 angular 14 中集成 stripe 实现自定义支付流程

本文旨在指导开发者如何在 Angular 14 项目中集成 Stripe,实现自定义的支付流程,避免使用 stripe-ngx 库的默认弹窗设计。我们将探讨如何在 Angular 组件中捕获支付成功事件,无需重定向到新的 URL,并解决使用 Stripe JS Checkout 过程中可能遇到的 clientSecret 缺失问题。

集成 Stripe 到 Angular 14 项目

在 Angular 14 项目中集成 Stripe,你可以直接使用 Stripe 提供的 JavaScript 库,以便更灵活地控制支付流程。以下步骤将引导你完成集成:

  1. 安装 Stripe JavaScript 库:

    首先,通过 npm 或 yarn 安装 Stripe JavaScript 库:

    npm install @stripe/stripe-js

    或者

    yarn add @stripe/stripe-js
  2. 在 Angular 组件中引入 Stripe:

    在需要使用 Stripe 的 Angular 组件中,引入 Stripe JavaScript 库。你需要使用你的 Stripe 公钥初始化 Stripe 实例。

    import { Component, OnInit } from '@angular/core';
    import { loadStripe, Stripe } from '@stripe/stripe-js';
    
    @Component({
      selector: 'app-payment',
      templateUrl: './payment.component.html',
      styleUrls: ['./payment.component.css']
    })
    export class PaymentComponent implements OnInit {
      stripe: Stripe | null = null;
      emailAddress: string = ''; // 假设你从用户那里获取了邮箱地址
    
      async ngOnInit() {
        this.stripe = await loadStripe('YOUR_STRIPE_PUBLIC_KEY'); // 替换为你的 Stripe 公钥
      }
    
      // ... 其他代码
    }
  3. 创建 Payment Element:

    Payment Element 是 Stripe 提供的一个 UI 组件,可以处理各种支付方式。你需要在 HTML 模板中创建一个容器来渲染 Payment Element。

    <div id="payment-element">
      <!-- Payment Element 将会渲染在这里 -->
    </div>
  4. 初始化 Payment Element:

    在组件中初始化 Payment Element。确保在 ngOnInit 或适当的生命周期钩子中执行此操作,并在 Stripe 加载完成后进行。

    OmniAudio
    OmniAudio

    OmniAudio 是一款通过 AI 支持将网页、Word 文档、Gmail 内容、文本片段、视频音频文件都转换为音频播客,并生成可在常见 Podcast ap

    下载
    import { AfterViewInit, ElementRef, ViewChild } from '@angular/core';
    
    // ...
    
    @ViewChild('paymentElement') paymentElement: ElementRef;
    
    async ngAfterViewInit() {
        if (!this.stripe) {
            return;
        }
    
        const elements = this.stripe.elements({
            clientSecret: 'YOUR_CLIENT_SECRET', // 替换为你的 Client Secret
        });
    
        const paymentElement = elements.create('payment');
        paymentElement.mount(this.paymentElement.nativeElement);
    }

    请确保替换 YOUR_STRIPE_PUBLIC_KEY 和 YOUR_CLIENT_SECRET 为你实际的 Stripe 公钥和 Client Secret。Client Secret 通常在服务器端创建 Payment Intent 时生成。

  5. 处理支付:

    当用户提交支付信息后,你需要调用 stripe.confirmPayment 方法来确认支付。

    async handleSubmit(event: any) {
      event.preventDefault();
    
      if (!this.stripe) {
        return;
      }
    
      const elements = this.stripe.elements();
    
      const { error } = await this.stripe.confirmPayment({
        elements,
        confirmParams: {
          receipt_email: this.emailAddress,
        },
        redirect: "if_required" // 根据需要设置 redirect 选项
      });
    
      if (error && (error.type === "card_error" || error.type === "validation_error")) {
        this.showMessage(error.message);
      } else if (error) {
        this.showMessage("An unexpected error occurred.");
      } else {
          // 支付成功,处理后续逻辑
          this.showMessage("Payment succeeded!");
      }
    }
    
    showMessage(message: string) {
        // 显示消息,例如使用 Angular Material 的 Snackbar
        console.log(message);
    }

    在这个例子中,redirect: "if_required" 选项告诉 Stripe 在需要时才进行重定向,例如需要进行 3D Secure 认证时。

捕获支付成功事件

要捕获支付成功事件,你需要在 confirmPayment 方法的回调函数中处理。如果 error 为 null,则表示支付成功。你可以在回调函数中执行后续操作,例如更新订单状态、发送邮件等。

解决 "clientSecret" 缺失问题

如果在调用 stripe.confirmPayment 时遇到 "clientSecret" 缺失的错误,请确保以下几点:

  1. Client Secret 的正确传递: 确保你正确地从服务器端获取了 Client Secret,并将其传递给了 Angular 组件。
  2. Payment Intent 的创建: 确保在服务器端正确创建了 Payment Intent,并且 Client Secret 是从该 Payment Intent 中获取的。
  3. Stripe Elements 的初始化: 确保在调用 stripe.confirmPayment 之前,正确地初始化了 Stripe Elements,并将 Client Secret 传递给了 stripe.elements 方法。

示例代码 (服务器端 - Node.js):

const stripe = require('stripe')('YOUR_STRIPE_SECRET_KEY'); // 替换为你的 Stripe Secret Key

exports.createPaymentIntent = async (req, res) => {
  try {
    const paymentIntent = await stripe.paymentIntents.create({
      amount: 1099, // 支付金额,以分为单位
      currency: 'usd',
      automatic_payment_methods: {
        enabled: true,
      },
    });

    res.json({ clientSecret: paymentIntent.client_secret });
  } catch (e) {
    return res.status(400).send({
      error: {
        message: e.message,
      },
    });
  }
};

注意事项:

  • 永远不要在客户端存储或处理 Stripe Secret Key。
  • 确保你的服务器端代码安全可靠,以防止未经授权的访问。
  • 在生产环境中,使用 HTTPS 协议来保护支付信息的安全。
  • 仔细阅读 Stripe 官方文档,了解更多关于集成 Stripe 的信息。

总结

通过以上步骤,你可以在 Angular 14 项目中成功集成 Stripe,实现自定义的支付流程。记住,安全是至关重要的,请务必遵循 Stripe 的最佳实践,并采取适当的安全措施来保护用户的支付信息。通过自定义支付流程,你可以更好地控制用户体验,并提供更灵活的支付选项。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

254

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

1110

2024.03.01

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

492

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

382

2023.10.25

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

531

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

576

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

761

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

6283

2023.08.17

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

49

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 43.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号