本文实例为大家分享了微信支付订单的查询接口,供大家参考,具体内容如下
1.接口简介
2.代码实现
package com.zhrd.bussinss.platform.controller.shop; import java.io.File; import java.io.FileInputStream; import java.security.KeyStore; import java.text.SimpleDateFormat; import java.util.Date; import javax.net.ssl.SSLContext; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import net.sf.json.JSONObject; import org.apache.http.HttpEntity; import org.apache.http.client.methods.CloseableHttpResponse; import org.apache.http.client.methods.HttpPost; import org.apache.http.conn.ssl.SSLConnectionSocketFactory; import org.apache.http.conn.ssl.SSLContexts; import org.apache.http.entity.StringEntity; import org.apache.http.impl.client.CloseableHttpClient; import org.apache.http.impl.client.HttpClients; import org.dom4j.Document; import org.dom4j.Element; import org.dom4j.io.SAXReader; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RequestMethod; import org.springframework.web.bind.annotation.RequestParam; import org.springframework.web.bind.annotation.ResponseBody; import com.zhrd.bussinss.platform.service.WeiXinPayService; import com.zhrd.bussinss.platform.utils.CustomizedPropertyPlaceholderConfigurer; import com.zhrd.bussinss.platform.weixinPayUtils.ClientCustomSSL; @Controller @RequestMapping(\"/shop/weiXinPayOrderSearch\") public class WeiXinPayOrderSearchController { @Autowired WeiXinPayService weiXinPayService; /** * 微信支出订单状态查询 * @param request * @param response * @return */ @RequestMapping(value=\"/init\",method=RequestMethod.GET ) public String init(HttpServletRequest request,HttpServletResponse response){ return \"weixinPayOrderSearch\"; } /** * 微信支出订单状态查询 * @param request * @param response * @return */ @RequestMapping(value=\"/getWeiXinPayOrder\",method=RequestMethod.POST ) @ResponseBody public Object getWeiXinPayOrder(HttpServletRequest request,HttpServletResponse response,@RequestParam(required=false) String transactionId,@RequestParam(required=false) String outTradeNo){ try{ KeyStore keyStore = KeyStore.getInstance(\"PKCS12\"); FileInputStream instream = new FileInputStream(new File( CustomizedPropertyPlaceholderConfigurer.getContextProperty(\"wx.cert\").toString())); try { keyStore.load(instream, \"见邮件\".toCharArray()); }finally { instream.close(); } // Trust own CA and all self-signed certs SSLContext sslcontext = SSLContexts.custom().loadKeyMaterial(keyStore, \"10061401\".toCharArray()).build(); // Allow TLSv1 protocol only SSLConnectionSocketFactory sslsf = new SSLConnectionSocketFactory( sslcontext, new String[] { \"TLSv1\" }, null, SSLConnectionSocketFactory.ALLOW_ALL_HOSTNAME_VERIFIER); CloseableHttpClient httpclient = HttpClients.custom() .setSSLSocketFactory(sslsf).build(); // HttpGet httpget = new // HttpGet(\"https://api.mch.weixin.qq.com/secapi/pay/refund\"); HttpPost httppost = new HttpPost( \"https://api.mch.weixin.qq.com/pay/orderquery\"); Date dt = new Date(); SimpleDateFormat sdf = new SimpleDateFormat(\"yyyyMMddHHmmss\"); String nonceStr = sdf.format(dt).toString();<pre name=\"code\" class=\"java\"> String xml = ClientCustomSSL.SearchNativePackage(transactionId.trim(),\"\", nonceStr);//此处为微信端id(本地id和服务器端id均可查询) try { StringEntity se = new StringEntity(xml); httppost.setEntity(se); System.out.println(\"executing request\" + httppost.getRequestLine()); CloseableHttpResponse responseEntry = httpclient.execute(httppost); try { HttpEntity entity = responseEntry.getEntity(); System.out.println(\"----------------------------------------\"); System.out.println(responseEntry.getStatusLine()); if (entity != null) { System.out.println(\"Response content length: \" + entity.getContentLength()); /*BufferedReader bufferedReader = new BufferedReader( new InputStreamReader(entity.getContent())); String text; while ((text = bufferedReader.readLine()) != null) { System.out.println(\"=======\"+text); }*/ SAXReader saxReader = new SAXReader(); Document document = saxReader.read(entity.getContent()); Element rootElt = document.getRootElement(); System.out.println(\"根节点:\" + rootElt.getName()); System.out.println(\"===\"+rootElt.elementText(\"result_code\")); System.out.println(\"===\"+rootElt.elementText(\"return_msg\")); String resultCode = rootElt.elementText(\"result_code\"); String returnCode = rootElt.elementText(\"return_code\"); JSONObject result = new JSONObject(); System.out.println(\"resultCode=====\"+resultCode); System.out.println(\"returnCode=====\"+returnCode); System.out.println(\"trade_state=====\"+rootElt.elementText(\"trade_state\")); System.out.println(\"transaction_id=====\"+rootElt.elementText(\"transaction_id\")); System.out.println(\"out_trade_no=====\"+ rootElt.elementText(\"out_trade_no\")); System.out.println(\"total_fee=====\"+rootElt.elementText(\"total_fee\")); if(resultCode != null && resultCode.equals(\"SUCCESS\") && returnCode.equals(\"SUCCESS\")){ result.put(\"tradeState\", rootElt.elementText(\"trade_state\")); result.put(\"transactionId\", rootElt.elementText(\"transaction_id\")); result.put(\"outTradeNo\", rootElt.elementText(\"out_trade_no\")); result.put(\"totalFee\", rootElt.elementText(\"total_fee\")); result.put(\"status\",\"success\"); result.put(\"msg\",\"success\"); }else if(returnCode.equals(\"SUCCESS\")){ result.put(\"errorCheck\", \"errCode\"); result.put(\"status\",\"false\"); result.put(\"errorMsg\",rootElt.elementText(\"err_code_des\")); }else{ result.put(\"errorCheck\", \"errMsg\"); result.put(\"status\",\"false\"); result.put(\"errorMsg\", rootElt.elementText(\"return_msg\")); } return result; } // EntityUtils.consume(entity); } finally { responseEntry.close(); } } finally { httpclient.close(); } }catch(Exception e){ e.printStackTrace(); JSONObject result = new JSONObject(); result.put(\"status\",\"error\"); result.put(\"msg\",e.getMessage()); return result; } return \"\"; } }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持phpstudy。
本文地址:https://www.stayed.cn/item/3522
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我