java實現微信支付功能開發執行個體

來源:互聯網
上載者:User

管理關於微信支付文檔

https://pay.weixin.qq.com/wiki/doc/api/index.html

微信支付普通商戶接入支援四種支付方式

刷卡支付

使用者開啟微信錢包的刷卡的介面,商戶掃碼後提交完成支付

公眾號支付

使用者在微信內進入商家H5頁面,頁面內調用JSSDK完成支付

掃碼支付

使用者開啟"微信掃一掃“,掃描商戶的二維碼後完成支付

APP支付

商戶APP中整合微信SDK,使用者點擊後跳轉到微信內完成支付

這裡我們來看公眾號支付

公眾號支付開發步驟

1、設定測試目錄

在微信公眾平台設定,欄目見圖7.7。支付測試狀態下,設定測試目錄,測試人的微訊號添加到白名單,發起支付的頁面目錄必須與設定的精確匹配。並將支付連結發到對應的公眾號會話視窗中才能正常發起支付測試。注意正式目錄一定不能與測試目錄設定成一樣,否則支付會出錯。

微信支付源碼

直接看代碼。

 代碼如下 複製代碼

RequestHandler requestHandler = new RequestHandler(super.getRequest(),super.getResponse());
 
//擷取token //兩小時內有效,兩小時後重新擷取
 
Token = requestHandler.GetToken();
 
//更新token 到應用中
 
requestHandler.getTokenReal();
 
System.out.println("微信支付擷取token=======================:" +Token);
 
//requestHandler 初始化
 
requestHandler.init();
 
requestHandler.init(appid,appsecret, appkey,partnerkey, key);

代碼:本地系統產生訂單

// 設定package訂單參數
 
  SortedMap<String, String> packageParams = new TreeMap<String, String>();
 
  packageParams.put("bank_type", "WX"); // 支付類型
 
  packageParams.put("body", "xxxx"); // 商品描述
 
  packageParams.put("fee_type", "1"); // 銀行幣種
 
  packageParams.put("input_charset", "UTF-8"); // 字元集
 
  packageParams.put("notify_url", "http://xxxx.com/xxxx/wxcallback"); // 通知地址 這裡的通知地址使用外網地址測試,注意80連接埠是否開啟。
 
  packageParams.put("out_trade_no", no); // 商戶訂單號
 
  packageParams.put("partner", partenerid); // 設定商戶號
 
  packageParams.put("spbill_create_ip", super.getRequest().getRemoteHost()); // 訂單產生的機器IP,指使用者瀏覽器端IP
 
  packageParams.put("total_fee", String.valueOf(rstotal)); // 商品總金額,以分為單位
 
 
 
// 設定支付參數
 
  SortedMap<String, String> signParams = new TreeMap<String, String>();
 
  signParams.put("appid", appid);
 
  signParams.put("noncestr", noncestr);
 
  signParams.put("traceid", PropertiesUtils.getOrderNO());
 
  signParams.put("timestamp", timestamp);
 
  signParams.put("package", packageValue);
 
  signParams.put("appkey", this.appkey);
 
 
 
  // 產生支付簽名,要採用URLENCODER的原始值進行SHA1演算法!
 
  String sign ="";
 
    try {
 
    sign = Sha1Util.createSHA1Sign(signParams);
 
    } catch (Exception e) {
 
    e.printStackTrace();
 
    }  
 
  // 增加非參與簽名的額外參數
 
  signParams.put("sign_method", "sha1");
 
  signParams.put("app_signature", sign);  
 
  // api支付拼包結束------------------------------------
 
  //擷取prepayid
 
  String prepayid = requestHandler.sendPrepay(signParams);
 
  System.out.println("prepayid :" + prepayid);
代碼:產生預付快訂單完成


 //產生預付快訂單完成,返回給android,ios 掉起微信所需要的參數。
 
  SortedMap<String, String> payParams = new TreeMap<String, String>();
 
  payParams.put("appid", appid);
 
  payParams.put("noncestr", noncestr);
 
  payParams.put("package", "Sign=WXPay");
 
  payParams.put("partnerid", partenerid);
 
  payParams.put("prepayid", prepayid);
 
  payParams.put("appkey", this.appkey);
 
  //這裡除1000 是因為參數長度限制。
 
  int time = (int) (System.currentTimeMillis() / 1000);
 
  payParams.put("timestamp",String.valueOf(time));
 
 
 
  System.out.println("timestamp:" + time);
 
 
 
  //簽名
 
  String paysign ="";
 
  try {
 
        paysign = Sha1Util.createSHA1Sign(payParams);
 
  } catch (Exception e) {
 
    e.printStackTrace();
 
  }
 
  payParams.put("sign", paysign);
 
 
 
 //拼json 資料返回給用戶端
 
  BasicDBObject backObject = new BasicDBObject();
 
  backObject.put("appid", appid);
 
  backObject.put("noncestr", payParams.get("noncestr"));
 
  backObject.put("package", "Sign=WXPay");
 
  backObject.put("partnerid", payParams.get("partnerid"));
 
  backObject.put("prepayid", payParams.get("prepayid"));
 
  backObject.put("appkey", this.appkey);
 
  backObject.put("timestamp",payParams.get("timestamp"));
 
  backObject.put("sign",payParams.get("sign"));
  
  String backstr = dataObject.toString();
 
  System.out.println("backstr:" + backstr);
 
  return backstr;

到此為止,預付款訂單已產生,並且已返回用戶端,坐等微信伺服器通知,通知的地址就是產生預付款訂單的notify_url

 ResponseHandler resHandler = new ResponseHandler(request, response);
 
  resHandler.setKey(partnerkey);
 
  //建立請求對象
 
  //RequestHandler queryReq = new RequestHandler(request, response);
 
  //queryReq.init();
 
  if (resHandler.isTenpaySign() == true) {
 
      //商戶訂單號
 
      String out_trade_no = resHandler.getParameter("out_trade_no");
 
      System.out.println("out_trade_no:" + out_trade_no);
 
      //財付通訂單號
 
      String transaction_id = resHandler.getParameter("transaction_id");
 
      System.out.println("transaction_id:" + transaction_id);
 
      //金額,以分為單位
 
      String total_fee = resHandler.getParameter("total_fee");
 
      //如果有使用折扣券,discount有值,total_fee+discount=原請求的total_fee
 
      String discount = resHandler.getParameter("discount");
 
      //支付結果
 
      String trade_state = resHandler.getParameter("trade_state");
 
 
 
      //判斷簽名及結果
 
      if ("0".equals(trade_state)) {
 
        //------------------------------
 
        //即時到賬處理業務開始
 
        //------------------------------
 
      
 
        System.out.println("----------------商務邏輯執行-----------------");
 
     
 
        //——請根據您的商務邏輯來編寫程式(以上代碼僅作參考)——
 
        System.out.println("----------------商務邏輯執行完畢-----------------");
 
        System.out.println("success"); // 請不要修改或刪除
 
      
 
        System.out.println("即時到賬支付成功");
 
        //給財付通系統發送成功資訊,財付通系統收到此結果後不再進行後續通知
 
        resHandler.sendToCFT("success");
 
  
 
       //給微信伺服器返回success 否則30分鐘通知8次
 
       return "success";
 
     }else{     
 
      System.out.println("通知簽名驗證失敗");
 
      resHandler.sendToCFT("fail");
 
      response.setCharacterEncoding("utf-8");
 
    }
 
   }else {
 
      System.out.println("fail -Md5 failed");
 
  }

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.