# Stripe国际支付集成指南 ## 概述 本项目已成功集成Stripe国际信用卡支付功能,支持多种国际货币(USD、EUR、GBP、JPY等)的在线支付。Stripe适配器已完整实现并集成到现有的统一支付架构中。 ## 功能特性 ### ✅ 已实现功能 1. **支付订单管理** - 创建Stripe PaymentIntent - 查询支付状态 - 支持多种国际货币 2. **Webhook处理** - 安全的签名验证 - 异步支付结果通知 - 订单状态同步 3. **退款管理** - 申请退款 - 查询退款状态 - 部分退款支持 4. **安全特性** - Webhook签名验证 - 环境变量配置管理 - 错误处理和日志记录 5. **API接口** - RESTful API设计 - Swagger文档自动生成 - 完整的DTO验证 ## 环境配置 ### 必需的环境变量 在`.env`文件中添加以下Stripe配置: ```bash # Stripe配置 STRIPE_SECRET_KEY=sk_test_your_secret_key_here STRIPE_PUBLISHABLE_KEY=pk_test_your_publishable_key_here STRIPE_WEBHOOK_SECRET=whsec_your_webhook_secret_here # 服务器配置(用于回调URL) SERVER_URL=https://your-domain.com ``` ### 获取Stripe密钥 1. **注册Stripe账号** - 访问 [stripe.com](https://stripe.com) - 创建账号并完成验证 2. **获取API密钥** - 登录Stripe Dashboard - 进入"开发者" -> "API密钥" - 复制可发布密钥和密钥 3. **设置Webhook** - 进入"开发者" -> "Webhook" - 添加端点:`https://your-domain.com/api/v1/payment/stripe/webhook` - 选择事件:`payment_intent.succeeded` - 复制签名密钥 ## API使用指南 ### 1. 创建支付订单 ```bash POST /api/v1/payment/stripe/create-order Content-Type: application/json { "userId": "user_123", "businessType": "credit_purchase", "businessId": "credits_500", "amount": 4800, "currency": "USD", "description": "购买500积分包", "customerEmail": "user@example.com" } ``` **响应示例:** ```json { "orderId": "order_123", "paymentIntentId": "pi_test_123", "clientSecret": "pi_test_123_secret_abc", "publishableKey": "pk_test_123", "amount": 4800, "currency": "USD", "status": "pending", "createdAt": "2024-01-01T00:00:00.000Z" } ``` ### 2. 查询订单状态 ```bash GET /api/v1/payment/stripe/order/{orderId} ``` ### 3. 申请退款 ```bash POST /api/v1/payment/stripe/refund Content-Type: application/json { "orderId": "order_123", "refundAmount": 2400, "reason": "用户申请退款" } ``` ### 4. 查询退款状态 ```bash GET /api/v1/payment/stripe/refund/{refundId} ``` ### 5. 获取支持的货币 ```bash GET /api/v1/payment/stripe/supported-currencies ``` ## 前端集成示例 ### React + Stripe Elements ```javascript import { loadStripe } from '@stripe/stripe-js'; import { Elements, CardElement, useStripe, useElements } from '@stripe/react-stripe-js'; const stripePromise = loadStripe('pk_test_your_publishable_key'); function PaymentForm({ clientSecret }) { const stripe = useStripe(); const elements = useElements(); const handleSubmit = async (event) => { event.preventDefault(); if (!stripe || !elements) return; const cardElement = elements.getElement(CardElement); const { error, paymentIntent } = await stripe.confirmCardPayment( clientSecret, { payment_method: { card: cardElement, billing_details: { email: 'user@example.com', }, } } ); if (error) { console.error('支付失败:', error); } else { console.log('支付成功:', paymentIntent); } }; return (
); } function App() { const [clientSecret, setClientSecret] = useState(''); // 创建支付订单获取clientSecret useEffect(() => { fetch('/api/v1/payment/stripe/create-order', { method: 'POST', headers: { 'Content-Type': 'application/json' }, body: JSON.stringify({ userId: 'user_123', businessType: 'credit_purchase', businessId: 'credits_500', amount: 4800, currency: 'USD' }) }) .then(res => res.json()) .then(data => setClientSecret(data.clientSecret)); }, []); return (