java調(diào)用微信現(xiàn)金紅包接口的心得與體會總結(jié)
這幾天看了下之前寫的有關(guān)微信支付的博客,看的人還是挺多的,看了下留言不知道是因?yàn)椴┛蛯懙牟粔蚣?xì)還是什么情況,大多都找我要源碼,我覺得吧程序員還是需要有這么一個思考的過程,因此沒直接給源碼,俗話說“授人以魚不如授人以漁”。因此希望看文章的同時也花一點(diǎn)時間自己親自敲一敲代碼。好了廢話不多說這次來分享微信現(xiàn)金紅包接口的使用。
下面是微信開發(fā)文檔對現(xiàn)金紅包的介紹:
現(xiàn)金紅包,是微信支付商戶平臺提供的營銷工具之一,上線以來深受廣大商戶與用戶的喜愛。商戶可以通過本平臺向微信支付用戶發(fā)放現(xiàn)金紅包。用戶領(lǐng)取紅包后,資金到達(dá)用戶微信支付零錢賬戶,和零錢包的其他資金有一樣的使用出口;若用戶未領(lǐng)取,資金將會在24小時后退回商戶的微信支付賬戶中。
產(chǎn)品意義
微信支付現(xiàn)金紅包因資金的承載方式為現(xiàn)金,一直以來深受用戶的青睞,近年來的春晚中,現(xiàn)金紅包都扮演著重要的角色;在日常運(yùn)營中也為商戶的營銷活動帶來熱烈的反響??偟膩碚f,現(xiàn)金紅包在包括但不僅限于以下場景中發(fā)揮著重要意義:
- ◆ 為企業(yè)拉取新用戶、鞏固老用戶關(guān)系、提升用戶活躍度
- ◆ 結(jié)合巧妙的創(chuàng)意點(diǎn)子,輔以紅包點(diǎn)綴,打造火爆的活動,提升企業(yè)與品牌知名度
- ◆ 結(jié)合企業(yè)運(yùn)營活動,以紅包作為獎品,使你的抽獎、滿送等營銷活動更便利進(jìn)行
- ◆ 同時,除了營銷之外,現(xiàn)金紅包在企業(yè)日常的運(yùn)營中也扮演著重要角色。如:為員工返福利、為供應(yīng)商返利、會員積分/虛擬等級兌現(xiàn)等等
綜上所述微信現(xiàn)金紅包是一種營銷工具,可以通過關(guān)注公眾號、注冊等給用戶發(fā)放增加用戶粘性。這次著重從程序開發(fā)方面分享我的心得體會
一 使用微信現(xiàn)金紅包功能需具備的條件
1 擁有微信商戶平臺且秘鑰證書齊全
2 商戶平太需要有足夠的余額可供使用(不夠可以從商戶平臺使用財(cái)付通充值)
3 有微信支付開發(fā)基礎(chǔ)更佳
二 開發(fā)的重點(diǎn)和難點(diǎn)
1 微信簽名算法
2 httpclient以及證書的使用
3 微信文檔的閱讀(https://pay.weixin.qq.com/wiki/doc/api/tools/cash_coupon.php?chapter=13_4&index=3)
如果有微信h5支付或掃碼支付的童鞋看這一部分的文檔可以說是小菜一碟,理解起來不費(fèi)吹灰之力,同時只要掌握httpclient的知識就萬事俱備了
三 直接擼代碼
public static void sendRedPack(String mch_billno,String openId,String send_name,String total_fee,String total_num,String wishing,String act_name,String remark,String ip) throws Exception{ String non=PayCommonUtil.CreateNoncestr(); SortedMap<Object, Object> p = new TreeMap<Object, Object>(); p.put("nonce_str", non); p.put("mch_billno", mch_billno); p.put("mch_id", ConfigUtil.MCH_ID); p.put("wxappid", ConfigUtil.APPID); p.put("re_openid", openId); p.put("total_amount", total_fee); p.put("total_num", "1"); p.put("client_ip", "127.0.0.1"); p.put("act_name",act_name); p.put("send_name", send_name); p.put("wishing", wishing); p.put("remark",remark); String sign = PayCommonUtil.createSign("UTF-8", p); System.out.println(sign); p.put("sign", sign); String reuqestXml = PayCommonUtil.getRequestXml(p); KeyStore keyStore = KeyStore.getInstance("PKCS12"); FileInputStream instream = new FileInputStream(new File(ConfigUtil.CERT_PATH)); try { keyStore.load(instream, ConfigUtil.MCH_ID.toCharArray()); } finally { instream.close(); } SSLContext sslcontext = SSLContexts.custom().loadKeyMaterial(keyStore, ConfigUtil.MCH_ID.toCharArray()).build(); 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");// 退款接口 httpPost.addHeader("Content-Type", "application/x-www-form-urlencoded; charset=UTF-8"); System.out.println("executing request" + httpPost.getRequestLine()); //請求的xml需轉(zhuǎn)碼為iso8859-1編碼,否則易出現(xiàn)簽名錯誤或紅包上的文字顯示有誤 StringEntity reqEntity = new StringEntity(new String(reuqestXml.getBytes(), "ISO8859-1")); // 設(shè)置類型 httpPost.setEntity(reqEntity); CloseableHttpResponse response = httpclient.execute(httpPost); try { HttpEntity entity = response.getEntity(); System.out.println("----------------------------------------"); System.out.println(response.getStatusLine()); if (entity != null) { System.out.println("Response content length: " + entity.getContentLength()); BufferedReader bufferedReader = new BufferedReader( new InputStreamReader(entity.getContent(), "UTF-8")); String text; while ((text = bufferedReader.readLine()) != null) { System.out.println(text); } } EntityUtils.consume(entity); } finally { response.close(); } } finally { httpclient.close(); } }
需要注意的地方是下面這里:
//請求的xml需轉(zhuǎn)碼為iso8859-1編碼,否則易出現(xiàn)簽名錯誤或紅包上的文字顯示有誤
StringEntity reqEntity = new StringEntity(new String(reuqestXml.getBytes(), "ISO8859-1"));
這個地方可以說把我弄得差點(diǎn)崩潰了各種試,各種調(diào)試還是抱著試一試的心態(tài)加上去就OK了,這個可能是因?yàn)閔ttpclient和原生的HttpsConnection在數(shù)據(jù)傳輸上的不同吧。這里沒做過多的研究。
調(diào)用這個方法就更簡單了直接像下面這樣
public static void main(String args[]){ try { sendRedPack("12828839012016101420","接收者的openid","xxx","100","1","恭喜發(fā)財(cái),年年有余","新年紅包","新年紅包還不快搶","127.0.0.1"); } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); } }
紅包發(fā)送后打印的信息如下:
TTP/1.1 200 OK Response content length: 567 <xml> <return_code><![CDATA[SUCCESS]]></return_code> <return_msg><![CDATA[發(fā)放成功]]></return_msg> <result_code><![CDATA[SUCCESS]]></result_code> <err_code><![CDATA[SUCCESS]]></err_code> <err_code_des><![CDATA[發(fā)放成功]]></err_code_des> <mch_billno><![CDATA[12828839012016101421]]></mch_billno> <mch_id><![CDATA[1282883901]]></mch_id> <wxappid><![CDATA[xxxxx]]></wxappid> <re_openid><![CDATA[xxxx]]></re_openid> <total_amount>100</total_amount> <send_listid><![CDATA[1000041701201610143000090813093]]></send_listid> </xml>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaWeb購物車項(xiàng)目開發(fā)實(shí)戰(zhàn)指南
之前沒有接觸過購物車的東東,也不知道購物車應(yīng)該怎么做,所以在查詢了很多資料,總結(jié)一下購物車的功能實(shí)現(xiàn),下面這篇文章主要給大家介紹了關(guān)于JavaWeb購物車項(xiàng)目開發(fā)的相關(guān)資料,需要的朋友可以參考下2022-06-06EasyExcel實(shí)現(xiàn)導(dǎo)入+各種數(shù)據(jù)校驗(yàn)功能
這篇文章主要介紹了EasyExcel實(shí)現(xiàn)導(dǎo)入+各種數(shù)據(jù)校驗(yàn),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-05-05