国产 无码 综合区,色欲AV无码国产永久播放,无码天堂亚洲国产AV,国产日韩欧美女同一区二区

對(duì)接微信支付接口

這篇具有很好參考價(jià)值的文章主要介紹了對(duì)接微信支付接口。希望對(duì)大家有所幫助。如果存在錯(cuò)誤或未考慮完全的地方,請(qǐng)大家不吝賜教,您也可以點(diǎn)擊"舉報(bào)違法"按鈕提交疑問(wèn)。

SpringBoot中對(duì)接微信支付接口

1.微信支付開(kāi)發(fā)文檔

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

1.準(zhǔn)備工作:

在微信上申請(qǐng)服務(wù)號(hào)類型的公眾號(hào),從公眾號(hào)獲取以下數(shù)據(jù)

  1. appid:微信公眾賬號(hào)或開(kāi)放平臺(tái)APP的唯一標(biāo)識(shí)

  2. mch_id:商戶號(hào) (配置文件中的partner)

  3. partnerkey:商戶密鑰

    2.根據(jù)項(xiàng)目需求選擇適合的支付方式,本例使用Native支付方式

微信支付api,微信,java,開(kāi)發(fā)語(yǔ)言

點(diǎn)擊查看文檔->API列表

微信支付api,微信,java,開(kāi)發(fā)語(yǔ)言

開(kāi)發(fā)步驟

引入依賴

<dependency>
    <groupId>com.github.wxpay</groupId>
    <artifactId>wxpay-sdk</artifactId>
    <version>0.0.3</version>
</dependency>

修改application.proerties配置文件

#關(guān)聯(lián)的公眾號(hào)appid #商戶號(hào) #商戶key
weixin.appid=wx34bb2aa123de3dcd
weixin.partner=1611167878
weixin.partnerkey=4ca478a4580794e2f7cf67881cb21dd4b1

參數(shù)注入:

@Component
public class PropertiesUtils implements InitializingBean {

    @Value("${weixin.appid}")
    private String appid;
    @Value("${weixin.partner}")
    private String partner;
    @Value("${weixin.partnerkey}")
    private String partnerkey;

    public static String APPID;
    public static String PARTNER;
    public static String PARTNERKEY;
    
    @Override
    public void afterPropertiesSet() throws Exception {
        APPID = appid;
        PARTNER = partner;
        PARTNERKEY = partnerkey;
    }
}

HttpClient工具類:

用于發(fā)送http請(qǐng)求,可直接復(fù)制

/**
 * http請(qǐng)求客戶端
 */
