欧美一区二区三区老妇人-欧美做爰猛烈大尺度电-99久久夜色精品国产亚洲a-亚洲福利视频一区二区

go語言的微信支付接口,go語言 接口

中行跨境GO支持的支付方式有哪些?

中行跨境GO目前支持的支付方式包括中國銀行個(gè)人手機(jī)銀行支付和微信支付。

成都創(chuàng)新互聯(lián)從2013年創(chuàng)立,先為贊皇等服務(wù)建站,贊皇等地企業(yè),進(jìn)行企業(yè)商務(wù)咨詢服務(wù)。為贊皇企業(yè)網(wǎng)站制作PC+手機(jī)+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。

以上內(nèi)容供您參考,業(yè)務(wù)規(guī)定請(qǐng)以實(shí)際為準(zhǔn)。

如有疑問,歡迎咨詢中國銀行在線客服。

誠邀您下載使用中國銀行手機(jī)銀行APP或中銀跨境GO APP辦理相關(guān)業(yè)務(wù)。

調(diào)取微信支付的方法

//獲取微信支付接口信息

? ? ? ? ? ? ? ? http.post(`${api.api}/config`,

? ? ? ? ? ? ? ? {

? ? ? ? ? ? ? ? ? ? url: location.href.split("#")[0]//截取地址欄地址傳到后臺(tái)

? ? ? ? ? ? ? ? })

? ? ? ? ? ? ? ? .then((res) = {

? ? ? ? ? ? ? ? ? ? //獲取后臺(tái)返回的參數(shù)

? ? ? ? ? ? ? ? ? ? this.appId = res.data.appId

? ? ? ? ? ? ? ? ? ? this.nonce = res.data.nonce

? ? ? ? ? ? ? ? ? ? this.signature = res.data.signature

? ? ? ? ? ? ? ? ? ? this.timestamp = res.data.timestamp

? ? ? ? ? ? ? ? ? ? //調(diào)取微信官方config接口

? ? ? ? ? ? ? ? ? ? wx.config({

? ? ? ? ? ? ? ? ? ? debug: false, // 開啟調(diào)試模式,調(diào)用的所有api的返回值會(huì)在客戶端alert出來,若要查看傳入的參數(shù),可以在pc端打開,參數(shù)信息會(huì)通過log打出,僅在pc端時(shí)才會(huì)打印。

? ? ? ? ? ? ? ? ? ? appId: this.appId, // 必填,公眾號(hào)的唯一標(biāo)識(shí)

? ? ? ? ? ? ? ? ? ? timestamp: this.timestamp, // 必填,生成簽名的時(shí)間戳

? ? ? ? ? ? ? ? ? ? nonceStr: this.nonce, // 必填,生成簽名的隨機(jī)串

? ? ? ? ? ? ? ? ? ? signature: this.signature,// 必填,簽名

? ? ? ? ? ? ? ? ? ? jsApiList: ['chooseWXPay'] // 必填,需要使用的JS接口列表

? ? ? ? ? ? ? ? });

? ? ? ? ? ? ? ? })

? ? ? ? ? ? ? ? .catch((error) = {

? ? ? ? ? ? ? ? ? ? console.log(error);

? ? ? ? ? ? ? ? });

? ? ? ? ? ? ? ? //調(diào)取后臺(tái)接口,獲取下單信息,并用wx.ready調(diào)取微信支付方法

? ? ? ? ? ? ? ? var id = JSON.parse(localStorage.getItem('token')).id

? ? ? ? ? ? ? ? http.get(`${api.api}/orders?id=${id}money=${this.total*100}type=${0}count=${this.date}acount=${this.count}`)

