nodejs 支付宝支付

JavaScript021

nodejs 支付宝支付,第1张

首先安装引入 alipay-sdk ,并配置 alipay-sdk

alipay-sdk 文档地址 https://www.npmjs.com/package/alipay-sdk

alipay-sdk 文档上并没有写给出app支付实例demo,我这边从网上各种查资料,琢磨了好久才实现。

签名并加密 返回给app客户端,app客户端拿到这串字符调用支付宝就可以了

获取app支付的通知

支付宝异步参数格式如下,字段名称请参考支付宝的文档( https://docs.open.alipay.com/204/105465/ )

比较遗憾,我没有做过支付宝的集成…… 倒是做过paypal,与一些国外信用卡支付的集成。具体怎么集成,看看文档与demo就ok了。

前端页面还是服务器端集成?

这个就看你支付业务的复杂度了,如果只是一个简单的扫码支付什么的,直接页面集成就好。具体还是得看支付宝官方文档的建议。当你支付业务相当复杂(比如循环付款,不知道支付宝有没有)或者觉得页面不安全,放在服务器也可以的。

注意下面:

支付后的消息回调(paypal 叫做IPN),这块的文档一定要看仔细看清楚,理解官方文档中说的每一种状态,成功、失败、处理中等等(可能支付宝中没有这些……我不太清楚)。 对每一种状态的处理都要考虑全面。

注意消息回调的延迟,可能用户付钱了,但是支付服务器可能会有处理延迟,这种情况要考虑好。

对参数的校验及其严格,关于价格最好是在服务器端计算,然后传给支付宝,不要相信客户端给的数据。

支付界面引导要友好,比如用户在付款成功后,但服务器出错了,没有做出对应处理,要给用户一个联系你们的入口,免得用户懵逼……

以上是我做一些支付集成后的感触……

千万不要坑用户。。。

关于钱的代码一定要全力对待,真的不能马虎的……

那么今天我就用JavaScript代码来实现这个效果吧,那么首先介绍一下整个的思路,首先我们先将确定输入密码的位数,我的需求是5位,那么就用一个div标签包住5个input标签

现在很多时候大家付款的场景都是在手机上面,而随着H5页面的开发变得越来越方便,很多场景也从客户端搬到了浏览器中,其中支付这个场景就很自然的被放在了浏览器中。那么这样的输入框大家一定不会陌生吧:

那么今天我就用JavaScript代码来实现这个效果吧,那么首先介绍一下整个的思路,首先我们先将确定输入密码的位数,我的需求是5位,那么就用一个div标签包住5个input标签。

并且给这个5个input设置display: inline-block 属性,同时用<!- ->来消除元素直接的margin值,那么HTML就是如下的样子:

<div class="input"><input type="tel" placeholder="随" maxlength=""><!--><input type="tel" placeholder="机" maxlength=""><!--><input type="tel" placeholder="" maxlength=""><!--><input type="tel" placeholder="位" maxlength=""><!--><input type="tel" placeholder="数" maxlength=""></div>

在代码中我们需要设置最多输入的位数,不然就不像了嘛~当然为了在移动端输入的时候能唤起数字键盘来,我们也需要设置type="tel"。那么接下来就是CSS样式的代码了,这里我就简单的贴出一些代码,具体高仿的像不像其实就是这里了~

input {display: inline-block&:last-child {border-right: px solid #}input {border-top: px solid #border-bottom: px solid #border-left: px solid #width: pxheight: pxoutline:nonefont-family: inheritfont-size: pxfont-weight: inherittext-align: centerline-height: pxcolor: #cccbackground: rgba(,,,)}}

那么接下来就是最关键的JavaScript部分了,

/*** 模拟支付宝的密码输入形式*/(function (window, document) {var active = ,inputBtn = document.querySelectorAll('input')for (var i = i <inputBtn.lengthi++) {inputBtn[i].addEventListener('click', function () {inputBtn[active].focus()}, false)inputBtn[i].addEventListener('focus', function () {this.addEventListener('keyup', listenKeyUp, false)}, false)inputBtn[i].addEventListener('blur', function () {this.removeEventListener('keyup', listenKeyUp, false)}, false)}/*** 监听键盘的敲击事件*/function listenKeyUp() {var beginBtn = document.querySelector('#beginBtn')if (!isNaN(this.value) &&this.value.length != ) {if (active <) {active += }inputBtn[active].focus()} else if (this.value.length == ) {if (active >) {active -= }inputBtn[active].focus()}if (active >= ) {var _value = inputBtn[active].valueif (beginBtn.className == 'begin-no' &&!isNaN(_value) &&_value.length != ) {beginBtn.className = 'begin'beginBtn.addEventListener('click', function () {calculate.begin()}, false)}} else {if (beginBtn.className == 'begin') {beginBtn.className = 'begin-no'}}}})(window, document)

首先我们对最外层的div进行监听,当发现用户选择div的时候就将input的焦点设置到active上面去,而这个active则是一个计数器,默认的时候是第一位的,也就是0,而当我们输入了正确的数字后将会增加一个active,这样input的焦点就会向后移动了,这样就完成了输入一个向后移动一位的功能了,而同时我们监听键盘上的退格键,当用户点击了退格键之后就对active减一,这样输入框的焦点也就向前移动了,当然,当input失去焦点的时候我们也同时移除绑定在上面的监听事件,这样就不会造成多次触发的问题了。