public class HttpClient {
    private String url;
    private Map<String, String> param;
    private int statusCode;
    private String content;
    private String xmlParam;
    private boolean isHttps;
    private boolean isCert = false;
    //證書(shū)密碼 微信商戶號(hào)(mch_id)
    private String certPassword;
    public boolean isHttps() {
        return isHttps;
    }
    public void setHttps(boolean isHttps) {
        this.isHttps = isHttps;
    }
    public boolean isCert() {
        return isCert;
    }
    public void setCert(boolean cert) {
        isCert = cert;
    }
    public String getXmlParam() {
        return xmlParam;
    }
    public void setXmlParam(String xmlParam) {
        this.xmlParam = xmlParam;
    }
    public HttpClient(String url, Map<String, String> param) {
        this.url = url;
        this.param = param;
    }
    public HttpClient(String url) {
        this.url = url;
    }
    public String getCertPassword() {
        return certPassword;
    }
    public void setCertPassword(String certPassword) {
        this.certPassword = certPassword;
    }
    public void setParameter(Map<String, String> map) {
        param = map;
    }
    public void addParameter(String key, String value) {
        if (param == null)
            param = new HashMap<String, String>();
        param.put(key, value);
    }
    public void post() throws ClientProtocolException, IOException {
        HttpPost http = new HttpPost(url);
        setEntity(http);
        execute(http);
    }
    public void put() throws ClientProtocolException, IOException {
        HttpPut http = new HttpPut(url);
        setEntity(http);
        execute(http);
    }
    public void get() throws ClientProtocolException, IOException {
        if (param != null) {
            StringBuilder url = new StringBuilder(this.url);
            boolean isFirst = true;
            for (String key : param.keySet()) {
                if (isFirst)
                    url.append("?");
                else
                    url.append("&");
                url.append(key).append("=").append(param.get(key));
            }
            this.url = url.toString();
        }
        HttpGet http = new HttpGet(url);
        execute(http);
    }
    /**
    * set http post,put param
    */
    private void setEntity(HttpEntityEnclosingRequestBase http) {
        if (param != null) {
            List<NameValuePair> nvps = new LinkedList<NameValuePair>();
            for (String key : param.keySet())
                nvps.add(new BasicNameValuePair(key, param.get(key))); // 參數(shù)
            http.setEntity(new UrlEncodedFormEntity(nvps, Consts.UTF_8)); // 設(shè)置參數(shù)
        }
        if (xmlParam != null) {
            http.setEntity(new StringEntity(xmlParam, Consts.UTF_8));
        }
    }
    private void execute(HttpUriRequest http) throws ClientProtocolException,
    IOException {
        CloseableHttpClient httpClient = null;
        try {
            if (isHttps) {
                if(isCert) {
                    FileInputStream inputStream = new FileInputStream(new File(ConstantPropertiesUtils.CERT));
                    KeyStore keystore = KeyStore.getInstance("PKCS12");
                    char[] partnerId2charArray = certPassword.toCharArray();
                    keystore.load(inputStream, partnerId2charArray);
                    SSLContext sslContext = SSLContexts.custom().loadKeyMaterial(keystore, partnerId2charArray).build();
                    SSLConnectionSocketFactory sslsf =
                        new SSLConnectionSocketFactory(sslContext,
                                                       new String[] { "TLSv1" },
                                                       null,
                                                       SSLConnectionSocketFactory.BROWSER_COMPATIBLE_HOSTNAME_VERIFIER);
                    httpClient = HttpClients.custom().setSSLSocketFactory(sslsf).build();
                } else {
                    SSLContext sslContext = new SSLContextBuilder()
                        .loadTrustMaterial(null, new TrustStrategy() {
                            // 信任所有
                            public boolean isTrusted(X509Certificate[] chain,
                                                     String authType)
                                throws CertificateException {
                                return true;
                            }
                        }).build();
                    SSLConnectionSocketFactory sslsf = new SSLConnectionSocketFactory(
                        sslContext);
                    httpClient = HttpClients.custom().setSSLSocketFactory(sslsf)
                        .build();
                }
            } else {
                httpClient = HttpClients.createDefault();
            }
            CloseableHttpResponse response = httpClient.execute(http);
            try {
                if (response != null) {
                    if (response.getStatusLine() != null)
                        statusCode = response.getStatusLine().getStatusCode();
                    HttpEntity entity = response.getEntity();
                    // 響應(yīng)內(nèi)容
                    content = EntityUtils.toString(entity, Consts.UTF_8);
                }
            } finally {
                response.close();
            }
        } catch (Exception e) {
            e.printStackTrace();
        } finally {
            httpClient.close();
        }
    }
    public int getStatusCode() {
        return statusCode;
    }
    public String getContent() throws ParseException, IOException {
        return content;
    }
}

到此準(zhǔn)備工作結(jié)束,剩下的就是參考微信支付開(kāi)發(fā)文檔,提供微信支付接口所需參數(shù)和獲取請(qǐng)求結(jié)果,從結(jié)果中取出我們所需的數(shù)據(jù)

準(zhǔn)備微信支付所需參數(shù)

//對(duì)接微信支付
        //組裝數(shù)據(jù)
        Map<String, String> paramMap = new HashedMap<>();
        paramMap.put("appid", PropertiesUtils.APPID); //公眾號(hào)appid
        paramMap.put("mch_id",PropertiesUtils.PARTNER); //商戶號(hào)
        paramMap.put("out_trade_no",orderInfo.getOutTradeNo());  //商戶訂單號(hào)
        paramMap.put("nonce_str", WXPayUtil.generateNonceStr()); //隨機(jī)字符串
       String object = orderInfo.getReserveDate()+"就診"+ orderInfo.getDepname();
        paramMap.put("body",object); //商品描述
        //paramMap.put("total_fee", order.getAmount().multiply(new BigDecimal("100")).longValue()+"");
        paramMap.put("total_fee","1"); //支付金額
        paramMap.put("spbill_create_ip","127.0.0.1"); //用戶的客戶端IP
        paramMap.put("notify_url", "https://2495161sb6.goho.co/api/order/weixinPay/weixinNotify");//微信支付結(jié)果通知的回調(diào)地址
        paramMap.put("trade_type", "NATIVE"); //交易類型

: total_fee 屬性為支付金額,單位是分

微信支付接口地址: https://api.mch.weixin.qq.com/pay/unifiedorder

調(diào)用接口,發(fā)送Http請(qǐng)求

//對(duì)接微信支付
HttpClient httpClient = new HttpClient("https://api.mch.weixin.qq.com/pay/unifiedorder");
     httpClient.setXmlParam(WXPayUtil.generateSignedXml(paramMap,ConstantPropertiesUtils.PARTNERKEY));
//微信接口為https請(qǐng)求,告訴httpClient改請(qǐng)求為https
httpClient.setHttps(true);
httpClient.post();