? ? ? ? ? ? ? ? .then((res) = {

? ? ? ? ? ? ? ? ? ? console.log(res)

? ? ? ? ? ? ? ? ? ? wx.ready(()={

? ? ? ? ? ? ? ? ? ? ? ? wx.chooseWXPay({

? ? ? ? ? ? ? ? ? ? ? ? ? ? timestamp: res.data.timeStamp, // 支付簽名時(shí)間戳,注意微信jssdk中的所有使用timestamp字段均為小寫。但最新版的支付后臺(tái)生成簽名使用的timeStamp字段名需大寫其中的S字符

? ? ? ? ? ? ? ? ? ? ? ? ? ? nonceStr: res.data.nonceStr, // 支付簽名隨機(jī)串,不長(zhǎng)于 32 位

? ? ? ? ? ? ? ? ? ? ? ? ? ? package: res.data.package, // 統(tǒng)一支付接口返回的prepay_id參數(shù)值,提交格式如:prepay_id=\*\*\*)

? ? ? ? ? ? ? ? ? ? ? ? ? ? signType: 'MD5', // 簽名方式,默認(rèn)為'SHA1',使用新版支付需傳入'MD5'

? ? ? ? ? ? ? ? ? ? ? ? ? ? paySign: res.data.paySign, // 支付簽名

? ? ? ? ? ? ? ? ? ? ? ? ? ? success:? (res) = {

? ? ? ? ? ? ? ? ? ? ? ? ? ? // 支付成功后的回調(diào)函數(shù)

? ? ? ? ? ? ? ? ? ? ? ? ? ? this.$router.push({path:'/creditcard'})

? ? ? ? ? ? ? ? ? ? ? ? ? ? }

? ? ? ? ? ? ? ? ? ? ? ? });

? ? ? ? ? ? ? ? ? ? })

? ? ? ? ? ? ? ? })

? ? ? ? ? ? ? ? .catch((error) = {

? ? ? ? ? ? ? ? ? ? console.log(error);

? ? ? ? ? ? ? ? });

微信支付后端篇

微信支付系列文章

微信支付-java后端實(shí)現(xiàn)

微信支付-vue 前端實(shí)現(xiàn)

java demo: 下載地址文章底部

技術(shù)棧

Spring boot

java

XML (微信在http協(xié)議中數(shù)據(jù)傳輸方案)

MD5 簽名

微信支付術(shù)語

openid (OpenID是公眾號(hào)一對(duì)一對(duì)應(yīng)用戶身份的標(biāo)識(shí))

app_id (公眾號(hào)id,登錄微信公眾號(hào)–開發(fā)–基本配置中獲得;)

key (收款商戶后臺(tái)進(jìn)行配置,登錄微信商戶平臺(tái)–賬戶中心–API安全-設(shè)置秘鑰,設(shè)置32位key值;)

mch_id (收款商家商戶號(hào);)

certPath (API證書, 登錄微信商戶平臺(tái)–賬戶中心-API安全-下載證書)

后端流程

服務(wù)端需要的核心操作, 總共分為以下幾步:

統(tǒng)一下單

前端調(diào)起微信支付必要參數(shù) (需加密)

訂單結(jié)果主動(dòng)通知 (回調(diào)接口)

查詢訂單結(jié)果

結(jié)束訂單支付接口(關(guān)閉訂單,支付訂單關(guān)閉)

代碼

微信總共支持多種語言的sdk, 在官網(wǎng)可以下載例子, java程序也可以引入微信支付的sdk包, 但是github上的sdk已經(jīng)很久沒有更新了, 最好的選擇, 也是我的選擇, 在官網(wǎng)上下載sdk項(xiàng)目, 將其中所有java類copy到自己的項(xiàng)目中.

官網(wǎng)sdk下載目錄

鏈接: 商戶平臺(tái)首頁

#### 根據(jù)微信sdk生成配置類 WXPayConfig

創(chuàng)建IWxPayConfig.class, 繼承sdk WXPayConfig.class, 實(shí)現(xiàn)sdk中部分抽象方法, 讀取本地證書, 加載到配置類中.

package core.com.chidori.wxpay;

import core.com.wxpay.IWXPayDomain;

import core.com.wxpay.WXPayConfig;

import core.com.wxpay.WXPayConstants;

import org.springframework.beans.factory.annotation.Value;

import org.springframework.stereotype.Service;

import java.io.ByteArrayInputStream;

import java.io.File;

import java.io.FileInputStream;

