[分享] 微信支付中商户对我的用户付款案例

  随着微信支付的普及,愈来愈的APP要求支持微信支付。相信大多数开发者也碰到了这样的需求。百度了一下,你们用到最多的是微信支付中我的对商户的支付业务,而不多有人用到微信中商户对我的付款的业务。我最近就碰到了这样的需求,由于历来没有作过,因此只能查资料,但是百度到的资料不多,而且是过期的东西。又问了圈子里的高手,但是你们都没有作过。没办法只有硬着头皮本身拱吧!还好还好,功夫不负有心人啊!终于被我整明白了,如今得空,拿出来跟你们一块儿分享。php

  首先给你们吃颗定心丸,全部的东西在你没有用过以前,它都是神秘的,当你用过以后,就会发现,也就那么回事。呵呵,开始正题吧!html

  这是企业付款的文档地址,你们须要先仔细看两遍。https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=14_1 (就算有个人指导,也建议你们先看文档,看文档能便于加深你们的理解)json

  整体思路: 一、准备数据;二、把全部的参数链接成一个字符串,而后进行MD5,把MD5获得的一个字符串作为最后一个参;三、把微信提供的安全证,封装到要提交的数据;(商户证书获取方法:https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=4_3 四、经过JAVA程序向微信提供的接口POST数据。微信接口返回处理结果。api

  一、准备数据:所谓的数据就是请求参数,有9个参数是必须的,详细说明见文档(https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=14_2)。下面我给你们提供个人示例代码。安全

  

//配置接口参数,如下是9个必须的参数。

  signParams.put("mch_appid", appid); // 微信分配的公众帐号ID(企业号corpid即为此appId)

  signParams.put("mchid", mchid);// 微信支付分配的商户号

  signParams.put("nonce_str", uuid); // 随机字符串,不长于32位

  signParams.put("partner_trade_no", partner_trade_no); // 商户订单号,需保持惟一性

  signParams.put("openid", openid); // 商户appid下,某用户的openid

  signParams.put("check_name", "NO_CHECK"); // NO_CHECK:不校验真实姓名

  // FORCE_CHECK:强校验真实姓名(未实名认证的用户会校验失败,没法转帐)

  // OPTION_CHECK:针对已实名认证的用户才校验真实姓名(未实名认证用户不校验,能够转帐成功)

  signParams.put("amount", amount); // 企业付款金额,单位为分

  signParams.put("desc", desc); // 企业付款操做说明信息。必填。

  signParams.put("spbill_create_ip", ip); // 调用接口的机器Ip地址

  

  注意map.put()中的key是死的写法,不能改。微信

  二、把全部的参数拼接成一个字符串,而后进行MD5运算,把获得的运算结果,作为签名参数,一块儿POST给接口。详细作法参考文档(https://pay.weixin.qq.com/wiki/doc/api/tools/mch_pay.php?chapter=4_3)并发

  三、为了提升程序的可用性,我把一些受微信影响,会变更的参数写到了配置文件里。配置文件和JAVA文件放在同一目录里就能够了。app

  安全证书这一步是关键,微信为了提升接口的安全性,因此增长了安全证书,以保证资金的安全。JAVA里用到的证书是pkcs12格式,你们按照文档里的提示,去下载相关证书,而后放到本身指定的目录里就能够了。下面是获取证书,并发起POST请求的代码示例。dom

 

 // 获取证书,发送POST请求;

  KeyStore keyStore = KeyStore.getInstance("PKCS12");

  FileInputStream instream = new FileInputStream(new File(config.elementTextTrim("cert_path"))); // 从配置文件里读取证书的路径信息

  keyStore.load(instream, mchid.toCharArray());// 证书密码是商户ID

  instream.close();

  SSLContext sslcontext = SSLContexts.custom().loadKeyMaterial(keyStore, mchid.toCharArray()).build();

  SSLConnectionSocketFactory sslsf = new SSLConnectionSocketFactory(sslcontext, new String[] { "TLSv1" }, null, SSLConnectionSocketFactory.BROWSER_COMPATIBLE_HOSTNAME_VERIFIER);

  CloseableHttpClient httpclient = HttpClients.custom().setSSLSocketFactory(sslsf).build();

  HttpPost httpost = new HttpPost(url); //发起POST请求

  

  四、向接口POST数据 ,得到返回结果。下面是个人示例代码。post

  

CloseableHttpResponse response = httpclient.execute(httpost);

  HttpEntity entity = response.getEntity();

  String jsonStr = EntityUtils.toString(response.getEntity(), "UTF-8");

  EntityUtils.consume(entity);

  // 把返回的字符串解释成DOM节点

  Document dom = DocumentHelper.parseText(jsonStr);

  Element root = dom.getRootElement();

  String returnCode = root.element("result_code").getText(); // 获取返回代码

  if (StringUtils.equals(returnCode, "SUCCESS")) { // 判断返回码为成功仍是失败

  String payment_no = root.element("payment_no").getText(); // 获取支付流水号

  String payment_time = root.element("payment_time").getText(); // 获取支付时间

  map.put("state", returnCode);

  map.put("payment_no", payment_no);

  map.put("payment_time", payment_time);

  return map;

  } else {

  String err_code = root.element("err_code").getText(); // 获取错误代码

  String err_code_des = root.element("err_code_des").getText();// 获取错误描述

  map.put("state", returnCode);// state

  map.put("err_code", err_code);// err_code

  map.put("err_code_des", err_code_des);// err_code_des

  return map;

  }

  

  以上4步,就完成了微信企业付款的业务。

  须要用到的jar包和个人程序示例代码。喜欢拿来就用的伙伴只须要写写配置文件,下载了安全证书,个人程序就能够直接拿来用了。源码地址:http://pan.baidu.com/s/1gfqbVJt

  有问题能够跟帖咨询。

  欢迎你们共同窗习,共同进步。

相关文章
相关标签/搜索