- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将 Stripe 集成到我的网站中,但我目前遇到了一些麻烦。我其实有问题
#1:我已经关注了这个thread还有这个stackblitz页。但它仍然无法正常工作。看起来我的应用程序没有获取 Stripe 组件。 我的ts文件
import {
Component,
AfterViewInit,
OnDestroy,
ViewChild,
ElementRef,
ChangeDetectorRef
} from '@angular/core';
import { NgForm } from "@angular/forms"
import { AngularStripeService } from '@fireflysemantics/angular-stripe-service'
@Component({
selector: 'payment',
templateUrl: './payment.component.html',
styleUrls: ['./payment.component.css']
})
export class PaymentComponent implements AfterViewInit, OnDestroy {
@ViewChild('cardInfo', { static: false }) cardInfo: ElementRef;
stripe: any;
loading = false;
confirmation: any;
card: any;
cardHandler = this.onChange.bind(this);
error: any;
constructor(
private cd: ChangeDetectorRef,
private stripeService:AngularStripeService) {}
ngAfterViewInit() {
this.stripeService.setPublishableKey('pk_test____________').then(
stripe=> {
console.log("in function"); // logging to console
this.stripe = stripe;
const elements = stripe.elements();
this.card = elements.create('card');
this.card.mount(this.cardInfo.nativeElement); // also tried "#card-info"
this.card.addEventListener('change', this.cardHandler);
}).catch((e:any)) => { // no errors
console.error(e);
}
ngOnDestroy() {
this.card.removeEventListener('change', this.cardHandler);
this.card.destroy();
}
onChange( error: any ) {
if (error) {
this.error = error.message;
} else {
this.error = null;
}
this.cd.detectChanges();
}
async onSubmit(form: NgForm) {
console.log(form)
const { token, error } = await this.stripe.createToken(this.card);
if (error) {
console.log('Error:', error);
} else {
console.log('Success!', token);
}
}
}
只有在提交表单时,应用程序才不会给出任何错误,我得到一个错误,即表单为空,这是有道理的。
我的包 JSON strip 组件
"@types/stripe-checkout": "^1.0.3",
"@types/stripe-v3": "^3.1.20",
"@fireflysemantics/angular-stripe-service": "^1.0.0",
"@stripe/stripe-js": "^1.9.0",
"@types/stripe": "^7.13.24",
我不确定我做错了什么我也在脑海中尝试过 CDN 版本,但这对
我的 HTML 和 CSS 与 Stackblitz 页面完全一样
#2:是否有关于如何将 Stripe IDEAL 与 Angular 集成的文档?
我没有必要解决这个教程,但我需要一个很好的 Stripe 和 Angular 示例
最佳答案
我找到了一个最新的教程 tutorial
完整文档 here
创建组件
首先,您应该通过 NPM 安装 Stripe。
npm install ngx-stripe @stripe/stripe-js;
像这样导入 Stripe。
import { NgxStripeModule } from 'ngx-stripe';
之后,现在将 Stripe 包含在您的导入中
NgxStripeModule.forRoot('***your-stripe-publishable-key***'),
之后,您现在可以在您的文件中使用 Stripe在您的 TS 中导入 Stripe 元素
import { StripeService, StripeCardComponent } from 'ngx-stripe';
import { StripeCardElementOptions, StripeElementsOptions } from '@stripe/stripe-js';
您可以更改样式和语言
cardOptions: StripeCardElementOptions = {
hidePostalCode: true,
style: {
base: {
iconColor: '#666EE8',
color: '#31325F',
fontWeight: '300',
fontFamily: '"Helvetica Neue", Helvetica, sans-serif',
fontSize: '14px',
'::placeholder': {
color: '#CFD7E0',
},
},
},
};
elementsOptions: StripeElementsOptions = {
locale: 'nl',
};
然后你可以初始化一个信用卡组件
<ngx-stripe-card
[options]="cardOptions"
[elementsOptions]="elementsOptions"
></ngx-stripe-card>
或者一个理想的组件
<ngx-stripe-ideal-bank
[options]="cardOptions"
[elementsOptions]="elementsOptions"
></ngx-stripe-ideal-bank>
创建付款
对于付款,您应该向创建和处理付款的后端服务器创建一个 http 请求。我是用 ExpressJS 服务器做的。首先是http请求
let data = {
name: name,
email: email,
postal: postal,
paymentOption: this.paymentOption,
products: this.products,
userEmail: this.email,
};
const headers = new HttpHeaders()
.set('Content-Type', 'application/json')
.set('Access-Control-Allow-Origin', '*')
.set('Access-Control-Allow-Credentials', 'true')
.set('Access-Control-Allow-Methods', 'POST')
.set('Access-Control-Allow-Headers', 'Content-Type')
.set('Authorization', '*');
this.http
.post('http://127.0.0.1:3000/pay', JSON.stringify(data), {
headers: headers,
})
现在您已经创建了一个 http 请求
app.post('/pay', cors(), async function (req, res) {
const paymentIntent = await stripe.paymentIntents.create({
amount: price, // watch out in cents
currency: 'eur',
receipt_email: email,
payment_method_types: [method], // card or ideal
description: `Customer named ${name}`,
});
)}
将您的响应发送回您的前端
res.status(201).json(paymentIntent.client_secret);
并确认付款
this.http
.post('http://127.0.0.1:3000/pay', JSON.stringify(data), {
headers: headers,
}).subscribe(async (data) => {
console.log(data);
if (this.paymentOption == 'creditcard') {
// confirm creditcard payment
this.stripeService
.confirmCardPayment(data.toString(), {
payment_method: {
card: this.card.element,
billing_details: {
name: name,
},
},
})
.subscribe((result) => {
console.log('result', result);
});
}
});
关于Angular 和 Stripe 集成,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63463450/
Windows 集成 (NTLM) 身份验证和 Windows 集成 (Kerberos) 之间有什么区别? 如何在IIS6中实现这些 w.r.t. MSDN 最佳答案 Kerberos 和 NTLM
Keycloak是一个用 Java 编写的开源身份验证和身份管理解决方案。它提供了一个nodejs适配器,使用它我能够成功地与express集成。这是有效的路由文件: 'use strict'
这是我关于 Bamboo 的第二个问题 ( My First One )。阅读建议信息后我的理解是,我需要一个构建工具,例如 nAnt 或 MSbuild 来编写一个获取源代码并构建它的脚本(我正在开
可用于将第三方应用程序与 jira 4.3 集成的身份验证方案有哪些?显然,从客户那里获取用户名和密码听起来很荒谬。另外,我知道 oauth 身份验证仅适用于版本 5。请告诉我。谢谢。 附注。我不是在
我有一个使用 DDS 的旧版 C++ 应用程序用于异步通信/消息传递。我需要将此应用程序集成到使用 JMS 进行消息传递的 JavaEE 环境中。除了构建独立的 JMS/DDS 桥接模块之外,我还有其
我正在尝试使用 Whatsapp 发送测试消息,但收到此错误消息: "error":{"code":27,"description":"Recipient not available on chann
我想将 photologue 与我的 Django 应用程序集成,并使用它在车辆库存中显示照片......有点像 Boost Motor Group Inc. 提供的内容。我已经集成了该应用程序,所以
我目前正在尝试弄清楚如何与 fujitsu scansnap 扫描仪集成,但没有从 fujitsu 找到有关 fujitsu scansnap 管理器如何调用您的应用程序并将文件发送到您的应用程序的详
在我的项目中,我使用了 9 个(九个)int-ip:udp-inbound-channel-adapter 和一个 jms:inbound-channel-adapter。 Jms 适配器从服务器接收
在我们当前的原型(prototype)中,大多数标准 HTML 控件都被小程序取代,最重要的是表单提交由小程序触发。 有没有一种方法可以像 一样在服务器端调用关联的操作 ? 本文Applet and
是否可以使用 twilio 号码从 whatsapp 发送/接收短信?有人用whatsapp试过twilio吗?我问过客服,如果可能的话,他说,不确定,但很多人都问过这个问题。 最佳答案 万一其他人来
我们办公室中几乎不存在版本控制,这显然导致了很多麻烦。我们想使用SVN和Notepad++进行设置...任何人都对如何实现此目标有任何想法?我已经开始研究并浏览了这个网站: http://www.sw
曾经有提供这种集成的 spring-modules 项目;但是,该项目现已弃用。现在有没有人继续支持这种集成?谢谢。 最佳答案 工作正在进行中。 http://blog.athico.com/sear
我的理解是,根据 http://wiki.dbpedia.org/Datasets,DBpedia 从 YAGO 获取类层次结构,而不是实体。 .但是,类似 http://dbpedia.org/cl
任何人都可以帮助我如何将 OpenCMS 与 Java Spring Web 应用程序集成。已经用谷歌搜索并浏览了很多网站但没有用。所以,请帮助我。 最佳答案 我认为将 SpringMVC 与 Ope
我正在尝试使用新的 migs getaway (MPGS) 我遵循了下一个 url 中的代码 https://ap-gateway.mastercard.com/api/documentation/i
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 4年前关闭。 Improve thi
我有一个 cmake 项目。我想轻松完成以下操作 搜索光标下任何变量、函数等的声明、定义和引用,这些可能在外部头文件中声明,其路径是在CMakeLists.txt中使用INCLUDE_DIRECTOR
有人能给我指点一下 Objective-C(或 c/c++)库的方向,或者教通过 FTP 上传或下载的教程(Objective-C)吗?最好能展示如何将文件下载到临时目录,然后稍后上传?我不介意针对
集成()给出了非常错误的答案: integrate(function (x) dnorm(x, -5, 0.07), -Inf, Inf, subdivisions = 10000L) # 2.127
我是一名优秀的程序员,十分优秀!