import java.io.InputStream;

@Service

public class IWxPayConfig extends WXPayConfig { // 繼承sdk WXPayConfig 實(shí)現(xiàn)sdk中部分抽象方法

private byte[] certData;

@Value("${vendor.wx.config.app_id}")

private String app_id;

@Value("${vendor.wx.pay.key}")

private String wx_pay_key;

@Value("${vendor.wx.pay.mch_id}")

private String wx_pay_mch_id;

public IWxPayConfig() throws Exception { // 構(gòu)造方法讀取證書, 通過getCertStream 可以使sdk獲取到證書

String certPath = "/data/config/chidori/apiclient_cert.p12";

File file = new File(certPath);

InputStream certStream = new FileInputStream(file);

this.certData = new byte[(int) file.length()];

certStream.read(this.certData);

certStream.close();

}

@Override

public String getAppID() {

return app_id;

}

@Override

public String getMchID() {

return wx_pay_mch_id;

}

@Override

public String getKey() {

return wx_pay_key;

}

@Override

public InputStream getCertStream() {

return new ByteArrayInputStream(this.certData);

}

@Override

public IWXPayDomain getWXPayDomain() { // 這個(gè)方法需要這樣實(shí)現(xiàn), 否則無法正常初始化WXPay

IWXPayDomain iwxPayDomain = new IWXPayDomain() {

@Override

public void report(String domain, long elapsedTimeMillis, Exception ex) {

}

@Override

public DomainInfo getDomain(WXPayConfig config) {

return new IWXPayDomain.DomainInfo(WXPayConstants.DOMAIN_API, true);

}

};

return iwxPayDomain;

}

}

發(fā)起統(tǒng)一下單 AND 前端調(diào)起微信支付必要參數(shù)

// 發(fā)起微信支付

WXPay wxpay = null;

Map result = new HashMap();

try {

// ******************************************

//

// 統(tǒng)一下單

//

// ******************************************

wxpay = new WXPay(iWxPayConfig); // *** 注入自己實(shí)現(xiàn)的微信配置類, 創(chuàng)建WXPay核心類, WXPay 包括統(tǒng)一下單接口

Map data = new HashMap ();

data.put("body", "訂單詳情");

data.put("out_trade_no", transOrder.getGlobalOrderId()); // 訂單唯一編號(hào), 不允許重復(fù)

data.put("total_fee", String.valueOf(transOrder.getOrderAmount().multiply(new BigDecimal(100)).intValue())); // 訂單金額, 單位分

data.put("spbill_create_ip", "192.168.31.166"); // 下單ip

data.put("openid", openId); // 微信公眾號(hào)統(tǒng)一標(biāo)示openid

data.put("notify_url", ""); // 訂單結(jié)果通知, 微信主動(dòng)回調(diào)此接口

data.put("trade_type", "JSAPI"); // 固定填寫

logger.info("發(fā)起微信支付下單接口, request={}", data);

Map response = wxpay.unifiedOrder(data); // 微信sdk集成方法, 統(tǒng)一下單接口unifiedOrder, 此處請(qǐng)求 MD5加密 加密方式

logger.info("微信支付下單成功, 返回值 response={}", response);

String returnCode = response.get("return_code");

if (!SUCCESS.equals(returnCode)) {

return null;

}

String resultCode = response.get("result_code");

if (!SUCCESS.equals(resultCode)) {

return null;

}

String prepay_id = response.get("prepay_id");

if (prepay_id == null) {

return null;

}

// ******************************************

//

// 前端調(diào)起微信支付必要參數(shù)

//

// ******************************************

String packages = "prepay_id=" + prepay_id;

Map wxPayMap = new HashMap ();

wxPayMap.put("appId", iWxPayConfig.getAppID());

wxPayMap.put("timeStamp", String.valueOf(Utility.getCurrentTimeStamp()));

wxPayMap.put("nonceStr", Utility.generateUUID());

wxPayMap.put("package", packages);

wxPayMap.put("signType", "MD5");

// 加密串中包括 appId timeStamp nonceStr package signType 5個(gè)參數(shù), 通過sdk WXPayUtil類加密, 注意, 此處使用 MD5加密 方式

String sign = WXPayUtil.generateSignature(wxPayMap, iWxPayConfig.getKey());

// ******************************************

//

// 返回給前端調(diào)起微信支付的必要參數(shù)

//

// ******************************************

result.put("prepay_id", prepay_id);

result.put("sign", sign);

result.putAll(wxPayMap);

return result;

} catch (Exception e) {

}

