返回顶部
首页 > 资讯 > 前端开发 > JavaScript >JavaScrip如何安全使用PaymentRequestAPI详解
  • 898
分享到

JavaScrip如何安全使用PaymentRequestAPI详解

JavaScripPaymentRequestAPIPaymentRequestAPI安全 2022-11-13 18:11:09 898人浏览 八月长安
摘要

目录引言Payment Request api浏览器支持如何创建PaymentRequest对象How to use the paymentMethods par

引言

Payment Request API提供了一个跨浏览器标准,允许您从客户那里收集付款、地址和联系信息。然后,您可以使用这些信息来处理他们的订单。

它还促进了浏览器和网站之间交换这些信息。这背后的基本思想是通过让用户轻松在浏览器中存储付款和联系信息来改善用户的在线购物体验。

Payment Request API浏览器支持

Payment Request API仍在积极开发中,仅受现代浏览器的最后几个版本的支持。

在开始提出付款请求之前,您应该进行功能检测,以确保浏览器支持API:

if (window.PaymentRequest) {
  // Yes, we can use the API
} else {
  // No, fallback to the checkout page
  window.location.href = '/checkout'
}

请注意,您只能在超过https服务的网站上使用# Payment Request API。

现在让我们看看这个有用的API是如何工作的。

如何创建PaymentRequest对象

付款请求始终通过使用PaymentRequest()构造函数创建PaymentRequest的新对象来启动。构造函数接受两个强制性参数和一个可选参数:

  • paymentMethods定义接受哪种付款方式。例如,您只能接受Visa和MasterCard信用卡。
  • paymentDetails包含应付付款总额、税款、运费、显示项目等。
  • options是一个可选参数,用于向用户请求其他详细信息,例如姓名、电子邮件、电话等。

接下来,我们将创建一个仅包含所需参数的新付款请求。

How to use the paymentMethods parameter

const paymentMethods = [  {    supportedMethods: ['basic-card']
  }
]
const paymentDetails = {
  total: {
    label: 'Total Amount',
    amount: {
      currency: 'USD',
      value: 8.49
    }
  }
}
const paymentRequest = new PaymentRequest(paymentMethods, paymentDetails)

Notice the supportedMethods parameter in the paymentMethods object. When it is set to basic-card, both debit and credit cards of all networks will be accepted.

但您可以限制受支持的网络和卡片类型。例如,只有以下Visa、MasterCard和Discover信用卡被接受:

const paymentMethods = [  {    supportedMethods: ['basic-card'],
    data: {
      supportedNetworks: ['visa', 'mastercard', 'discover'],
      supportedTypes: ['credit']
    }
  }
]
// ...

How to use the paymentDetails object

传递给PaymentRequest构造函数的第二个参数是付款详细信息对象。它包含订单总数和可选的显示项目数组total参数必须包括一个label参数和一个带有currencyvalue``amount参数。

您还可以添加其他显示项目,以提供总数的高级细分:

const paymentDetails = {
  total: {
    label: 'Total Amount',
    amount: {
      currency: 'USD',
      value: 8.49
    }
  },
  displayItems: [
    {
      label: '15% Discount',
      amount: {
        currency: 'USD',
        value: -1.49
      }
    },
    {
      label: 'Tax',
      amount: {
        currency: 'USD',
        value: 0.79
      }
    }
  ]
}

displayItems参数并不意味着显示一长长的项目列表。由于移动设备上浏览器的支付用户界面的空间有限,您应该使用此参数仅显示顶级字段,如小计、折扣、税费、运费等。

Keep in mind that the PaymentRequest API does not perfORM any calculations. So your WEB application is responsible for providing the pre-calculated total amount.

如何使用options参数请求更多详细信息

您可以使用第三个可选参数向用户请求其他信息,例如姓名、电子邮件地址和电话号码:

// ...
const options = {
  requestPayerName: true,
  requestPayerPhone: true,
  requestPayerEmail: true
}
const paymentRequest = new PaymentRequest(paymentMethods, paymentDetails, options)

默认情况下,所有这些值都是false的,但将它们中的任何一个值为true``options对象中将导致付款UI中的额外步骤。如果用户已经在浏览器中存储了这些详细信息,它们将被预先填充。

如何显示付款用户界面

创建PaymentRequest对象后,您必须调用show()方法向用户显示付款请求UI。

show()方法返回一个承诺,如果用户成功填写了详细信息,则该promise将使用aPaymentResponse对象解决。如果出现错误或用户关闭用户界面,则承诺将被拒绝。

