调用微信现金红包接口发放红包

时间:2016-06-25 10:55:58   收藏:0   阅读:339

1.通过code获取到用户的openid.

地址: "https://api.weixin.qq.com/sns/oauth2/access_token?appid=wxid&secret=secret&code="
            + code + "&grant_type=authorization_code";

公众号需获取网页授权获取用户基本信息权限。

引导用户到指定的授权页面

例如:https://open.weixin.qq.com/connect/oauth2/authorize?appid=APPID&redirect_uri=redirect_uri&response_type=code&scope=SCOPE&state=STATE#wechat_redirect

参考文章:http://www.cnblogs.com/ansiboy/p/3755158.html

2.通过openid及用户相关信息向用户发放红包。

      地址:"https://api.mch.weixin.qq.com/mmpaymkttransfers/sendredpack"

需要发放商户号用户openid等相关信息,需要注意的是签名信息与随机字符串

代码如下:

1. public static String createSendRedPackOrderSign(WeixinRedPacket redPack){
            StringBuffer sign = new StringBuffer();
            sign.append("act_name=").append(redPack.getAct_name());
            sign.append("&client_ip=").append(redPack.getClient_ip());
            sign.append("&mch_billno=").append(redPack.getMch_billno());
            sign.append("&mch_id=").append(redPack.getMch_id());
            sign.append("&nonce_str=").append(redPack.getNonce_str());
            sign.append("&re_openid=").append(redPack.getRe_openid());
            sign.append("&remark=").append(redPack.getRemark());
            sign.append("&send_name=").append(redPack.getSend_name());
            sign.append("&total_amount=").append(redPack.getTotal_amount());
            sign.append("&total_num=").append(redPack.getTotal_num());
            sign.append("&wishing=").append(redPack.getWishing());
            sign.append("&wxappid=").append(redPack.getWxappid());
            sign.append("&key=").append("abcdefg123456789abcdefg123456789");
            return DigestUtils.md5Hex(getContentBytes(sign.toString(), "utf-8")).toUpperCase();
        }
      private static String create_nonce_str() {
            return UUID.randomUUID().toString();
        }

 

2.需要注意上传证书及将所有信息发放给微信,这里还需要使用微信给出的开发包,在微信上下载即可。

 

KeyStore keyStore  = KeyStore.getInstance("PKCS12");
           FileInputStream instream = new FileInputStream(new File("D:\\certs\\apiclient_cert.p12"));
           try {
               keyStore.load(instream, "123".toCharArray());//商户号
           } finally {
               instream.close();
           }

           // Trust own CA and all self-signed certs
           SSLContext sslcontext = SSLContexts.custom()
                   .loadKeyMaterial(keyStore, "123".toCharArray())
                   .build();
           // Allow TLSv1 protocol only
           SSLConnectionSocketFactory sslsf = new SSLConnectionSocketFactory(
                   sslcontext,
                   new String[] { "TLSv1" },
                   null,
                   SSLConnectionSocketFactory.BROWSER_COMPATIBLE_HOSTNAME_VERIFIER);
           CloseableHttpClient httpclient = HttpClients.custom()
                   .setSSLSocketFactory(sslsf)
                   .build();
           try {

               HttpPost httppost = new HttpPost("https://api.mch.weixin.qq.com/mmpaymkttransfers/sendredpack");
               StringEntity s = new StringEntity(requestJson,"UTF-8");
               s.setContentEncoding("UTF-8");
               s.setContentType("text/xml");//发送json数据需要设置contentType
               httppost.setEntity(s);
               CloseableHttpResponse resp = httpclient.execute(httppost);
               try {
                   HttpEntity entity = resp.getEntity();

                   if (entity != null) {
                       BufferedReader bufferedReader = new BufferedReader(new InputStreamReader(entity.getContent(),"utf-8"));
                       String text;
                       String xmlString = "";
                       while ((text = bufferedReader.readLine()) != null) {
                           xmlString += text;
                       }
                       
                       //return_code与result_code都为success代表发放红包成功
                       maps = XmlParseUtil.parse(xmlString);
                   }
                   EntityUtils.consume(entity);
               } finally {
                   resp.close();
               }
           } finally {
               httpclient.close();
           }

 

 

微信官方文档地址:https://pay.weixin.qq.com/helper/cashredopenapi_V2.pdf

 

评论(0
© 2014 mamicode.com 版权所有 京ICP备13008772号-2  联系我们:gaon5@hotmail.com
迷上了代码!