回調(diào)結(jié)果處理

核心是支付訂單回調(diào)時(shí), 需校驗(yàn)加密簽名是否匹配, 防止出現(xiàn)模擬成功通知

@RequestMapping(value = "/payCallback", method = RequestMethod.POST)

public String payCallback(HttpServletRequest request, HttpServletResponse response) {

logger.info("進(jìn)入微信支付異步通知");

String resXml="";

try{

//

InputStream is = request.getInputStream();

//將InputStream轉(zhuǎn)換成String

BufferedReader reader = new BufferedReader(new InputStreamReader(is));

StringBuilder sb = new StringBuilder();

String line = null;

try {

while ((line = reader.readLine()) != null) {

sb.append(line + " ");

}

} catch (IOException e) {

e.printStackTrace();

} finally {

try {

is.close();

} catch (IOException e) {

e.printStackTrace();

}

}

resXml=sb.toString();

logger.info("微信支付異步通知請(qǐng)求包: {}", resXml);

return wxTicketService.payBack(resXml);

}catch (Exception e){

logger.error("微信支付回調(diào)通知失敗",e);

String result = " ";

return result;

}

}

@Override

public String payBack(String notifyData) {

logger.info("payBack() start, notifyData={}", notifyData);

String xmlBack="";

Map notifyMap = null;

try {

WXPay wxpay = new WXPay(iWxPayConfig);

notifyMap = WXPayUtil.xmlToMap(notifyData); // 轉(zhuǎn)換成map

if (wxpay.isPayResultNotifySignatureValid(notifyMap)) {

// 簽名正確

// 進(jìn)行處理。

// 注意特殊情況:訂單已經(jīng)退款,但收到了支付結(jié)果成功的通知,不應(yīng)把商戶側(cè)訂單狀態(tài)從退款改成支付成功

String return_code = notifyMap.get("return_code");//狀態(tài)

String out_trade_no = notifyMap.get("out_trade_no");//訂單號(hào)

if (out_trade_no == null) {

logger.info("微信支付回調(diào)失敗訂單號(hào): {}", notifyMap);

xmlBack = " ";

return xmlBack;

}

// 業(yè)務(wù)邏輯處理 ****************************

logger.info("微信支付回調(diào)成功訂單號(hào): {}", notifyMap);

xmlBack = " ";

return xmlBack;

} else {

logger.error("微信支付回調(diào)通知簽名錯(cuò)誤");

xmlBack = " ";

return xmlBack;

}

} catch (Exception e) {

logger.error("微信支付回調(diào)通知失敗",e);

xmlBack = " ";

}

return xmlBack;

}

統(tǒng)一下單的簽名和后續(xù)前端拉取微信支付的簽名需要統(tǒng)一, 也就是都采用MD5加密, 如果2者不同, 會(huì)導(dǎo)致前端拉取微信支付fail, 這是一個(gè)巨大的坑, 因?yàn)檫@個(gè)原因調(diào)試了好久, 微信在文檔里沒有明確標(biāo)出統(tǒng)一下單的簽名校驗(yàn)方式 需要和前端拉取微信支付的簽名校驗(yàn)保持一致.

微信sdk里的源碼需要針對(duì)這個(gè)問題調(diào)整一下, 調(diào)整如下:

WXPay類需要修改下加密判斷,在WXPay構(gòu)造方法中,調(diào)整如下

