HTML5和JAVA在微信,html5 调起微信支付

本文主要是梳理在微信浏览器中调起微信支付的整个过程,以及主要过程当中界面的展现效果。虽然整个交易过程看起来很简单,就是输入金额,而后调起微信支付,输入密码完成交易,可是在实现过程当中,是须要对接微信公众平台和微信商户平台的,这块比较繁琐。javascript

流程图:

在微信浏览器中调起微信支付,有那么几方面的交互:h5微信、h5服务器、服务器微信服务器。三方面一个不能少。总体流程大体以下:php

a98328b87f4c48d3b44670f231eaa59a.gif

下面具体说明下每一个环节要作的事情。

注册公众平台

这里注意一点,目前支付能力只支持服务号,对于我的的订阅号是不支持的。申请支付能力须要提交的信息可能比较繁琐。在开发->基本配置中便可看到AppId

绑定域名

必定按照微信规定的格式填写域名,而且将MP_verify_3GXUmRy2Q1SznaIC.txt文件拷贝到与名对应的服务器根目录下。

h5请求微信服务器获取codehtml

//服务器接口

var baseURL = 'http://192.168.1.46:8080/alipay';

sessionStorage.setItem('baseURL', baseURL);

//公众号appid

var appId = "wx62343e380757XXXX";

sessionStorage.setItem('appId', appId);

function getQueryString(name) {

var reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)", "i");

var r = window.location.search.substr(1).match(reg);

if(r != null) return unescape(r[2]);

return null;

}

// 微信平台,支付宝,其余

var browserType = (function() {

var ua = window.navigator.userAgent.toLowerCase();

if(ua.match(/MicroMessenger/i) == 'micromessenger') {

return 1;

} else

if(ua.match(/AlipayClient/i) == 'alipayclient') {

return 2;

} else {

return 3;

}

})();

// 获取

var userId, code;

try {

userId = getQueryString('userId');

//测试

// userId = "10914918196281681006";

if(userId) {

sessionStorage.setItem('userId', userId);

}

code = getQueryString('code');

if(code) {

sessionStorage.setItem('code', code);

}

} catch(e) {

weui.alert('获取数据出错!');

throw new Error('upload error');

}

var currentUrl = location.href;

// 判断平台

if(browserType == 1) {

if(!code) {

location.href = "https://open.weixin.qq.com/connect/oauth2/authorize?appid=" + appId + "&redirect_uri=" + currentUrl + "&response_type=code&scope=snsapi_base&state=STATE#wechat_redirect";

return;

}

} else if(browserType == 2) {} else { //其余浏览器

weui.alert('当前浏览器不支持!');

return;

}

//直接跳转到支付界面

location.replace('userPayDesk.html');

h5请求服务器获取openId

中间有个过程,即服务器请求微信服务器获取openId后返回给前端。

h5跨域请求能够用ajax,或者axios跨域。服务器端请求在此不讨论。前端

// 请求后台,获取openId等

var instance = axios.create({

baseURL: baseURL,

timeout: 10000,

headers: {

'Content-Type': 'application/x-www-form-urlencoded'

}

});

instance.post(

'/scan/getOpenID',

'code=' + code

)

.then(function(response) {

var res = response.data;

//

if(res.code == '0000') {

var openId = res.response.openId;

try {

sessionStorage.setItem('openId', openId);

//跳转到支付页面

location.replace('userPayDesk.html');

} catch(e) {

weui.alert('当前手机版本不支持!');

throw new Error('sessionStoragr unsurpport');

}

} else {

weui.alert(res.msg);

}

})

.catch(function(error) {

});

输入金额

界面展示以下:java

a98328b87f4c48d3b44670f231eaa59a.gif

最后会将源码上传上去,界面样式你们能够参考下。ios

付款,请求统一下单

这里传递的参数能够根据需求来定,我须要用到商户的userId以便服务器区分是支付给哪一个商户方便记帐。web

// 系统下单

instance.post(

' /pay/appScanPay',

'transAmount=' + moneyFloat + '&userId=' + userId + '&openId=' + openId + '&browserType=' + browserType

)

.then(function(response) {

var res = response.data;

code = '';

if(res.code == '0000') {

if(res.response.hasOwnProperty('payInfo') && res.response.payInfo) {

//保存订单号和建立日期

sessionStorage.setItem('transTime', res.response.transTime);

sessionStorage.setItem('orderId', res.response.orderId);

sessionStorage.setItem('amount', res.response.amount);

wxPay(res.response.payInfo);

} else if(res.response.hasOwnProperty('qrCode')) {

location.href = res.response.qrCode;

}

} else {

weui.alert(res.msg, function() {

location.replace('userPay.html');

});

}

setTimeout(function() {

loading2.hide();

}, 200);

})

.catch(function(error) {

weui.alert('系统繁忙');

});

h5调起微信支付

这里利用微信浏览器的私有操做方法WeixinJSBridge.invoke,对于想用jweixin-1.0.0.js的,能够参照其官方文档来,这里就不赘述了,文档地址:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421141115ajax

// 调用微信支付接口