// ...
const paymentRequest = new PaymentRequest(paymentMethods, paymentDetails, options)
paymentRequest
  .show()
  .then(paymentResponse => {
    // close the payment UI
    paymentResponse.complete().then(() => {
      // TODO: call REST API to process the payment at the backend server
      // with the data from `paymentResponse`.
    })
  })
  .catch(err => {
    // user closed the UI or the API threw an error
    console.log('Error:', err)
  })

使用上述代码,浏览器将向用户显示付款用户界面。一旦用户填写了详细信息并单击“Pay”按钮,您将在show()承诺中收到PaymentResponse对象。

当您调用PaymentResponse.complete()方法时,付款请求UI会立即关闭。此方法返回一个新的承诺,以便您可以使用收集的信息调用后端服务器并处理付款。

如果您想在付款用户界面显示旋转器时致电后端服务器处理付款,您可以延迟调用complete())。

Let's create a mock function for payment processing with the backend server. It takes paymentResponse as a parameter and returns a promise after 1.5 seconds that resolves to a JSON object:

const processPaymentWithServer = paymentResponse => {
  return new Promise((resolve, reject) => {
    setTimeout(() => {
      resolve({ status: true })
    }, 1500)
  })
}
//...
paymentRequest
  .show()
  .then(paymentResponse => {
    processPaymentWithServer(paymentResponse).then(data => {
      if (data.status) {
        paymentResponse.complete('success')
      } else {
        paymentResponse.complete('fail')
      }
    })
  })
  .catch(err => {
    console.log('Error:', err)
  })

在上面的示例中,浏览器支付UI将显示一个处理屏幕,直到processPaymentWithServer()方法返回的承诺得到解决。我们还使用“成功”和“失败”字符串来告诉浏览器交易结果。如果您调用complete('fail')浏览器将向用户显示错误消息。

如何取消付款请求

如果您想取消付款请求,因为没有活动或任何其他原因,您可以使用PaymentRequest.abort()方法。它立即关闭付款请求UI,并拒绝show()承诺。

// ...
setTimeout(() => {
  paymentRequest
    .abort()
    .then(() => {
      // aborted payment request
      console.log('Payment request aborted due to no activity.')
    })
    .catch(err => {
      // error while aborting
      console.log('abort() Error: ', err)
    })
}, 5000)

结论

这就是javascript# Payment Request API快速介绍的结束。它提供了一种基于浏览器的方法来收集客户付款和联系信息,这些信息可以发送到后端服务器以处理付款。

以上就是JavaScrip如何安全使用Payment Request API详解的详细内容,更多关于JavaScrip Payment Request API的资料请关注编程网其它相关文章!

--结束END--

本文标题: JavaScrip如何安全使用PaymentRequestAPI详解

