最近在做微信支付,微信支付比较坑,官方居然只有.NET、C#、PHP的demo居然没有java的demo。然后微信支付是不提供测试账号的需要直接用正式的公众号。首先来介绍下微信扫码支付吧,微信扫码有两种方式,这里采用第二种方式统一下单(JSAPI)。需要提前在微信公众号后台申请微信支付开通,具体的开通规则详细文档见点击打开链接

其实微信支付挺简单的无非就是拼装参数给微信发送请求,要注意的几点就是支付的金额是分,微信没有同步回调地址,只有异步回调的地址。这样的话就不能实时反馈支付结果到PC端页面。网上大多数同步的做法就是通过ajax定时查询订单的状态,(可以查询自己业务订单的支付状态或者去调微信支付查询接口微信给我们返回的订单状态)两种都可以,lz建议还是去查询微信服务那边的订单查询接口。这样可以缓解我们自己的服务器的压力,也可以预防人家恶意刷我们的接口。京东也是采用定时轮询查询订单的状态的他们是每隔3s去查一次。

下面附上H5和PC扫码支付的代码这是H5和Pc下单的接口

package com.workit.pay.weixin.wxPay;

import java.util.Date;
import java.util.Map;
import java.util.SortedMap;
import java.util.TreeMap; import org.slf4j.Logger;
import org.slf4j.LoggerFactory; import com.workit.comm.util.String.StringUtil;
import com.workit.pay.weixin.wxPay.constant.WeiXinPayConstant;
import com.workit.pay.weixin.wxPay.util.PayCommonUtil;
import com.workit.pay.weixin.wxPay.util.WeixinFormatXmlProcess; /**
* @Title: WxPayService.java
*.qqwx.wxPay
* @Description: TODO
*
* @date 2017年5月3日 上午11:16:48
* @version V1.0
*/
public class WxPayService {
private static final Logger logger = LoggerFactory.getLogger(WxPayService.class); public static String getOrderNo(){
return "DD"+String.valueOf(new Date().getTime());
} /**
*
* @Title: unifiedOrderPC
* @Description: 微信PC 扫码下单接口
* @param @param body
* @param @param orderNo
* @param @param totalFee
* @param @return
* @param @throws Exception
* @return String
*/
public static String unifiedOrderPC(String body,String orderNo, String totalFee) throws Exception{
return unifiedOrder(body,orderNo, totalFee,null,WeiXinPayConstant.TRADE_TYPE_PC,null);
} /**
*
* @Title: unifiedOrderH5
* @Description: 微信H5 下单接口
* @param @param body 商品描述
* @param @param orderNo
* @param @param totalFee
* @param @param openId
* @param @param ip
* @param @return
* @param @throws Exception
* @return SortedMap<Object,Object>
*/
public static SortedMap<Object, Object> unifiedOrderH5(String body,String orderNo, String totalFee,String openId,String ip) throws Exception{
String prepay_id = unifiedOrder(body,orderNo, totalFee,openId,WeiXinPayConstant.TRADE_TYPE_H5,ip);
if(StringUtil.isNotEmpty(prepay_id)){
SortedMap<Object, Object> payMap = new TreeMap<Object, Object>();
payMap.put("appId",WeiXinPayConstant.APPID);
payMap.put("timeStamp",PayCommonUtil.createTimestamp());
payMap.put("nonceStr",PayCommonUtil.CreateNoncestr());
payMap.put("signType","MD5");
payMap.put("package", "prepay_id="+prepay_id);
String paySign = PayCommonUtil.createSign("UTF-8",payMap,WeiXinPayConstant.API_KEY);
payMap.put("paySign", paySign);
payMap.put("pg", prepay_id);
return payMap;
}else{
return null;
} }
/**
*
* @Title: unifiedOrder
* @Description: 微信支付扫码和H5支付统一下单接口
* @param @param body 商品描述
* @param @param orderNo 订单编号
* @param @param totalFee 总金额单位分
* @param @param openId H5必传的参数
* @param @param payType 支付终端
* @param @param ip 请求IP
* @param @return
* @param @throws Exception
* @return String
*/
public static String unifiedOrder(String body,String orderNo, String totalFee,String openId,String payType,String ip) throws Exception{
SortedMap<Object, Object> parameters = new TreeMap<Object, Object>();
String tradeType = "";
String spbill_create_ip = "";
if(WeiXinPayConstant.TRADE_TYPE_H5.equals(payType)){//H5支付
tradeType = WeiXinPayConstant.TRADE_TYPE_H5;
spbill_create_ip = ip;
parameters.put("openid", openId);//用户标识 openid 否 String(128) oUpF8uMuAJO_M2pxb1Q9zNjWeS6o trade_type=JSAPI时(即公众号支付),此参数必传,此参数为微信用户在商户对应appid下的唯一标识。openid如何获取,可参考【获取openid】。企业号请使用【企业号OAuth2.0接口】获取企业号内成员userid,再调用【企业号userid转openid接口】进行转换
}else{
spbill_create_ip = "10.20.20.64";
tradeType = WeiXinPayConstant.TRADE_TYPE_PC;//PC扫码支付
parameters.put("product_id",orderNo);
}
parameters.put("appid", WeiXinPayConstant.APPID);//公众账号ID appid 是 String(32) wxd678efh567hg6787 微信支付分配的公众账号ID(企业号corpid即为此appId)
parameters.put("body", body);//商品描述 body 是 String(128) 腾讯充值中心-QQ会员充值 商品简单描述,该字段请按照规范传递,具体请见参数规定
parameters.put("mch_id", WeiXinPayConstant.MCH_ID);//商户号 mch_id 是 String(32) 1230000109 微信支付分配的商户号
parameters.put("nonce_str",PayCommonUtil.CreateNoncestr());//随机字符串 nonce_str 是 String(32) 5K8264ILTKCH16CQ2502SI8ZNMTM67VS 随机字符串,长度要求在32位以内。推荐随机数生成算法
parameters.put("out_trade_no",orderNo);//商户订单号 out_trade_no 是 String(32) 20150806125346 商户系统内部订单号,要求32个字符内,只能是数字、大小写字母_-|*@ ,且在同一个商户号下唯一。详见商户订单号
parameters.put("spbill_create_ip",spbill_create_ip);//终端IP spbill_create_ip 是 String(16) 123.12.12.123 APP和网页支付提交用户端ip,Native支付填调用微信支付API的机器IP。
parameters.put("total_fee", totalFee);//标价金额 total_fee 是 Int 88 订单总金额,单位为分,详见支付金额
parameters.put("notify_url",WeiXinPayConstant.NOTIFY_URL);//通知地址 notify_url 是 String(256) http://www.weixin.qq.com/wxpay/pay.php 异步接收微信支付结果通知的回调地址,通知url必须为外网可访问的url,不能携带参数。
parameters.put("trade_type",tradeType);//交易类型 trade_type 是 String(16) JSAPI 取值如下:JSAPI,NATIVE,APP等,说明详见参数规定
String sign = PayCommonUtil.createSign("UTF-8",parameters,WeiXinPayConstant.API_KEY);//签名 sign 是 String(32) C380BEC2BFD727A4B6845133519F3AD6 通过签名算法计算得出的签名值,详见签名生成算法
parameters.put("sign", sign);
String requestXML = PayCommonUtil.getRequestXml(parameters); //把参数打包转成xml格式
String result =PayCommonUtil.httpsRequest(WeiXinPayConstant.WEIXIN_PAY_URL,"POST",requestXML);//向微信发送统一下单请求
Map<String, Object> mapResult = WeixinFormatXmlProcess.parseXml1(result); //微信响应的结果
String resultCode =(String)mapResult.get("return_code");
logger.info(mapResult.toString());
if(WeiXinPayConstant.WX_PAY_SUCCESS_STATUS.equals(resultCode)){
if(WeiXinPayConstant.TRADE_TYPE_H5.equals(payType)){//H5支付
return (String)mapResult.get("prepay_id");
}else{
return (String)mapResult.get("code_url");
}
}else{
return null;
}
} }

