国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

使用weixin-java-tools完成微信授權登錄、微信支付的示例

2024-05-06 16:46:12
字體:
來源:轉載
供稿:網友

本文為學習記錄weixin-java-tools實現公眾號微信支付.

碼云地址:點我

    // 授權登錄用到    <dependency>      <groupId>com.github.binarywang</groupId>      <artifactId>weixin-java-mp</artifactId>      <version>3.1.0</version>    </dependency>
    // 微信支付用到    <dependency>      <groupId>com.github.binarywang</groupId>      <artifactId>weixin-java-pay</artifactId>      <version>3.1.0</version>    </dependency>

授權登錄官方 api:點我

個人理解的授權登錄流程:引導用戶點擊喚起授權登錄的地址,打開頁面后攜帶微信返回的code參數;使用code參數獲取AccessToken;獲取用戶數據。

引導客戶打開授權登錄地址后,攜帶code跳轉到指定頁面在指定頁面調用方法:

public Result getAccessToken(@RequestParam(name = "code") String code, HttpServletRequest request, HttpServletResponse response) {    if (StringUtils.isBlank(code)) {      return Result.error("code不存在");    }    try {      WxMpOAuth2AccessToken wxMpOAuth2AccessToken = wxMpService.oauth2getAccessToken(code);      String accessToken = wxMpOAuth2AccessToken.getAccessToken();      // 獲取用戶微信賬戶信息      WxMpUser wxMpUser = wxMpService.getUserService().userInfo(wxMpOAuth2AccessToken.getOpenId());      if (StringUtils.isBlank(wxMpUser.getOpenId())) {        return Result.error("用戶數據不存在");      }      return Result.success(wxMpUser);    } catch (WxErrorException e) {      e.printStackTrace();      log.info("授權異常:{}", e);      return Result.error("授權登錄失敗");    } catch (Exception e) {      e.printStackTrace();      return Result.error("登錄失敗");    }  }

前端保存下用戶信息就完事了。

個人理解的微信支付流程:用戶頁面點擊<微信支付>按鈕 后端調用 <微信統一下單> 統一下單返回參數 ,前端使用 <統一下單>返回的參數喚起微信支付。

商戶中需要在api安全中設置很多東西... 就不一一贅述了 

微信支付官方api 前端:點我

后端api點我

商戶登錄地址 點我

public Result pay(Long orderNo, HttpServletRequest request) {        //查詢訂單信息    Order order = orderService.findByOrderNo(orderNo);    try {      WxPayUnifiedOrderRequest orderRequest = new WxPayUnifiedOrderRequest();      //獲取當前用戶      UserInfo userInfo = RequestContextHolderUtil.getUserInfo();      orderRequest.setBody("支付內容的說明");      //商戶號      orderRequest.setMchId(mchId);      orderRequest.setAttach("xxx公司");      orderRequest.setOutTradeNo(orderNo.toString());      orderRequest.setTotalFee(BaseWxPayRequest.yuanToFen(order.getPayment().toString()));//元轉成分      orderRequest.setOpenid(userInfo.getOpenId());      orderRequest.setSpbillCreateIp(HttpUtils.getIp(request));      //我這里是微信公眾號內打開的h5頁面 type使用 JSAPI 根據業務場景變更      orderRequest.setTradeType(WxPayConstants.TradeType.JSAPI);      // 支付成功后跳轉頁面  這里需要對url進行編碼      orderRequest.setNotifyUrl("http://xxxxxxxxx");      orderRequest.setAppid(appId);            // 調用sdk提供的統一下單方法 createOrder會返回重新組裝后的對象 建議使用這個       Object unOrder = wxService.createOrder(orderRequest);      // 這個可能是偏向原生一點的統一下單,返回的參數有很多沒用的 或者null值 建議使用 createOrder下單      // wxService.unifiedOrder(orderRequest);             return Result.success(unOrder);    } catch (Exception e) {      log.error("微信支付失敗!訂單號:{},原因:{}", orderNo, e.getMessage());      e.printStackTrace();      return Result.error("支付失敗,請稍后重試!");    }  }

前端js代碼:

前端喚起微信支付的時候可能會出一些問題,這里建議使用 console.log(res.err_desc);輸出錯誤信息 

res.err_msg 只會提示支付失敗... desc會提示一些具體信息

function onBridgeReady(){  WeixinJSBridge.invoke(    'getBrandWCPayRequest', {      "appId":"wx31fd1e1bad23db37",   //公眾號名稱,由商戶傳入      "timeStamp":wxData.timeStamp,     //時間戳,自1970年以來的秒數      "nonceStr":wxData.nonceStr, //隨機串      "package":wxData.packageValue,      "signType":wxData.signType,     //微信簽名方式:      "paySign":wxData.paySign //微信簽名    },    function(res){      console.log(res.err_desc)      if(res.err_msg == "get_brand_wcpay_request:ok" ){        // 使用以上方式判斷前端返回,微信團隊鄭重提示:        //res.err_msg將在用戶支付成功后返回ok,但并不保證它絕對可靠。      }    });}var wxData={};function pay(orderId){  $.ajax({    url:"統一下單方法url",    type:'get',    data:{orderNo:orderId},    beforeSend: function (xhr) {      xhr.setRequestHeader("token", $.cookie("token"));    },    crossDomain: true,    success:function(result){      wxData=result.data;      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();      }    }  });}

注:商戶中心支付路徑設置 所有調起微信支付的頁面都要在此注冊,否則微信支付會一閃而過。
微信開發工具上可以模擬授權登錄,但是無法模擬微信支付,所以微信支付在微信開發工具上出現的錯誤都不用管,直接拿到真機上去測試!

使用了sdk后的支付和授權還是很方便的,麻煩的是微信方面的一些配置和流程... 很坑。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 健康| 宁晋县| 柳江县| 梓潼县| 禹城市| 遂昌县| 聂拉木县| 乡宁县| 虞城县| 秭归县| 桐庐县| 安陆市| 浦北县| 太原市| 塘沽区| 运城市| 贵溪市| 伊川县| 土默特右旗| 仙游县| 漠河县| 扎囊县| 志丹县| 枞阳县| 施甸县| 灌云县| 靖远县| 遂川县| 麻栗坡县| 佛山市| 曲松县| 琼海市| 满城县| 江华| 温泉县| 咸阳市| 太湖县| 横峰县| 仙游县| 安吉县| 秭归县|