public WXPay(final WXPayConfig config, final String notifyUrl, final boolean autoReport, final boolean useSandbox) throws Exception {

this.config = config;

this.notifyUrl = notifyUrl;

this.autoReport = autoReport;

this.useSandbox = useSandbox;

if (useSandbox) {

this.signType = SignType.MD5; // 沙箱環(huán)境

}

else {

this.signType = SignType.MD5; // 將這里的加密方式修改為SignType.MD5, 保持跟前端吊起微信加密方式保持一致

}

this.wxPayRequest = new WXPayRequest(config);

}

結(jié)束語

做完以后, 微信支付的后端邏輯還是很清晰的, 但是在開發(fā)過程中很煎熬, 不清楚每個(gè)專業(yè)術(shù)語在微信哪里配置, 加密方式亂的很

如何使用golang實(shí)現(xiàn)微信支付的服務(wù)端

這類專業(yè)的技術(shù)問題涉及到了代碼的層面,您在網(wǎng)上詢問肯定是得不到完美的解決的,建議您可以下載一下開發(fā)者文檔

該文檔在您申請(qǐng)了微信商家之后就可以下載的

然后根據(jù)文檔里面的技術(shù)規(guī)范進(jìn)行調(diào)整和開發(fā)

微信網(wǎng)頁支付應(yīng)該怎么調(diào)用微信接口

1、申請(qǐng)微信支付。小程序認(rèn)證以后,可以在小程序后臺(tái),微信支付菜單欄,申請(qǐng)微信支付。填寫企業(yè)信息和對(duì)公賬戶,微信支付會(huì)打一筆隨機(jī)金額到對(duì)公賬戶,輸入金額完成驗(yàn)證后,在線簽署遷移,即完成了微信支付的申請(qǐng)流程。

微信支付申請(qǐng)完,會(huì)發(fā)送微信支付商戶號(hào),商戶平臺(tái)用戶名密碼等信息到注冊(cè)者郵箱。

2、配置小程序密鑰。小程序后臺(tái)設(shè)置頁,點(diǎn)擊生成,管理員驗(yàn)證二維碼后,會(huì)隨機(jī)生成AppSecret。請(qǐng)妥善保管好Appsecret,不要明文存儲(chǔ)于服務(wù)器,AppSecret用于和微信服務(wù)器交互。比如獲取用戶的openid接口就需要用到.

3、設(shè)置密鑰和下載證書

用申請(qǐng)微信支付獲得的用戶名和密碼,登錄商戶平臺(tái)(pay.weixin.qq.com),在賬戶中心,API安全中下載證書和設(shè)置密鑰。

密鑰是32位,設(shè)置以后需要妥善保管,因?yàn)闊o法查看密鑰,所有微信支付相關(guān)的接口都會(huì)使用這個(gè)密鑰加密。

4、配置HTTPS服務(wù)器 小程序的前端是使用微信提供的框架開發(fā),但是后臺(tái)依然是開發(fā)者自己的服務(wù)器。小程序發(fā)起的是HTTPS請(qǐng)求,意味著小程序開發(fā)者必須配置HTTPS服務(wù)器。配置HTTPS服務(wù)器之前,先要獲取證書,證書可以向相關(guān)機(jī)構(gòu)購買,騰訊云目前可以向用戶提供免費(fèi)的證書。

5、微信支付流程

微信支付有多種支付方式,包括刷卡支付,公眾號(hào)支付,掃碼支付,APP支付,所有微信支付的接口都可以到官方找到。小程序是在微信里調(diào)起支付的,其實(shí)是公眾號(hào)支付,關(guān)于公眾號(hào)支付的詳細(xì)文檔可以這里找到:。所有公眾號(hào)支付相關(guān)的鏈接都可以在此鏈接找到,開發(fā)者首先需要大概了解這些接口。

6、小程序調(diào)起微信支付,用的是小程序微信支付接口wx.requestPayment,該接口的詳細(xì)描述可以查看小程序的微信支付API。

這個(gè)接口中的package和timeStamp參數(shù)是從開發(fā)者的第三方服務(wù)器返回的,package是第三方服務(wù)器從統(tǒng)一下單接口回復(fù)中獲得。

接口中其他的參數(shù),appId,noceStr,signType以及paySign則由小程序這邊存儲(chǔ)或者計(jì)算而得。

