前端 VUE 微信支付 JSAPI

本文详细介绍了在微信公众号的H5页面中实现微信支付的全过程,包括引入JSSDK、初始化配置、调用支付接口、处理支付结果等关键步骤。在支付成功或失败后,通过window.location.href进行页面跳转。同时,文章强调了vue路由跳转在此场景下的不适用,并提供了后台交互获取支付参数和签名的方法。
摘要由CSDN通过智能技术生成

在威信公众号之中的产品H5页面,在购买时需要直接唤起微信支付,完成投保、核保流程。今天分享自己在唤起微信支付中的一些体会,希望可以帮助到大家。

先给大家将官方的说明文档附上,感兴趣的可以直接看看   微信支付-开发者文档

准备工作

  • 引入JSSDK文件(sdk文件
  • 初始化微信环境(wx.config,wx.ready)
  • 唤起微信支付的方法(wx.chooseWXPay)

 支付流程

1、在产品投保页面准备微信支付所需参数(index.vue)

支付成功或失败后跳转页面使用window.location.href,vue自己的路由跳转是不起作用的(#号的原因)

let This = this;
this.visible.loading = true;
saveProposoal({'投保参数'}).then(res => {
	this.visible.loading = false;
	if(res.code == 200){
		let proposalNo = res.data.proposalNo;
        //初始化配置
		pay({
            //支付参数				
			data : {openid : openId,proposalNo:proposalNo},
            //支付成功回调函数,跳转支付成功页
			success(res){
				window.location.href = '支付成功页面'
			},
            //支付取消回调函数,跳转支付失败页
			cancel(res){
			    window.location.href = '支付失败页面'
			},
			fail(res){
				This.$toast('支付失败');							
			}
		})
	}else{
		this.$toast(res.message);
	}
})

2、Pay方法

需后台小伙伴提供签名接口获取公众号的唯一标识appID,ticket。前端拿到这些数据自己 去生成签名数据。用来初始化微信环境

后台小伙伴提供的支付接口(微信支付接口),返回支付所需要的参数

  • timestamp,支付签名时间戳
  • nonceStr,支付签名随机串
  • package,统一支付接口返回的prepay_id参数值
  • signType,签名方式
  • paySign,支付签名
//微信支付
export function pay(opts){
	let {data,signData,success,cancel,fail} = opts;
	let config = null;
    //调用后台接口生成微信签名数据
	签名接口xx(signData).then(res =>{
		if(res.code == 200){
            //处理后端返回的签名数据
			config = wxSign({ticket:res.content.ticket,appId:res.content.appid})
            //调用微信支付接口,获取支付参数
			return 微信支付接口xxx(data)
		}
	}).then(res =>{
		if(res.code == 200){
            //调用微信支付			
			wxPay({
				config : config,
				data : res.content,
				success(res){
					success && success(res)
				},
				cancel(res){
					cancel && cancel(res)
				},
				fail(res){
					fail && fail(res)
				}
			})
		}
	})
}

3、wxSign()

通过签名接口获取到的数据,进一步处理。将这些处理后的参数用来初始化微信支付API。wx.config()接口注入权限验证配置并申请所需开放标签

export default function(data){
	var urlN = window.location.href.split('#')[0];
	var timestampn = new Date().getTime().toString();
	var timestamp = timestampn.substring(0, 10);			//生成签名的时间戳
	var nonceStr = Math.random().toString(36).substr(2);	//生成签名的随机串
	var con = `jsapi_ticket=${data.ticket}&noncestr=${nonceStr}&timestamp=${timestamp}&url=${urlN}`
	var signature = hex_sha1(con);		//引自sha1.js
	//签名处理后参数	
	return {
		appId : data.appId,
		timestamp : timestamp,
		nonceStr : nonceStr,
		signature : signature
	}
}

4、wxPay()

//微信支付
export default function(opts){
	let {config,data,success,cancel,fail} = opts;
	wx.config({
		debug: false,					//开启调试模式
		appId: config.appId,			//公众号的唯一标识
		timestamp: config.timestamp,	//生成签名的时间戳
		nonceStr: config.nonceStr,		//生成签名的随机串
		signature: config.signature,	//签名
		jsApiList: [ 'chooseWXPay']		//需要使用的JS接口列表
		//openTagList : ['wx-open-launch-weapp']
	});
	wx.ready(function () {
		wx.chooseWXPay({
			timestamp: data.timeStamp,	// 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符
			nonceStr: data.nonceStr,	// 支付签名随机串,不长于 32 位
			package: data['package_'],	// 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=\*\*\*)
			signType: data.signType,	// 签名方式,默认为'SHA1',使用新版支付需传入'MD5'
			paySign: data.paySign,		// 支付签名
			success: function (res) {
				success && success(res)
			},
			cancel: function (res) {
				cancel && cancel(res)
			},
			fail: function (res) {
				fail && fail(res)
			}
		});
	})
}

到这里,整个支付前端就完成了。

### 回答1: Uniapp是一种跨平台的开发框架,可以用于同时开发iOS、Android和H5应用。而H5是指在网页上运行的应用程序。微信支付JSAPI是微信提供的一种支付接口,通过调用JSAPI接口,可以在H5应用中实现微信支付功能。 在Uniapp中使用微信支付JSAPI,可以通过以下步骤进行操作: 1. 首先,在Uniapp项目中引入微信支付的相关配置文件和SDK库文件。 2. 在需要使用微信支付的页面中,引入微信支付的JS文件,并初始化微信支付参数。支付参数包括商户号、appid、签名等信息。 3. 创建统一下单接口的后端处理程序,用于生成预支付订单并返回支付预处理参数给前端。 4. 在支付页面中,调用微信支付JSAPI的方法,传入预支付处理参数和支付回调方法。 5. 当用户点击支付按钮后,会弹出微信支付界面,用户可以选择支付方式进行支付操作。 6. 支付成功后,微信会将支付结果返回给前端,并通过支付回调方法进行处理,可以展示支付成功的提示信息和更新订单状态等操作。 需要注意的是,使用微信支付JSAPI需要在微信开放平台上注册并申请相关的权限。同时,在使用过程中,还需要确保支付参数的正确性、支付安全性和业务逻辑的完善性。 总之,Uniapp可以很好地支持H5应用中的微信支付JSAPI,通过合理的配置和调用,可以方便地在H5应用中实现微信支付功能,为用户提供更加便捷的支付体验。 ### 回答2: Uniapp是一款跨平台的应用开发框架,可以让开发者使用Vue.js语法来开发同时兼容多个平台的应用程序。Uniapp支持在H5平台中使用微信支付JSAPI。 微信支付JSAPI是微信提供的一组用于在网页中实现微信支付功能的JavaScriptAPI接口。通过调用微信支付JSAPI,开发者可以在H5页面中调起微信支付功能,用户可以使用微信支付完成支付操作。 在Uniapp中使用微信支付JSAPI,首先需要引入微信支付的JS文件。可以在页面的头部引入:<script src="https://res.wx.qq.com/open/js/jweixin-1.4.0.js"></script>。 然后,在需要使用微信支付的地方,可以通过uni.request方法向服务器请求获取支付参数。获取到支付参数后,可以使用wx.requestPayment方法调起微信支付界面,并传入支付参数。支付成功后,微信会返回支付结果给开发者的回调函数,开发者可以在回调函数中处理支付结果。 需要注意的是,在使用微信支付JSAPI的过程中需要保证支付参数的安全性,避免支付参数被恶意篡改。通常可以在服务器端生成支付参数,并通过服务器端返回给前端,以确保支付参数的安全性。 总结起来,Uniapp可以在H5平台中使用微信支付JSAPI来实现微信支付功能,开发者需要引入微信支付的JS文件,通过uni.request方法获取支付参数,调用wx.requestPayment方法调起支付,处理支付结果的回调函数,并确保支付参数的安全性。 ### 回答3: Uniapp 是一款跨平台开发框架,可以同时开发小程序、H5 和APP。Uniapp 提供了对微信支付的支持,可以使用微信支付的 JSAPI(JavaScript API)来进行支付功能的开发。 Uniapp H5 微信支付 JSAPI 的实现过程如下: 1. 首先,需要在微信支付商户平台上注册并获取到自己的商户号(mch_id),同时生成随机字符串(nonce_str)和当前时间戳(timestamp)。 2. 接下来,在前端页面中引入微信支付的 JS 文件,可以通过在页面头部添加以下代码进行引入: ``` <script src="https://res.wx.qq.com/open/js/jweixin-1.4.0.js"></script> ``` 3. 在页面中设置要支付的订单信息,包括订单号(out_trade_no)、订单总金额(total_fee)等,并将这些信息以及商户号、随机字符串和时间戳等传递给后端服务器。 4. 后端服务器在接收到前端传递的支付信息后,根据微信支付 API 的要求,生成签名(sign)并返回给前端。 5. 前端页面收到后端返回的签名后,调用微信支付的 JSAPI 方法,传入订单信息和签名等参数,即可发起支付请求。 6. 微信客户端会弹出支付窗口,用户输入密码或进行指纹验证后,支付完成。 注意事项: - 在使用 Uniapp 进行微信支付开发时,需要确保页面已经获得了微信公众号的授权,因为微信支付是需要通过公众号的权限进行的。 - 需要合理处理支付结果的回调,根据支付结果进行相应的处理,如跳转到支付成功页面或给予支付失败的提示等。 通过使用 Uniapp H5 微信支付 JSAPI,我们可以方便地在 Uniapp 框架下进行微信支付的开发,实现支付功能的需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值