接收返回值,獲取所需數(shù)據(jù)

 //獲取響應(yīng)數(shù)據(jù)
  String content = httpClient.getContent();
  Map<String, String> resultMap = WXPayUtil.xmlToMap(content);
  //以下字段在return_code和result_code都為SUCCESS的時(shí)候有返回
  if(resultMap.get("return_code").equals("SUCCESS")&&resultMap.get("result_code").equals("SUCCESS")) {
     map = new HashMap<>();
     map.put("orderId", orderId); //訂單id
     map.put("totalFee", orderInfo.getAmount()); 
     map.put("resultCode", resultMap.get("result_code"));
     map.put("codeUrl", resultMap.get("code_url")); //二維碼鏈接
            }

查詢訂單退款等操作參考下單即可

map = new HashMap<>();
map.put(“orderId”, orderId); //訂單id
map.put(“totalFee”, orderInfo.getAmount());
map.put(“resultCode”, resultMap.get(“result_code”));
map.put(“codeUrl”, resultMap.get(“code_url”)); //二維碼鏈接
}文章來(lái)源地址http://www.zghlxwxcb.cn/news/detail-548045.html


查詢訂單退款等操作參考下單即可

到了這里,關(guān)于對(duì)接微信支付接口的文章就介紹完了。如果您還想了解更多內(nèi)容,請(qǐng)?jiān)谟疑辖撬阉鱐OY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!

本文來(lái)自互聯(lián)網(wǎng)用戶投稿,該文觀點(diǎn)僅代表作者本人,不代表本站立場(chǎng)。本站僅提供信息存儲(chǔ)空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如若轉(zhuǎn)載,請(qǐng)注明出處: 如若內(nèi)容造成侵權(quán)/違法違規(guī)/事實(shí)不符,請(qǐng)點(diǎn)擊違法舉報(bào)進(jìn)行投訴反饋,一經(jīng)查實(shí),立即刪除!

領(lǐng)支付寶紅包贊助服務(wù)器費(fèi)用

