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.com, wepayTS@tencent.com)这两个邮件我都发了,结果还是漫无回应啊。于是,打通了商户平台的客服(0755-86018333),客服是MM,估计不懂技术问题,叫我去提问平台提交问题(http://kf.qq.com//bills/150821samab01c976f2a.html),说是技术人员看到会回复的,我问是不是 马上回复,MM不说,就说会回复的,唉,毕竟人家客服不懂,就没继续问下去了。打开客服给的网址,填写的时候,发现没有WAP端,也没有统一下单这说法,那我只好填写了 网页(JSAPI)支付 ,下面在详细说明,提交后,出现了个提示,说是七天内给个回应。我去,那还不是白忙活,要7天 业务紧急啊。。
3.代码编写
(1).获取统一下单参数
- public String CreateWapUrl(String outTradeNo, String ip) throws SDKRuntimeException {
- HashMap<String, Object> param = new HashMap<String, Object>();
- param.put("appid", WxPayConfig.APPID);
- param.put("mch_id", WxPayConfig.MCHID);
- param.put("nonce_str", CommonUtil.CreateNoncestr());
- param.put("body", "产品测试");
- param.put("out_trade_no", outTradeNo);
- param.put("total_fee", 1);
- param.put("spbill_create_ip", ip);
- param.put("notify_url", WxPayConfig.NOTIFYURL);
- param.put("trade_type", "WAP");
- param.put("sign", getSign(param));
- return CommonUtil.MapToXml(param);
- }
(2).获取签名值
- public String getSign(HashMap<String, Object> param) throws SDKRuntimeException {
- String sign="";
- String content = CommonUtil.FormatParamMap(param);
- sign = Sign(content, WxPayConfig.KEY);
- return sign;
- }
- public static String Sign(String content, String key) throws SDKRuntimeException {
- String signStr = "";
- if ("" == key) {
- throw new SDKRuntimeException("财付通签名key不能为空!");
- }
- if ("" == content) {
- throw new SDKRuntimeException("财付通签名内容不能为空");
- }
- signStr = content + "&key=" + key;
- return MD5Util.MD5(signStr).toUpperCase();
- }
(3).工具类方法
- public static boolean IsNumeric(String str) {
- if (str.matches("\\d *")) {
- return true;
- } else {
- return false;
- }
- }
- //map转成xml
- public static String MapToXml(HashMap<String, Object> arr) {
- String xml = "<xml>";
- Iterator<Entry<String, Object>> iter = arr.entrySet().iterator();
- while (iter.hasNext()) {
- Entry<String, Object> entry = iter.next();
- String key = entry.getKey();
- String val = entry.getValue()+"";
- if (IsNumeric(val)) {
- xml += "<" + key + ">" + val + "</" + key + ">";
- } else
- xml += "<" + key + "><![CDATA[" + val + "]]></" + key + ">";
- }
- xml += "</xml>";
- return xml;
- }
- //xml转成map
- @SuppressWarnings("unchecked")
- public static Map<String, String> parseXml(String xml) throws Exception {
- Map<String, String> map = new HashMap<String, String>();
- Document document = DocumentHelper.parseText(xml);
- Element root = document.getRootElement();
- List<Element> elementList = root.elements();
- for (Element e : elementList) {
- map.put(e.getName(), e.getText());
- }
- return map;
- }
- public static String FormatParamMap(HashMap<String, Object> parameters) throws SDKRuntimeException {
- String buff = "";
- try {
- List<Map.Entry<String, Object>> infoIds = new ArrayList<Map.Entry<String, Object>>(
- parameters.entrySet());
- Collections.sort(infoIds,
- new Comparator<Map.Entry<String, Object>>() {
- public int compare(Map.Entry<String, Object> o1,
- Map.Entry<String, Object> o2) {
- return (o1.getKey()).toString().compareTo(
- o2.getKey());
- }
- });
- for (int i = 0; i < infoIds.size(); i++) {
- Map.Entry<String, Object> item = infoIds.get(i);
- if (item.getKey() != "") {
- buff += item.getKey() + "="
- + URLEncoder.encode(item.getValue()+"", "utf-8") + "&";
- }
- }
- if (buff.isEmpty() == false) {
- buff = buff.substring(0, buff.length() - 1);
- }
- } catch (Exception e) {
- throw new SDKRuntimeException(e.getMessage());
- }
- return buff;
- }
- public static String CreateNoncestr() {
- String chars = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789";
- String res = "";
- for (int i = 0; i < 16; i++) {
- Random rd = new Random();
- res += chars.charAt(rd.nextInt(chars.length() - 1));
- }
- return res;
- }
(4).发送请求方法
- public static String sendPost(String url, String param,String charset) {
- PrintWriter out = null;
- BufferedReader in = null;
- String result = "";
- try {
- URL realUrl = new URL(url);
- // 打开和URL之间的连接
- URLConnection conn = realUrl.openConnection();
- // 设置通用的请求属性
- conn.setRequestProperty("accept", "*/*");
- conn.setRequestProperty("connection", "Keep-Alive");
- conn.setRequestProperty("user-agent", "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.1;SV1)");
- // 发送POST请求必须设置如下两行
- conn.setDoOutput(true);
- conn.setDoInput(true);
- // 获取URLConnection对象对应的输出流
- out = new PrintWriter(conn.getOutputStream());
- // 发送请求参数
- out.print(new String(param.getBytes(),charset));
- // flush输出流的缓冲
- out.flush();
- // 定义BufferedReader输入流来读取URL的响应
- in = new BufferedReader(new InputStreamReader(conn.getInputStream(), charset));
- String line;
- while ((line = in.readLine()) != null) {
- result += line;
- }
- } catch (Exception e) {
- e.printStackTrace();
- }
- //使用finally块来关闭输出流、输入流
- finally{
- try{
- if(out!=null){
- out.close();
- }
- if(in!=null){
- in.close();
- }
- }
- catch(IOException ex){
- ex.printStackTrace();
- }
- }
- return result;
- }
(5).执行接口
- //网页版微信支付接口
- public String wxWapPay() throws Exception {
- String result = SUCCESS;
- String message = "";
- int code = 0;
- try {
- String ip = getIpAddr(request);
- String outTradeNo = new SimpleDateFormat("YYYYMMDDHHmmssSSS").format(new Date())+"-wap";
- String param = new WxPayHelper().CreateWapUrl(outTradeNo, ip);
- String resp = HttpRequest.sendPost(WxPayConfig.UNIFIEDORDER_INTERFACE, param, "utf-8");
- Map<String, String> res = CommonUtil.parseXml(resp);
- if(res.get("return_code") == "SUCCESS") {
- if(res.get("result_code") == "SUCCESS") {
- message = res.get("code_url");
- }else {
- code = -1;
- message = res.get("err_code_des");
- logger.error("wxWapPay error code"+res.get("err_code")+", reason is "+res.get("err_code_des"));
- }
- }else {
- code = -1;
- message = res.get("return_msg");
- logger.error("wxWapPay error reason is "+res.get("return_msg"));
- }
- } catch (Exception e) {
- code = -1;
- logger.error("wxWapPay Exception reason is "+ e);
- e.printStackTrace();
- }
- dataMap = new HashMap<String, Object>();
- dataMap.put("code", code);
- dataMap.put("message", message);
- return result;
- }
更多参考
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
相关推荐
Java接入H5微信支付涉及到的是Java后端与微信支付接口的集成技术,是现代电子商务系统中常见的支付方式。在此过程中,开发者需要理解微信支付的API规范,并使用Java语言编写相关代码来实现用户在H5(移动端网页)上...
微信/支付宝 H5支付接口(C#版demo)
通过理解以上知识点,开发者可以实现wap端的微信H5支付功能,让非微信浏览器中的用户也能享受到微信支付的便利。在实际应用中,还需要考虑用户体验优化,如错误处理、支付状态的实时同步等问题。
对于小程序支付,流程与H5类似,但需要在小程序端调用微信提供的API。首先,后端生成预支付交易单,然后将预支付交易单的参数返回给小程序,小程序再通过自己的API发起支付请求,用户在小程序内部确认支付。 5. **...
6. **生成H5支付跳转链接**:根据预支付交易会话标识,生成微信支付H5页面的跳转链接,用户点击后将进入微信支付页面。 7. **处理支付结果**:微信支付成功后,用户会被重定向到指定的回调URL,需在此处处理支付结果...
微信H5支付是微信支付为移动网页场景提供的支付解决方案,用户在手机浏览器中打开商家的H5页面,点击支付按钮后,通过调用微信支付的H5支付接口,引导用户在微信内完成支付流程。这一过程涉及的关键技术点包括商户...
微信H5支付是一种在网页上实现的支付方式,由微信官方提供的一种支付接口,主要用于移动端的在线交易。在这个“微信H5支付DEMO”中,包含了一整套完整的支付流程示例,帮助开发者快速理解和集成微信H5支付功能。下面...
公众号支付是指用户在微信中打开商户的H5页面,商户在H5页面通过调用微信支付提供的JSAPI接口调起微信支付模块来完成支付。 适用于在公众号、朋友圈、聊天窗口等微信内完成支付的场景。 APP支付是指商户通过在...
本篇文章主要介绍了java实现微信H5支付方法详解,非常具有实用价值,需要的朋友可以参考下
微信H5支付DEMO是一个基于C#和ASP.NET技术实现的微信H5支付示例,主要目的是为了展示如何集成微信支付功能,使用户能够在H5网页中流畅地完成支付过程。这个DEMO涵盖了从调用微信支付接口进行统一下单到引导用户完成...
2. **生成订单**:在用户点击支付按钮后,服务器端会根据商品信息生成一个订单,并调用微信支付接口,请求预支付交易会话标识(prepay_id)。 3. **前端处理**:服务器返回预支付交易信息后,前端使用HTML5的AJAX...
uni-app框架下,开发H5,集成微信JS API支付,安装指定的,jweixin-module之后调用方法关键代码,搞了一星期,终于都搞明白,很简单,一看就懂了。
2. **H5支付**:H5支付是指通过HTML5页面实现的在线支付方式,通常包括微信支付和支付宝支付。这种支付方式无需下载额外的应用,用户只需在浏览器中完成支付流程。 3. **原生桥接**:为了实现H5支付,Cocos Creator...
微信支付H5界面是移动互联网时代,商家为了方便用户通过手机浏览器进行支付而设计的一种支付方式。本资源提供了一个完整的HTML5微信支付页面效果,包括自定义键盘、样式以及JavaScript实现,使得开发者能够快速集成...
SP 扫码支付是用的最普遍的一种接口,所有 ASP 的网站都可以整合使用,微信扫码支付结果会实时在微信中回调显示,同时实现支付下单结果返回,并入库自动更新订单操作。 微信公众号支付是基于微信公众号而开发的支付...
微信支付是中国最流行的移动支付方式之一,广泛应用于各种线上和线下场景。官方提供的SDK和Demo是开发者集成微信支付功能的关键工具。以下是对标题和描述中所提及知识点的详细解释: 1. **微信支付接口**:微信支付...
本文将详细介绍H5微信支付的完整流程,以及与之相关的"微信支付分"等相关概念。 首先,H5微信支付是微信支付针对网页端开发的一种支付解决方案。它允许商家在自己的H5页面中集成微信支付功能,让用户无需跳转到微信...
微信支付和h5wap支付
1. **微信H5支付**:微信H5支付是微信支付提供的一种针对移动浏览器的支付方式,用户在H5页面中点击支付按钮后,会跳转到微信支付页面完成支付流程。 2. **PHP**:PHP是一种广泛使用的开源服务器端脚本语言,尤其...
微信小程序调起H5支付是一种常见的在线支付方式,它允许用户在微信小程序内无缝跳转到H5页面完成支付流程。这种支付模式结合了小程序的便捷性和H5页面的灵活性,为用户提供了一种流畅的购物体验。下面我们将详细介绍...