`
hai0378
  • 浏览: 528346 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

微信支付之H5页面WAP端接入

 
阅读更多

1.前言

公司是通过支付宝和微信支付那块内容获取收入,app端已经接入成功,现在要做WAP端。需要页面和后台接口一起来实现。

2.接口接入

因为微信支付版本更新了,网上下的demo是V2.5版的,用不了了。所以去网上找资料,看到最新版的V3。

这里我找到了一个统一下单接口,文档入口.

他的接口地址为:https://api.mch.weixin.qq.com/pay/unifiedorder

因此,开始接入我所需要的wap端参数。

这里需要的参数关键有Appid,mch_id,key。

appid和mch_id是在公众平台那边获取。key值是在商户平台(pay.weixin.qq.com)-->账户设置-->API安全-->密钥设置 这边自己设置的。

坑一:若key值设置不对,会出现错误“支付权限查询失败” 。这时候请检查 appid,mch_id所在的公众号 对应 商户号的key值是否正确。

坑二:我在开发中还遇到“您没有WAP支付权限” 这么个错误。百了很久都没人遇到这个坑。于是,发送邮件给微信支付(weixinpay@tencent.comwepayTS@tencent.com)这两个邮件我都发了,结果还是漫无回应啊。于是,打通了商户平台的客服(0755-86018333),客服是MM,估计不懂技术问题,叫我去提问平台提交问题(http://kf.qq.com//bills/150821samab01c976f2a.html),说是技术人员看到会回复的,我问是不是 马上回复,MM不说,就说会回复的,唉,毕竟人家客服不懂,就没继续问下去了。打开客服给的网址,填写的时候,发现没有WAP端,也没有统一下单这说法,那我只好填写了  网页(JSAPI)支付 ,下面在详细说明,提交后,出现了个提示,说是七天内给个回应。我去,那还不是白忙活,要7天 业务紧急啊。。

3.代码编写

(1).获取统一下单参数

[java] view plaincopy
 
  1. public String CreateWapUrl(String outTradeNo, String ip) throws SDKRuntimeException {  
  2.     HashMap<String, Object> param = new HashMap<String, Object>();  
  3.     param.put("appid", WxPayConfig.APPID);  
  4.     param.put("mch_id", WxPayConfig.MCHID);  
  5.     param.put("nonce_str", CommonUtil.CreateNoncestr());  
  6.     param.put("body""产品测试");  
  7.     param.put("out_trade_no", outTradeNo);  
  8.     param.put("total_fee"1);  
  9.     param.put("spbill_create_ip", ip);  
  10.     param.put("notify_url", WxPayConfig.NOTIFYURL);  
  11.     param.put("trade_type""WAP");  
  12.     param.put("sign", getSign(param));  
  13.     return CommonUtil.MapToXml(param);  
  14. }  

(2).获取签名值

[java] view plaincopy
 
  1. public String getSign(HashMap<String, Object> param) throws SDKRuntimeException {  
  2.     String sign="";  
  3.     String content = CommonUtil.FormatParamMap(param);  
  4.     sign =  Sign(content, WxPayConfig.KEY);  
  5.     return sign;  
  6. }  
  7.   
  8. public static String Sign(String content, String key) throws SDKRuntimeException {  
  9.     String signStr = "";  
  10.     if ("" == key) {  
  11.         throw new SDKRuntimeException("财付通签名key不能为空!");  
  12.     }  
  13.     if ("" == content) {  
  14.         throw new SDKRuntimeException("财付通签名内容不能为空");  
  15.     }  
  16.     signStr = content + "&key=" + key;  
  17.     return MD5Util.MD5(signStr).toUpperCase();  
  18. }  

(3).工具类方法

[java] view plaincopy
 
  1. public static boolean IsNumeric(String str) {  
  2.     if (str.matches("\\d *")) {  
  3.         return true;  
  4.     } else {  
  5.         return false;  
  6.     }  
  7. }  
  8.   
  9. //map转成xml  
  10. public static String MapToXml(HashMap<String, Object> arr) {  
  11.     String xml = "<xml>";  
  12.       
  13.     Iterator<Entry<String, Object>> iter = arr.entrySet().iterator();  
  14.     while (iter.hasNext()) {  
  15.         Entry<String, Object> entry = iter.next();  
  16.         String key = entry.getKey();  
  17.         String val = entry.getValue()+"";  
  18.         if (IsNumeric(val)) {  
  19.             xml += "<" + key + ">" + val + "</" + key + ">";  
  20.   
  21.         } else  
  22.             xml += "<" + key + "><![CDATA[" + val + "]]></" + key + ">";  
  23.     }  
  24.   
  25.     xml += "</xml>";  
  26.     return xml;  
  27. }  
  28.   
  29. //xml转成map  
  30. @SuppressWarnings("unchecked")  
  31. public static Map<String, String> parseXml(String xml) throws Exception {  
  32.      Map<String, String> map = new HashMap<String, String>();  
  33.      Document document = DocumentHelper.parseText(xml);  
  34.      Element root = document.getRootElement();  
  35.      List<Element> elementList = root.elements();  
  36.      for (Element e : elementList) {  
  37.          map.put(e.getName(), e.getText());  
  38.      }  
  39.      return map;  
  40. }  
  41.   
  42.   
  43. public static String FormatParamMap(HashMap<String, Object> parameters) throws SDKRuntimeException {  
  44.     String buff = "";  
  45.     try {  
  46.         List<Map.Entry<String, Object>> infoIds = new ArrayList<Map.Entry<String, Object>>(  
  47.                 parameters.entrySet());  
  48.         Collections.sort(infoIds,  
  49.                 new Comparator<Map.Entry<String, Object>>() {  
  50.                     public int compare(Map.Entry<String, Object> o1,  
  51.                             Map.Entry<String, Object> o2) {  
  52.                         return (o1.getKey()).toString().compareTo(  
  53.                                 o2.getKey());  
  54.                     }  
  55.                 });  
  56.   
  57.         for (int i = 0; i < infoIds.size(); i++) {  
  58.             Map.Entry<String, Object> item = infoIds.get(i);  
  59.             if (item.getKey() != "") {  
  60.                 buff += item.getKey() + "="  
  61.                         + URLEncoder.encode(item.getValue()+"""utf-8") + "&";  
  62.             }  
  63.         }  
  64.         if (buff.isEmpty() == false) {  
  65.             buff = buff.substring(0, buff.length() - 1);  
  66.         }  
  67.     } catch (Exception e) {  
  68.         throw new SDKRuntimeException(e.getMessage());  
  69.     }  
  70.     return buff;  
  71. }  
  72.   
  73. public static String CreateNoncestr() {  
  74.     String chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";  
  75.     String res = "";  
  76.     for (int i = 0; i < 16; i++) {  
  77.         Random rd = new Random();  
  78.         res += chars.charAt(rd.nextInt(chars.length() - 1));  
  79.     }  
  80.     return res;  
  81. }  

(4).发送请求方法

[java] view plaincopy
 
  1. public static String sendPost(String url, String param,String charset) {  
  2.         PrintWriter out = null;  
  3.         BufferedReader in = null;  
  4.         String result = "";  
  5.         try {  
  6.             URL realUrl = new URL(url);  
  7.             // 打开和URL之间的连接  
  8.             URLConnection conn = realUrl.openConnection();  
  9.             // 设置通用的请求属性  
  10.             conn.setRequestProperty("accept""*/*");  
  11.             conn.setRequestProperty("connection""Keep-Alive");  
  12.             conn.setRequestProperty("user-agent""Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");  
  13.             
  14.             // 发送POST请求必须设置如下两行  
  15.             conn.setDoOutput(true);  
  16.             conn.setDoInput(true);  
  17.             // 获取URLConnection对象对应的输出流  
  18.             out = new PrintWriter(conn.getOutputStream());  
  19.             // 发送请求参数  
  20.             out.print(new String(param.getBytes(),charset));  
  21.             // flush输出流的缓冲  
  22.             out.flush();  
  23.             // 定义BufferedReader输入流来读取URL的响应  
  24.             in = new BufferedReader(new InputStreamReader(conn.getInputStream(), charset));  
  25.             String line;  
  26.             while ((line = in.readLine()) != null) {  
  27.                 result += line;  
  28.             }  
  29.         } catch (Exception e) {  
  30.             e.printStackTrace();  
  31.         }  
  32.         //使用finally块来关闭输出流、输入流  
  33.         finally{  
  34.             try{  
  35.                 if(out!=null){  
  36.                     out.close();  
  37.                 }  
  38.                 if(in!=null){  
  39.                     in.close();  
  40.                 }  
  41.             }  
  42.             catch(IOException ex){  
  43.                 ex.printStackTrace();  
  44.             }  
  45.         }  
  46.         return result;  
  47.     }      

(5).执行接口

[java] view plaincopy
 
  1. //网页版微信支付接口  
  2. public String wxWapPay() throws Exception {  
  3.     String result = SUCCESS;  
  4.     String message = "";  
  5.     int code = 0;  
  6.     try {  
  7.         String ip = getIpAddr(request);  
  8.         String outTradeNo = new SimpleDateFormat("YYYYMMDDHHmmssSSS").format(new Date())+"-wap";  
  9.         String param = new WxPayHelper().CreateWapUrl(outTradeNo, ip);  
  10.         String resp = HttpRequest.sendPost(WxPayConfig.UNIFIEDORDER_INTERFACE, param, "utf-8");  
  11.         Map<String, String> res = CommonUtil.parseXml(resp);  
  12.           
  13.         if(res.get("return_code") == "SUCCESS") {  
  14.             if(res.get("result_code") == "SUCCESS") {  
  15.                 message = res.get("code_url");  
  16.             }else {  
  17.                 code = -1;  
  18.                 message = res.get("err_code_des");  
  19.                 logger.error("wxWapPay error code"+res.get("err_code")+", reason is "+res.get("err_code_des"));  
  20.             }  
  21.         }else {  
  22.             code = -1;  
  23.             message = res.get("return_msg");  
  24.             logger.error("wxWapPay error reason is "+res.get("return_msg"));  
  25.         }  
  26.     } catch (Exception e) {  
  27.         code = -1;  
  28.         logger.error("wxWapPay Exception reason is "+ e);  
  29.         e.printStackTrace();  
  30.     }  
  31.     dataMap = new HashMap<String, Object>();  
  32.     dataMap.put("code", code);  
  33.     dataMap.put("message", message);  
  34.       
  35.     return result;  
  36. }  

 

更多参考

 

https://pay.weixin.qq.com/wiki/doc/api/jsapi.php?chapter=9_1

 

 

微信官网文档:

https://pay.weixin.qq.com/wiki/doc/api/wap.php?chapter=15_4

 

 

  • 大小: 115.8 KB
分享到:
评论

相关推荐

    Java接入H5微信支付demo.zip

    Java接入H5微信支付涉及到的是Java后端与微信支付接口的集成技术,是现代电子商务系统中常见的支付方式。在此过程中,开发者需要理解微信支付的API规范,并使用Java语言编写相关代码来实现用户在H5(移动端网页)上...

    微信/支付宝 H5支付接口(C#版demo)

    微信/支付宝 H5支付接口(C#版demo)

    wap端微信h5支付,用于非微信浏览器

    通过理解以上知识点,开发者可以实现wap端的微信H5支付功能,让非微信浏览器中的用户也能享受到微信支付的便利。在实际应用中,还需要考虑用户体验优化,如错误处理、支付状态的实时同步等问题。

    java微信支付(H5、小程序)实例和SDK

    对于小程序支付,流程与H5类似,但需要在小程序端调用微信提供的API。首先,后端生成预支付交易单,然后将预支付交易单的参数返回给小程序,小程序再通过自己的API发起支付请求,用户在小程序内部确认支付。 5. **...

    SpringBoot集成H5微信支付宝支付

    6. **生成H5支付跳转链接**:根据预支付交易会话标识,生成微信支付H5页面的跳转链接,用户点击后将进入微信支付页面。 7. **处理支付结果**:微信支付成功后,用户会被重定向到指定的回调URL,需在此处处理支付结果...

    tp5 微信支付h5支付

    微信H5支付是微信支付为移动网页场景提供的支付解决方案,用户在手机浏览器中打开商家的H5页面,点击支付按钮后,通过调用微信支付的H5支付接口,引导用户在微信内完成支付流程。这一过程涉及的关键技术点包括商户...

    微信H5支付DEMO 绝对可用

    微信H5支付是一种在网页上实现的支付方式,由微信官方提供的一种支付接口,主要用于移动端的在线交易。在这个“微信H5支付DEMO”中,包含了一整套完整的支付流程示例,帮助开发者快速理解和集成微信H5支付功能。下面...

    微信支付(H5支付。微信公众号支付)

    公众号支付是指用户在微信中打开商户的H5页面,商户在H5页面通过调用微信支付提供的JSAPI接口调起微信支付模块来完成支付。 适用于在公众号、朋友圈、聊天窗口等微信内完成支付的场景。 APP支付是指商户通过在...

    java实现微信H5支付方法详解

    本篇文章主要介绍了java实现微信H5支付方法详解,非常具有实用价值,需要的朋友可以参考下

    微信H5支付DEMO

    微信H5支付DEMO是一个基于C#和ASP.NET技术实现的微信H5支付示例,主要目的是为了展示如何集成微信支付功能,使用户能够在H5网页中流畅地完成支付过程。这个DEMO涵盖了从调用微信支付接口进行统一下单到引导用户完成...

    html5微信支付 页面效果

    2. **生成订单**:在用户点击支付按钮后,服务器端会根据商品信息生成一个订单,并调用微信支付接口,请求预支付交易会话标识(prepay_id)。 3. **前端处理**:服务器返回预支付交易信息后,前端使用HTML5的AJAX...

    uniapp H5集成微信JS支付

    uni-app框架下,开发H5,集成微信JS API支付,安装指定的,jweixin-module之后调用方法关键代码,搞了一星期,终于都搞明白,很简单,一看就懂了。

    cocos crestor 修改引擎代码实现h5支付,跳转到微信.支付宝.客户端

    2. **H5支付**:H5支付是指通过HTML5页面实现的在线支付方式,通常包括微信支付和支付宝支付。这种支付方式无需下载额外的应用,用户只需在浏览器中完成支付流程。 3. **原生桥接**:为了实现H5支付,Cocos Creator...

    微信支付H5界面代码.zip

    微信支付H5界面是移动互联网时代,商家为了方便用户通过手机浏览器进行支付而设计的一种支付方式。本资源提供了一个完整的HTML5微信支付页面效果,包括自定义键盘、样式以及JavaScript实现,使得开发者能够快速集成...

    Asp微信支付系统接口代码下载 修复版+微信扫码支付+H5支付+微信公众号支付+微信红包支付+微信刷卡支付等等

    SP 扫码支付是用的最普遍的一种接口,所有 ASP 的网站都可以整合使用,微信扫码支付结果会实时在微信中回调显示,同时实现支付下单结果返回,并入库自动更新订单操作。 微信公众号支付是基于微信公众号而开发的支付...

    微信支付官方demo及接口

    微信支付是中国最流行的移动支付方式之一,广泛应用于各种线上和线下场景。官方提供的SDK和Demo是开发者集成微信支付功能的关键工具。以下是对标题和描述中所提及知识点的详细解释: 1. **微信支付接口**:微信支付...

    h5微信支付完整版_h5微信支付完整版_微信支付分_fathercxc_h5支付_微信支付_

    本文将详细介绍H5微信支付的完整流程,以及与之相关的"微信支付分"等相关概念。 首先,H5微信支付是微信支付针对网页端开发的一种支付解决方案。它允许商家在自己的H5页面中集成微信支付功能,让用户无需跳转到微信...

    微信支付和h5wap支付.zip

    微信支付和h5wap支付

    PHP微信H5支付完整代码(包含回调后台代码),改好商户资料和您回调地址即可使用

    1. **微信H5支付**:微信H5支付是微信支付提供的一种针对移动浏览器的支付方式,用户在H5页面中点击支付按钮后,会跳转到微信支付页面完成支付流程。 2. **PHP**:PHP是一种广泛使用的开源服务器端脚本语言,尤其...

    微信小程序端,调起H5支付demo

    微信小程序调起H5支付是一种常见的在线支付方式,它允许用户在微信小程序内无缝跳转到H5页面完成支付流程。这种支付模式结合了小程序的便捷性和H5页面的灵活性,为用户提供了一种流畅的购物体验。下面我们将详细介绍...

Global site tag (gtag.js) - Google Analytics