JAVA-微信支付开发
為什么80%的碼農(nóng)都做不了架構(gòu)師?>>> ??
怕忘記,記錄一下。
首先。先看一邊官方文檔。https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=7_1
然后。微信公眾號(hào)設(shè)置支付目錄及授權(quán)域名
參照https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=7_3
具體流程
用戶發(fā)起支付請(qǐng)求 --> 重定向至微信授權(quán) -->微信重定向至服務(wù)器接口 --> 創(chuàng)建訂單信息跳轉(zhuǎn)至支付頁面 --> 統(tǒng)一下單 --> 等待用戶支付,微信回調(diào) --> 接口接收到微信通知 --> 完成支付流程
1.
?用戶發(fā)起支付請(qǐng)求,重定向至微信提供的授權(quán)接口,需攜帶參數(shù)
appid 為 公眾號(hào)的APP_ID
redirect_uri 為 微信處理完授權(quán) 回調(diào)接口 需要進(jìn)行URLEncode
state 為微信回調(diào)時(shí)攜帶的參數(shù) 根據(jù)需要填寫 我這里填的是手機(jī)號(hào)
https://open.weixin.qq.com/connect/oauth2/authorize?appid="+WeChatConfig.APP_ID+"&redirect_uri="+URLEncoder.encode(WeChatConfig.CALL_BACK_URL)+"&response_type=code&scope=snsapi_base&state="+phonenmb+"#wechat_redirect";2.
用戶同意授權(quán)會(huì)獲得一個(gè)code,通過這個(gè)code獲取授權(quán)的access_token
String code = request.getParameter("code"); AuthToken authToken = WeChatUtils.getTokenByAuthCode(code);在這里,我預(yù)先根據(jù)用戶信息創(chuàng)建了一個(gè)未支付訂單,將訂單信息傳到支付頁面
3.
用戶查看支付信息,同意后進(jìn)行支付,進(jìn)入統(tǒng)一下單
主要是構(gòu)建微信統(tǒng)一下單需要的各種參數(shù)
//構(gòu)建微信統(tǒng)一下單需要的參數(shù) Map<String,String> map = Maps.newHashMap(); //用戶ID map.put("userId",userId); //用戶標(biāo)識(shí)openId map.put("openId",openid); //請(qǐng)求Ip地址 map.put("remoteIp",request.getRemoteAddr()); //調(diào)用統(tǒng)一下單service Map<String,Object> resultMap = WeChatPayService.unifiedOrderJsApi(order,map); //通信標(biāo)識(shí) String returnCode = (String) resultMap.get("return_code"); //交易標(biāo)識(shí) String resultCode = (String) resultMap.get("result_code"); //返回信息 String return_msg = (String) resultMap.get("return_msg");成功的情況下微信會(huì)返回
returnCode=SUCCESS
result_code=SUCCESS
return_msg=OK
失敗的話查看msg信息,對(duì)照開發(fā)文檔
只有當(dāng)returnCode與resultCode均返回“success”,才代表微信支付統(tǒng)一下單成功
然后需要將信息傳遞到支付頁面
//微信公眾號(hào)AppId String appId = (String) resultMap.get("appid"); //當(dāng)前時(shí)間戳 String timeStamp = WeChatUtils.getTimeStamp(); //統(tǒng)一下單返回的預(yù)支付id String prepayId = "prepay_id="+resultMap.get("prepay_id"); //不長(zhǎng)于32位的隨機(jī)字符串 String nonceStr = WeChatUtils.getRandomStr(32); //自然升序map SortedMap<String,Object> signMap = Maps.newTreeMap(); signMap.put("appId",appId); signMap.put("package",prepayId); signMap.put("timeStamp",timeStamp); signMap.put("nonceStr",nonceStr); signMap.put("signType","MD5"); model.addAttribute("appId",appId); model.addAttribute("timeStamp",timeStamp); model.addAttribute("nonceStr",nonceStr); model.addAttribute("prepayId",prepayId); //獲取簽名 model.addAttribute("paySign",WeChatUtils.getSign(signMap));其中最重要的是簽名,簽名沒有問題,支付流程基本上就完成了
4.
支付成功回調(diào)接口
支付后,微信會(huì)發(fā)送成功信息到步驟1中的redirect_uri接口
返回信息 XML解析到Map中
驗(yàn)證其中return_code 是否為SUCCESS
是則支付成功,保存微信返回的支付數(shù)據(jù),return_msg = OK
否則支付失敗,打印一下return_msg 信息處理
?
?
?
轉(zhuǎn)載于:https://my.oschina.net/xingyu4j/blog/1800991
總結(jié)
以上是生活随笔為你收集整理的JAVA-微信支付开发的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: js对html进行转义和反转义的操作
- 下一篇: 通过实例理解 RabbitMQ 的基本概