微信H5網(wǎng)頁公眾號(hào)外支付接入攻略demo

最近在某C論壇中發(fā)現(xiàn)有很多的網(wǎng)友在提問和求助自己的網(wǎng)站賣東西,希望可以接入一個(gè)支付接口,可以在用戶購買后直接在網(wǎng)頁上支付。

我在這里發(fā)表一下,網(wǎng)站如果希望用戶通過在線付款的方式進(jìn)行付款,就需要申請(qǐng)一種或多種用于進(jìn)行人民幣支付的支付接口。在線支付接口提供商可以是某個(gè)商業(yè)銀行、銀聯(lián)在線支付或者支付寶、微信支付等第三方的支付機(jī)構(gòu)。

這其中微信支付的申請(qǐng)是比較簡(jiǎn)單的

下面是對(duì)申請(qǐng)微信支付接口做簡(jiǎn)單介紹:

最常用的第三方支付機(jī)構(gòu)如新浪支付微博錢包、支付寶、財(cái)付通、快錢、環(huán)迅支付、易寶支付等。他們擁有中國人民銀行頒發(fā)的非金融機(jī)構(gòu)第三方支付許可證。可以為用戶提供支付業(yè)務(wù)服務(wù),如果用第三方支付首選微信支付,簡(jiǎn)單易操作。

網(wǎng)站接入微信支付實(shí)現(xiàn)在線支付功能,通常有兩種方式,一種是在微信內(nèi)部訪問網(wǎng)站,然后下單支付;另一種是在微信外部訪問網(wǎng)站,然后下單支付。

在微信內(nèi)部,我們可以通過在公眾號(hào)聊天窗口發(fā)送訪問自己網(wǎng)站鏈接,或者將網(wǎng)站鏈接發(fā)在自己的朋友圈,微信用戶都可以在進(jìn)入下單,點(diǎn)擊下單就會(huì)喚起微信H5支付,確認(rèn)金額,輸入支付密碼即可完成交易。這個(gè)是公眾號(hào)支付申請(qǐng),之前就已經(jīng)開放申請(qǐng)了。針對(duì)微信內(nèi)場(chǎng)景支付

在微信外部,我們可以通過觸屏手機(jī)上自帶的瀏覽器進(jìn)入網(wǎng)站,喚起微信支付。這個(gè)是微信H5支付申請(qǐng),是在近期開放的。針對(duì)的是企業(yè)公司的商城網(wǎng)站場(chǎng)景支付。

所以想獲得微信支付H5支付接口:

1首先要有公司資質(zhì)例如營業(yè)執(zhí)照、公司對(duì)公賬戶、網(wǎng)站備案域名、合法居民身份證;

2這些都需要自申請(qǐng)中上傳給微信人工審核;

3審核通過后就可以獲得微信支付商戶平臺(tái)的賬戶和密碼

4在商戶平臺(tái)里找到申請(qǐng)入口

5進(jìn)入申請(qǐng)界面填入H5相關(guān)設(shè)置信息,注意填入的信息一定要和自己的銷售商品情況保持一致。

6提交,等待審核,2個(gè)工作日左右,審核通過馬上獲得支付接口

7再將接口和網(wǎng)站接入即可。

對(duì)新接觸微信支付的企業(yè)來說,申請(qǐng)微信支付還是一個(gè)比較頭疼的事情,遇到申請(qǐng)失敗或被駁回、沒有備案的公司網(wǎng)站網(wǎng)址域名、需要網(wǎng)站授權(quán)函、類目不會(huì)選擇導(dǎo)致未通過,都可以通過黑河馬進(jìn)行協(xié)助解決,代申請(qǐng)包通過。

標(biāo)題名稱:go語言的微信支付接口,go語言 接口
文章來源:http://chinadenli.net/article30/dsgicpo.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供自適應(yīng)網(wǎng)站網(wǎng)站導(dǎo)航企業(yè)網(wǎng)站制作網(wǎng)站策劃品牌網(wǎng)站設(shè)計(jì)定制網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站