function wxPay(payInfo) {

if(typeof WeixinJSBridge == "undefined") {

if(document.addEventListener) {

document.addEventListener('WeixinJSBridgeReady', onBridgeReady, false);

} else if(document.attachEvent) {

document.attachEvent('WeixinJSBridgeReady', onBridgeReady);

document.attachEvent('onWeixinJSBridgeReady', onBridgeReady);

}

} else {

onBridgeReady(payInfo);

}

function onBridgeReady(payInfo) {

WeixinJSBridge.invoke(

'getBrandWCPayRequest', {

"appId": payInfo.appId, //公众号名称,由商户传入

"timeStamp": payInfo.timeStamp, //时间戳,自1970年以来的秒数

"nonceStr": payInfo.nonceStr, //随机串

"package": payInfo.package, //订单详情扩展字符串

"signType": payInfo.signType, //微信签名方式:

"paySign": payInfo.paySign //微信签名

},

function(res) {

if(res.err_msg == "get_brand_wcpay_request:ok") {

//

location.replace('userPaySuccess.html');

// weui.alert("付款成功", function() {

// WeixinJSBridge.call('closeWindow');

// });

} else {

weui.alert("付款失败", function() {

location.replace('userPay.html');

});

}

}

);

}

}

支付成功,重定向到成功页面:

成功页面以下:axios

a98328b87f4c48d3b44670f231eaa59a.gif

小技巧:

这里分享一个在微信浏览器操做的小技巧,就是对于安卓用户,可能会点击物理返回键,这时候你可能不但愿重定向到上一页,这里能够参考下个人作法,就是点返回键直接退出微信浏览器:api

pushHistory();

var bool = false;

setTimeout(function() {

bool = true;

}, 1500);

window.addEventListener("popstate", function(e) {

if(bool) {

WeixinJSBridge.call('closeWindow');

}

pushHistory();

}, false);

function pushHistory() {

var state = {

title: "title",

url: "#"

};

window.history.pushState(state, "title", "#");

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Java 中实现微信支付需要使用微信支付 SDK。您可以在微信支付官方网站上下载最新版本的 SDK,并在您的 Java 项目中使用它。 使用微信支付 SDK 的具体步骤如下: 1. 注册微信支付商户并获取商户 ID 和密钥。 2. 下载并导入微信支付 SDK。 3. 创建支付订单并获取支付二维码。 4. 使用扫码支付或者 JSAPI 支付接口调用微信支付。 5. 接收微信支付的异步通知并进行订单状态的更新。 有关微信支付的更多信息,您可以参考微信支付官方文档:https://pay.weixin.qq.com/wiki/doc/api/index.html 希望这些信息对您有帮助! ### 回答2: 要实现微信支付功能,可以使用Java编程语言结合微信支付开放平台提供的API来实现。 首先,需要在微信支付开放平台注册并创建一个应用,获取到应用的AppID、商户号、AppSecret等信息。 接下来,在Java项目中引入微信支付SDK,可以使用第三方库,如"wechatpay-api"来简化开发流程。然后,通过使用SDK提供的相关方法,可以实现以下功能: 1. 获取access_token:通过获取 access_token 接口,获取微信支付接口调用凭证,用于后续接口调用的身份验证。 2. 统一下单:使用统一下单接口,将用户提交的支付信息传给微信支付平台,生成预支付订单,并返回预付款二维码链接或者支付ID。 3. 生成支付链接或二维码:将预付款二维码链接或支付ID返回给前端,通过生成支付链接或者二维码的方式,提供给用户进行支付。 4. 微信支付回调:在用户支付成功后,微信支付平台会异步调用开发者设置的支付结果通知地址,向该地址发送支付结果信息。开发者需要在接收到回调时,验证回调的合法性,并及时处理支付结果。 5. 查询订单状态:通过订单查询接口,可以查询用户支付订单的当前状态,如支付成功、支付失败等。 6. 退款:使用退款接口,可以实现订单退款操作,退还用户支付的金额。 以上是使用Java实现微信支付的基本步骤。在具体实现过程中,还需注意接口调用的参数传递、异常处理、数据加密等问题。为确保支付安全,建议使用HTTPS协议进行数据传输,并加强对接口的签名验证。 ### 回答3: Java 实现微信支付可以通过微信支付开放平台提供的开发工具包来完成。首先,需要在微信支付开放平台注册一个开发者账号,并创建一个应用获取对应的应用ID和应用密钥。 接下来,可以使用Java语言进行开发。首先,需要引入微信支付Java SDK,例如官方提供的weixin-java-pay SDK。通过在项目的pom.xml文件中添加相关依赖,即可将SDK集成到项目中。 然后,通过在代码中进行配置,将应用ID和应用密钥等信息设置到SDK中。可以使用SDK提供的配置类进行设置,例如WxPayConfig。 接下来,可以使用SDK提供的API进行微信支付的相关操作。例如,使用SDK提供的统一下单API可以生成一个支付链接,通过该链接用户可以进行支付操作。可以通过创建对应的请求对象,并调用SDK提供的发送请求的方法来实现。 支付结果通知可以使用SDK提供的回调接口来处理,当支付完成后,微信支付平台会向预先设置的回调URL发送通知。可以在代码中编写对应的处理逻辑,接收并解析微信支付平台发送的通知,校验数据的正确性,并进行相应的业务处理。 最后,可以使用SDK提供的查询订单API来查询订单的支付结果。可以根据订单号或其他查询条件,调用SDK提供的查询订单接口来获取订单的最新支付状态。 通过以上步骤,就可以使用Java实现微信支付功能。需要注意的是,开发过程中需要仔细阅读微信支付开放平台提供的文档和SDK的使用指南,并按照实际需求进行相关配置和操作。同时,为了确保支付过程的安全性,建议使用SSL证书进行加密传输。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值