相關(guān)文章

  • 微信小程序支付-java對(duì)接微信

    ?一共是兩個(gè)方法: 一個(gè)方法后臺(tái)生成預(yù)支付訂單,得到預(yù)支付交易會(huì)話標(biāo)識(shí)prepay_id,傳給前端,讓前端調(diào)起小程序支付; 一個(gè)是支付回調(diào) 目錄 一、生成預(yù)支付訂單? 注意: 二、 支付回調(diào) ? ? ? ? 封裝參數(shù)向微信發(fā)送生成預(yù)支付交易單請(qǐng)求,微信會(huì)返回一個(gè)prepay_id,再將

    2024年02月12日
    瀏覽(20)
  • SpringBoot對(duì)接微信小程序支付功能開(kāi)發(fā)(二,支付回調(diào)功能)

    SpringBoot對(duì)接微信小程序支付功能開(kāi)發(fā)(二,支付回調(diào)功能)

    接著上一篇: SpringBoot對(duì)接微信小程序支付功能開(kāi)發(fā)(一,下單功能) 在上一篇下單功能中我們有傳支付結(jié)果回調(diào)地址。 下面是回調(diào)接口實(shí)現(xiàn) 根據(jù)官網(wǎng)給的參數(shù)進(jìn)行業(yè)務(wù)處理 這就完成了,微信支付回調(diào)你的地址,并且把支付的信息傳進(jìn)來(lái),剩下就要根據(jù)自己業(yè)務(wù)進(jìn)行操作。

    2024年02月11日
    瀏覽(62)
  • Java對(duì)接微信支付(史上最詳細(xì))

    本文將介紹如何使用Java對(duì)接微信支付,包括獲取支付參數(shù)、支付回調(diào)處理等步驟。本文適用于已經(jīng)熟悉微信支付基本原理的讀者。 JDK 1.8 Maven Spring Boot 2.x 微信支付開(kāi)發(fā)文檔 為了進(jìn)行支付,我們需要先獲取微信支付的參數(shù)信息,包括appid、商戶id、支付密鑰等。 配置文件 我們

    2024年02月15日
    瀏覽(30)
  • SpringBoot對(duì)接微信小程序支付功能開(kāi)發(fā)(一,下單功能)

    1,接入前準(zhǔn)備: 接入模式選擇直連模式; 申請(qǐng)小程序,得到APPID,并開(kāi)通微信支付; 申請(qǐng)微信商戶號(hào),得到mchid,并綁定APPID; 配置商戶API key,下載并配置商戶證書(shū),根據(jù)微信官方文檔操作:https://pay.weixin.qq.com/wiki/doc/apiv3/open/pay/chapter2_8_1.shtml 上面都配置完之后會(huì)得到:小

    2024年02月10日
    瀏覽(31)
  • Python對(duì)接微信小程序V3接口進(jìn)行支付,并使用uwsgi+nginx+django進(jìn)行https部署

    網(wǎng)上找了很多教程,但是很亂很雜,并且教程資源很少且說(shuō)的詳細(xì)。這里就記錄一下分享給大家 共分為以下幾個(gè)步驟: 目錄 一、開(kāi)始前準(zhǔn)備信息 二、使用前端code獲取用戶的openid 三、對(duì)接小程序v3接口下單 四、小程序支付的回調(diào) 五、安裝并啟動(dòng)uwsgi 六、安裝并啟動(dòng)nginx 七、

    2024年02月12日
    瀏覽(27)
  • weixin-java-pay對(duì)接微信V3支付記錄

    https://github.com/binarywang/weixin-java-pay-demo 這個(gè)demo里, 沒(méi)有v3版本的配置, 這里記錄一下 v3支付, 相對(duì)之前的版本來(lái)說(shuō), 更為安全, 也相對(duì)繁瑣一些, 而且請(qǐng)求和響應(yīng)都使用了json格式的數(shù)據(jù) 1. 配置 發(fā)起支付所需的配置有三個(gè)證書(shū)文件, 在商戶后臺(tái)申請(qǐng) apiclient_cert.p12 apiclient_key.pem ap

    2024年02月11日
    瀏覽(25)
  • 【微信支付】java-微信小程序支付-V3接口

    【微信支付】java-微信小程序支付-V3接口

    最開(kāi)始需要在微信支付的官網(wǎng)注冊(cè)一個(gè)商戶; 在管理頁(yè)面中申請(qǐng)關(guān)聯(lián)小程序,通過(guò)小程序的 appid 進(jìn)行關(guān)聯(lián);商戶號(hào)和appid之間是多對(duì)多的關(guān)系 進(jìn)入微信公眾平臺(tái),功能-微信支付中確認(rèn)關(guān)聯(lián) 具體流程請(qǐng)瀏覽官方文檔:接入前準(zhǔn)備-小程序支付 | 微信支付商戶平臺(tái)文檔中心 流程走

    2024年02月06日
    瀏覽(33)
  • java微信支付v3系列——6.微信支付查詢訂單API

    java微信支付v3系列——1.微信支付準(zhǔn)備工作 java微信支付v3系列——2.微信支付基本配置 java微信支付v3系列——3.訂單創(chuàng)建準(zhǔn)備操作 java微信支付v3系列——4.創(chuàng)建訂單的封裝及使用 java微信支付v3系列——5.微信支付成功回調(diào) java微信支付v3系列——6.微信支付查詢訂單API java微信支

    2023年04月08日
    瀏覽(30)
  • 對(duì)接支付通道如何收費(fèi)?支付接口收費(fèi)標(biāo)準(zhǔn)

    對(duì)接支付通道如何收費(fèi)?支付接口收費(fèi)標(biāo)準(zhǔn)

    支付接口收費(fèi)標(biāo)準(zhǔn)是怎樣的 反映到平臺(tái)方來(lái)說(shuō),就是它的盈利模式,是維持企業(yè)生存,到發(fā)展壯大的根本保障。目前第三方支付平臺(tái)費(fèi)用有:手續(xù)費(fèi)、廣告費(fèi)、服務(wù)費(fèi)、沉淀資金的利息收入四種。 1、手續(xù)費(fèi) 手續(xù)費(fèi)是第三方支付平臺(tái)費(fèi)用的最傳統(tǒng)的盈利模式之一。即第三方支

    2024年02月16日
    瀏覽(19)
  • 關(guān)于支付通道,支付接口,支付對(duì)接的100個(gè)名詞解釋

    一份簡(jiǎn)明易懂的支付術(shù)語(yǔ)解釋清單,幫助你更好地理解支付通道、支付接口和支付對(duì)接等相關(guān)概念。 100個(gè)名詞的簡(jiǎn)要解釋: 在線支付:通過(guò)互聯(lián)網(wǎng)實(shí)現(xiàn)的支付方式,包括網(wǎng)銀支付、第三方支付等。 支付網(wǎng)關(guān):連接商戶和支付機(jī)構(gòu)的中間件,實(shí)現(xiàn)支付流程的安全處理和支付數(shù)

    2024年02月04日
    瀏覽(56)

覺(jué)得文章有用就打賞一下文章作者

支付寶掃一掃打賞

博客贊助

微信掃一掃打賞

請(qǐng)作者喝杯咖啡吧~博客贊助

支付寶掃一掃領(lǐng)取紅包,優(yōu)惠每天領(lǐng)

二維碼1

領(lǐng)取紅包

二維碼2

領(lǐng)紅包