微信支付签名验证工具怎么在前端签名

请教大神帮我解决下微信JSSDk接口签名错误的问题?在线等
[问题点数:20分,无满意结帖,结帖人zhzivy]
请教大神帮我解决下微信JSSDk接口签名错误的问题?在线等
[问题点数:20分,无满意结帖,结帖人zhzivy]
不显示删除回复
显示所有回复
显示星级回复
显示得分回复
只显示楼主
匿名用户不能发表回复!|前端如何在H5页面调起微信支付前端如何在H5页面调起微信支付创意胡先生百家号在微信服务号开发的时候经常会遇到微信支付的功能实现,通过实际经验自己总结了一下,前端在H5页面调起微信支付有两种办法,一是利用内置对象,二是通过引用微信的js sdk,亲测都能支付成功,从写法上来看用内置对象方法比较简单。这里讲的只是前端要做的事情,整个微信支付还有多一半的工作量需要后台去实现,这里就不讲了。方法一(利用内置对象):function onBridgeReady(){WeixinJSBridge.invoke('getBrandWCPayRequest',{&appId&:&wx0ec43b&,//公众号名称,由商户传入&timeStamp&:&&,//时间戳,自1970年以来的秒数&nonceStr&:&e61463f8efacccfbbb444&,//随机串&package&:&prepay_id=u802345jgfjsdfgsdg888&,&signType&:&MD5&,//微信签名方式:&paySign&:&70EABB79628FBCAFADD89&//微信签名},function(res){if(res.err_msg==&get_brand_wcpay_request:ok&){}//使用以上方式判断前端返回,微信团队郑重提示:res.err_msg将在用户支付成功后返回ok,但并不保证它绝对可靠。});}if(typeofWeixinJSBridge==&undefined&){if(document.addEventListener){document.addEventListener('WeixinJSBridgeReady',onBridgeReady,false);}elseif(document.attachEvent){document.attachEvent('WeixinJSBridgeReady',onBridgeReady);document.attachEvent('onWeixinJSBridgeReady',onBridgeReady);}}else{onBridgeReady();}方法二(利用js sdk):js sdk用法的详细说明见官方文档:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp下面是支付环节用到的内容,截取自js sdk的:微信JS-SDK是微信公众平台面向网页开发者提供的基于微信内的网页开发工具包。通过使用微信JS-SDK,网页开发者可借助微信高效地使用拍照、选图、语音、位置等手机系统的能力,同时可以直接使用微信分享、扫一扫、卡券、支付等微信特有的能力,为微信用户提供更优质的网页体验。此文档面向网页开发者介绍微信JS-SDK如何使用及相关注意事项。JSSDK使用步骤步骤一:绑定域名【必需】先登录微信公众平台进入“公众号设置”的“功能设置”里填写“JS接口安全域名”。备注:登录后可在“开发者中心”查看对应的接口权限。步骤二:引入JS文件【必需】在需要调用JS接口的页面引入如下JS文件,(支持https):http://res.wx.qq.com/open/js/jweixin-1.2.0.js备注:支持使用 AMD/CMD 标准模块加载方法加载步骤三:通过config接口注入权限验证配置【必需】所有需要使用JS-SDK的页面必须先注入配置信息,否则将无法调用(同一个url仅需调用一次,对于变化url的SPA的web app可在每次url变化时进行调用,目前Android微信客户端不支持pushState的H5新特性,所以使用pushState来实现web app的页面会导致签名失败,此问题会在Android6.2中修复)。wx.config({debug: true, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。appId: '', // 必填,公众号的唯一标识timestamp: , // 必填,生成签名的时间戳nonceStr: '', // 必填,生成签名的随机串signature: '',// 必填,签名,见附录1jsApiList: [] // 必填,需要使用的JS接口列表,所有JS接口列表见附录2});步骤四:通过ready接口处理成功验证wx.ready(function(){// config信息验证后会执行ready方法,所有接口调用都必须在config接口获得结果之后,config是一个客户端的异步操作,所以如果需要在页面加载时就调用相关接口,则须把相关接口放在ready函数中调用来确保正确执行。对于用户触发时才调用的接口,则可以直接调用,不需要放在ready函数中。});步骤五:通过error接口处理失败验证wx.error(function(res){// config信息验证失败会执行error函数,如签名过期导致验证失败,具体错误信息可以打开config的debug模式查看,也可以在返回的res参数中查看,对于SPA可以在这里更新签名。});接口调用说明所有接口通过wx对象(也可使用jWeixin对象)来调用,参数是一个对象,除了每个接口本身需要传的参数之外,还有以下通用参数:1.success:接口调用成功时执行的回调函数。2.fail:接口调用失败时执行的回调函数。3.complete:接口调用完成时执行的回调函数,无论成功或失败都会执行。4.cancel:用户点击取消时的回调函数,仅部分有用户取消操作的api才会用到。5.trigger: 监听Menu中的按钮点击时触发的方法,该方法仅支持Menu中的相关接口。备注:不要尝试在trigger中使用ajax异步请求修改本次分享的内容,因为客户端分享操作是一个同步操作,这时候使用ajax的回包会还没有返回。以上几个函数都带有一个参数,类型为对象,其中除了每个接口本身返回的数据之外,还有一个通用属性errMsg,其值格式如下:调用成功时:&xxx:ok& ,其中xxx为调用的接口名用户取消时:&xxx:cancel&,其中xxx为调用的接口名调用失败时:其值为具体错误信息基础接口判断当前客户端版本是否支持指定JS接口wx.checkJsApi({jsApiList: ['chooseImage'], // 需要检测的JS接口列表,所有JS接口列表见附录2,success: function(res) {// 以键值对的形式返回,可用的api值true,不可用为false// 如:{&checkResult&:{&chooseImage&:true},&errMsg&:&checkJsApi:ok&}}});备注:checkJsApi接口是客户端6.0.2新引入的一个预留接口,第一期开放的接口均可不使用checkJsApi来检测。发起一个微信支付请求 【必需】wx.chooseWXPay({timestamp: 0, // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符nonceStr: '', // 支付签名随机串,不长于 32 位package: '', // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=***)signType: '', // 签名方式,默认为'SHA1',使用新版支付需传入'MD5'paySign: '', // 支付签名success: function (res) {// 支付成功后的回调函数}});注意:以上两种H5的微信支付方法都需要注意以下两点一、设置支付目录请确保实际支付时的请求目录与后台配置的目录一致,否则将无法成功唤起微信支付。二、设置授权域名开发公众号支付时,在统一下单接口中要求必传用户openid,而获取openid则需要您在公众平台设置获取openid的域名,只有被设置过的域名才是一个有效的获取openid的域名,否则将获取失败。本文仅代表作者观点,不代表百度立场。系作者授权百家号发表,未经许可不得转载。创意胡先生百家号最近更新:简介:创意胡先生拥有多年互联网推广经验作者最新文章相关文章还有很多小孩也没找到,你愿意帮助他们么?分享前端微信支付js代码-微信开发-PHP中文网QQ群微信公众号还没有收藏分享前端微信支付js代码本文实例为大家分享了前端微信支付代码,供大家参考,具体内容如下$('.Save_Patient_Msg').click(function(){
$('.Save_Patient_Msg').off('click');
var hrdfId = getOrderId();
var txnAmt = $('.sum_pay.font-red').html();
var data = {orderId: hrdfId, txnAmt: &0.01&,
prodDesc: &远程诊断服务&, callType: &JSAPI&,
access_token: getUrlParam(&access_token&)
type: 'POST',
url: '/hims/api/commonPay/queryTransNo?access_token='+getUrlParam('access_token'),
dataType:'json',
contentType:'application/json',
data: JSON.stringify(data),
success: function(Wxres){
if(!Wxres){
$.alert('服务器拥堵,请稍后访问')
console.log(Wxres);
if(Wxres.data.respCode == 'fail'){
$.alert(Wxres.data.respMsg);
//10 微信支付接口
// 10.1 发起一个支付请求
// 注意:此 Demo 使用 2.7 版本支付接口实现,建议使用此接口时参考微信支付相关最新文档。
var param = Wxres.
wx.config({
debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
appId: 'wx403eadfb', // 必填,公众号的唯一标识
timestamp: param.timestamp, // 必填,生成签名的时间戳
nonceStr: param.noncestr, // 必填,生成签名的随机串
signature: param.signJs,// 必填,调用js签名,
jsApiList: ['chooseWXPay'] // 必填,需要使用的JS接口列表,这里只写支付的
wx.chooseWXPay({
timestamp: param.timestamp, // 支付签名时间戳,注意微信jssdk中的所有使用timestamp字段均为小写。但最新版的支付后台生成签名使用的timeStamp字段名需大写其中的S字符
nonceStr: param.noncestr, // 支付签名随机串,不长于 32 位
package: &prepay_id=&+param.transNo, // 统一支付接口返回的prepay_id参数值,提交格式如:prepay_id=***)
signType: &MD5&, // 签名方式,默认为'SHA1',使用新版支付需传入'MD5'
paySign: param.sign, // 支付签名
success: function (res) {
if(res.errMsg == &chooseWXPay:ok&){
//alert(&支付成功&);
window.location.href = &/hims/weixin/pages/Order_ok.html?access_token=&+getUrlParam(&access_token&);
alert(res.errMsg);
cancel: function(res){
//alert('取消支付');
error:function(data){
var msg = data.message || data.
$.alert('服务器错误'+msg);
function getUrlParam(name){
var reg = new RegExp(&(^|&)&+ name +&=([^&]*)(&|$)&); //构造一个含有目标参数的正则表达式对象
var r = window.location.search.substr(1).match(reg); //匹配目标参数
if (r!=null) return unescape(r[2]); //返回参数值
})以上就是分享前端微信支付js代码的详细内容,更多请关注php中文网其它相关文章!共3篇9点赞收藏分享:.php.cn&猜你喜欢PHP中文网:独家原创,永久免费的在线,php技术学习阵地!
All Rights Reserved | 皖B2-QQ群:关注微信公众号Cordova(6)
android(7)
最近负责微信支付 全栈的开发,有些要点和坑在此做个笔记。
一. java后端
1. 在使用WxPay的SDK时对请求参数进行封装,发现签名失败,后来发现nonce_str随机字符串不需要传递,在SDK里面已经封装好了。
2.timestamp这个时间戳的参数注意,在ios端只支持10位的时间戳,所以统一用10位时间戳来兼容ios
r.put("timestamp", System.currentTimeMillis() / 1000 + "");
3.当支付类型是APP时,特别需要注意文档的一段话:(先调用【】生成预付单,获取到
prepay_id 后将参数再次签名传输给APP发起支付)
//r为统一下单返回的map
if ("APP".equals(arg.get("trade_type").toString())) {
Map&String, String& signMap = new HashMap&&();
signMap.put("appid", WXPayConfigImpl.getInstance().getAppID());
signMap.put("partnerid", WXPayConfigImpl.getInstance().getMchID());
signMap.put("prepayid", r.get("prepay_id"));
signMap.put("package", "Sign=WXPay");
signMap.put("noncestr", r.get("nonce_str"));
signMap.put("timestamp", r.get("timestamp"));
String appSign = WXPayUtil.generateSignature(signMap, WXPayConfigImpl.getInstance().getKey());
r.put("sign", appSign);
4.对于异步返回参数的注意,需要返回的是XML格式:
Map&String, String& returnMap = new HashMap&&();
returnMap.put("return_code", "SUCCESS");
returnMap.put("return_msg", "OK");
return WXPayUtil.mapToXml(returnMap);
二.Android端
1.在微信的网站上所需要的APP签名最好用文档给的gensignature.apk来获取
2.WXPayEntryActivity这个必须要放在自己的app包名根目录下的wxapi文件夹下,配置为如下
&activity android:exported="true" android:launchMode="singleTop" android:name=".wxapi.WXPayEntryActivity" android:theme="@style/Theme.AppCompat.NoActionBar" /&
3.微信支付可以不用sdk的jar包直接在dependencies下配置就可以使用:
compile "com.tencent.mm.opensdk:wechat-sdk-android-with-mta:1.1.6"
1.不光要实现onResp,还一定要加上handleOpenURL
- (void)handleOpenURL:(NSNotification *)notification {
NSURL *url = [notification object];
if ([url isKindOfClass:[NSURL class]] && [url.scheme isEqualToString:[self settingForKey: @"wxappid"]]) {
[WXApi handleOpenURL:url delegate:self];
2.时间戳timestamp 只支持10位。
1.前端就是二维码扫描支付,思路是后端生成二维码的链接给前端,前端用js去画个二维码显示,由于qrcode是比较老的库,无法使用amd模块化导入所以使用JQ的getScript:
$.getScript("js/qrcode.min.js")
.done(function(script, textStatus) {
var qrcode = new QRCode(document.getElementById("wxpayQrcode"), {
text: url,
width: 230,
height: 230,
colorDark : "#000000",
colorLight : "#ffffff",
correctLevel : QRCode.CorrectLevel.H
}).fail(function(jqxhr, settings, exception) {
//"获取二维码失败!
2. 获取支付结果,思路是调用后端的微信SDK查询订单接口,可使用socket或者setInterval来做,setInterval时必须注意参数被传递进去是作为他内部的一块内存数据。
this.timer=setInterval(this.payOrderQueryRpc,3000,out_trade_no,self);
payOrderQueryRpc(out_trade_no, self) {
if (document.getElementById("pay" + self.payPageId)) {
if (查询订单) {
clearInterval(self.timer);
clearInterval(self.timer);}

我要回帖

更多关于 微信app支付签名错误 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信