本文链接: https://lsjlt.com/news/170206.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • JavaScrip如何安全使用PaymentRequestAPI详解
    目录引言Payment Request API浏览器支持如何创建PaymentRequest对象How to use the paymentMethods par...
    99+
    2022-11-13
    JavaScrip Payment Request API Payment Request API 安全
  • JavaScrip怎么安全使用Payment Request API
    这篇文章主要讲解了“JavaScrip怎么安全使用Payment Request API”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScrip怎么安全使用Pay...
    99+
    2023-07-04
  • 如何使用npm安装yarn详解
    目录引言window版:mac版:那么,npm 和yarn的区别是什么呢??命令对比:总结引言 很多同学用惯了npm安装项目依赖,想要尝试使用yarn的命令,但是第一次使用yarn的...
    99+
    2024-04-02
  • 详解如何使用C++写一个线程安全的单例模式
    目录单例模式的简单实现有问题的双重检测锁现代C++中的解决方法使用现代C++中的内存顺序限制使用现代C++中的call_once方法使用静态局部变量单例模式的简单实现 单例模式大概是...
    99+
    2022-11-13
    C++线程安全的单例模式 C++ 单例模式 C++ 线程安全
  • win10安全模式如何使用
    本篇内容介绍了“win10安全模式如何使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!win10安全模式有什么用:答:安全模式可以方便地检...
    99+
    2023-06-30
  • 详解CopyOnWriteArrayList是如何保证线程安全
    目录一:前言二:成员变量分析三:源码分析1.空参构造2.传入一个Collection对象的构造方法3.传入一个数组的构造方法四:总结一:前言 在我们需要保证线程安全的时候,如果使用到...
    99+
    2024-04-02
  • 云服务器安全性如何保障安全使用
    数据备份:云服务器通常会为用户提供数据备份服务,以确保在数据丢失或损坏时能够恢复数据。备份数据应该存储在安全的位置,以防止数据的泄露和恶意破坏。 访问控制:云服务器提供商通常会实施访问控制措施,以确保只有授权的用户才能访问服务器。这些措施...
    99+
    2023-10-27
    安全性 服务器
  • 详解SpringBoot是如何保证接口安全的
    目录为什么要保证接口安全防篡改如何解决防重放基于timestamp的方案基于nonce + timestamp 的方案代码实现1、构建请求头对象2、工具类从HttpServletRe...
    99+
    2023-02-02
    SpringBoot保证接口安全 SpringBoot 接口安全
  • 如何安全的使用vps主机
    安全使用vps主机的方法:1、修改vps主机的初始密码,以免被人恶意操作;2、不要乱装杀毒软件和防火墙,以免占用资源导致系统崩溃或数据泄露;3、不要私自修改默认设置,以免操作错误导致无法登录远程桌面;4、vps主机用途不要太杂,以免出现导致...
    99+
    2024-04-02
  • 如何安全的使用https代理
    如何安全的使用https代理?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。就网络协议而言,代理ip也根据网络协议的不同划分出不同的类型供大家选择。HTTP是因特网上使用最广泛的...
    99+
    2023-06-15
  • 如何使用 PHP 的安全函数?
    php 的安全函数可保护您的应用程序免受常见的 web 攻击。它们包括:输入验证:过滤和转义输入以防止跨站点脚本 (xss) 攻击。表单令牌:防止跨站点请求伪造 (csrf) 攻击。数据...
    99+
    2024-04-19
    安全 php 敏感数据 lsp
  • Go语言中map使用和并发安全详解
    目录1 map使用1.1 map定义1.2 map的使用和概念1.3 map的容量1.4 map的使用1.4.1 map的遍历1.4.2 map的删除和断言1.5 map的坑2 并发...
    99+
    2024-04-02
  • 详解如何使用ReactiveObjC
    目录概述基本使用1、基本控件2、监听属性变化3、遍历数组和字典4、监听 Notification 通知事件5、代替Delegate代理二、RAC常用类三、高级函数使用1、连接信号、合...
    99+
    2022-05-21
    IOS ReactiveObjC
  • 如何设计一个安全的API接口详解
    目录前言一 安全性问题 1.1 调用接口的先决条件-token 1.2 使用POST作为接口请求方式 1.3 客户端IP白名单 1.4 单个接口针对ip限流 1.5 记录接口请求日志...
    99+
    2024-04-02
  • 如何让美国vps使用更安全
    让美国vps使用更安全的方法:1、选择好的VPS主机商,以保证自身的利益;2、选择自行搭建系统,不用使用可视化管理面板;3、关注一键安装包或第三方组件的更新,及时进行系统的安全管理;4、定期检查网站的程序文件,看是否有漏洞和是否有可疑的文件...
    99+
    2024-04-02
  • 如何让VPS主机使用更安全
    让VPS主机使用更安全的方法:1、选择好的VPS主机商,以保证自身的利益;2、选择自行搭建系统,不用使用可视化管理面板;3、关注一键安装包或第三方组件的更新,及时进行系统的安全管理;4、定期检查网站的程序文件,看是否有漏洞和是否有可疑的文件...
    99+
    2024-04-02
  • 如何使用 Lynis 扫描 Linux 安全性
    本篇内容介绍了“如何使用 Lynis 扫描 Linux 安全性”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!你有没有想过你的 Linux 机...
    99+
    2023-06-15
  • 如何使用Lynis扫描Linux 安全性
    这篇文章给大家介绍如何使用Lynis扫描Linux 安全性,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Lynis是一个非常流行的开源安全审计工具能够强化基于Linux和unix的系统,自动生成一份关于机器安全的报。安...
    99+
    2023-06-28
  • PostgreSQL中如何安全使用SQL拼接
    要安全地使用SQL拼接,可以采取以下措施: 使用参数化查询:使用参数化查询可以防止SQL注入攻击。在PostgreSQL中,可以使...
    99+
    2024-04-29
    SQL PostgreSQL
  • 使用Jedis面临的非线程安全问题详解
    目录1. jedis类图2. 为什么jedis不是线程安全的2.1 共享socket引起的异常2.2 共享数据流引起的异常3、jedis多线程操作网上都说jedis实例是非线程安全的,常常通过JedisPool连接池去管...
    99+
    2022-12-22
    Jedis非线程安全问题 Jedis 线程安全 Jedis 线程
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作