微信支付(PC扫码支付和H5公众号支付)的更多相关文章

  1. 微信支付之扫码、APP、小程序支付接入详解

    做电商平台的小伙伴都知道,支付服务是必不可少的一部分,今天我们开始就说说支付服务的接入及实现.目前在国内,几乎90%中小公司的支付系统都离不开微信支付和支付宝支付.那么大家要思考了,为什么微信支付和支 ...

  2. 集成微信支付的代码。兼容小程序,扫码,app,公众号。h5 支付 ,以及 服务商提现

      /** * 因为微信总是很多个商户号很多和appid.很多个密钥文件,所以全部改成手动传值的方式,就可以支持多商户调用 * * @param appId 商户的appid * @param mch ...

  3. 微信支付之扫码支付、公众号支付、H5支付、小程序支付相关业务流程分析总结

    前言 很久以来,一直想写一篇微信支付有关的总结文档:一方面是总结自己的一些心得,另一方面也可以帮助别人,但是因种种原因未能完全理解透彻微信支付的几大支付方式,今天有幸做一些总结上的文章,也趁此机会,将 ...

  4. h5微信支付在微信内页使用微信公众号支付

    由于app的迭代,原本的微信支付是使用原生写的 然后h5这边做交互,现在需要修改使用h5的微信支付,于是就有了现在的这个例子,微信支付其实对于我们前端来说就是调用接口然后,根据链接进行支付,其中有点坑 ...

  5. 【原创分享·微信支付】 C# MVC 微信支付教程系列之公众号支付

    微信支付教程系列之公众号支付         今天,我们接着讲微信支付的系列教程,前面,我们讲了这个微信红包和扫码支付.现在,我们讲讲这个公众号支付.公众号支付的应用环境常见的用户通过公众号,然后再通 ...

  6. C# MVC 微信支付教程系列之公众号支付

    微信支付教程系列之公众号支付           今天,我们接着讲微信支付的系列教程,前面,我们讲了这个微信红包和扫码支付.现在,我们讲讲这个公众号支付.公众号支付的应用环境常见的用户通过公众号,然后 ...

  7. 微信公众号支付(JSAPI)对接备忘

    0 说明 本文里说的微信公众号支付对接指的是对接第三方支付平台的微信公众号支付接口. 非微信支付官方文档里的公众号支付开发者文档那样的对接.不过,毕竟腾讯会把一部分渠道放给银行或有支付牌照的支付机构, ...

  8. 【分享·微信支付】 C# MVC 微信支付教程系列之公众号支付

    微信支付教程系列之公众号支付           今天,我们接着讲微信支付的系列教程,前面,我们讲了这个微信红包和扫码支付.现在,我们讲讲这个公众号支付.公众号支付的应用环境常见的用户通过公众号,然后 ...

  9. 微信公众号支付|微信H5支付|微信扫码支付|小程序支付|APP微信支付解决方案总结

    最近负责的一些项目开发,都用到了微信支付(微信公众号支付.微信H5支付.微信扫码支付.APP微信支付).在开发的过程中,在调试支付的过程中,或多或少都遇到了一些问题,今天总结下,分享,留存. 先说注意 ...

随机推荐

  1. C++里面this关键字的用法和功能

    1.this指针的用处 一个对象的this指针并不是对象本身的一部分,不会影响sizeof(对象)的结果.this作用域是在类内部,当在类的非静态成员函数中访问类的非静态成员的时候,编译器会自动将对象 ...

  2. 树莓派搭建seafile服务器备忘

    用户:pi 密码:raspberry 启用root用户https://blog.csdn.net/chenxd1101/article/details/53437925(防止特殊原因pi用户不能登录时 ...

  3. MyBatis-01:环境搭建

    MyBatis-01:环境搭建 1.搭建实验数据库 CREATE DATABASE `mybatis`; USE `mybatis`; DROP TABLE IF EXISTS `user`; CRE ...

  4. 记一次MySQL出现Waiting for table metadata lock的原因、排查过程与解决方法

    任务背景:将sql文件通过shell直接导入到mysql中执行(还原) bug表现:导入后java项目卡死 过程: 1.网上乱搜一通,无意间看到一篇文章,这篇文章说明了如何开启mysql的genera ...

  5. springmvc<二> 一些配置

    1.1.3. Web MVC Config    1.1.2中的解析器可以自定义实现,DispatcherServlet检查每个特殊bean的WebApplicationContext,如果没有匹配的 ...

  6. Redis数据库简介

    最近的项目需要用到Redis数据库和MySQL,恶补学习. Redis的使用手册可以看: https://redis.io/ https://www.runoob.com/redis/redis-tu ...

  7. Java 中的语法糖,真甜。

    我把自己以往的文章汇总成为了 Github ,欢迎各位大佬 star https://github.com/crisxuan/bestJavaer 我们在日常开发中经常会使用到诸如泛型.自动拆箱和装箱 ...

  8. NET core 添加了新的nuget包,部署出现Could not load file or assembly

    这个坑,今天整了一天,我添加了Microsoft.AspNetCore.Mvc.Versioning包,结果发布到服务器,我复制了dll过去出现了一直找不到加载不成功的问题 Startup.Confi ...

  9. 半夜删你代码队 Day2冲刺

    一.每日站立式会议 1.站立式会议 成员 昨日完成工作 今日计划工作 遇到的困难 陈惠霖 整理任务 了解相关网页设计 任务安排有的不合理,需改进 侯晓龙 学习了解相关知识 尝试写第一个实例子 无 周楚 ...

  10. CSS基础-边框

    border border-top设置上边界 border-bottom / border-left / border-right 同理 可以为每一条边设置 : border-top-width宽度 ...