java实现微信扫码支付功能
作者:品学兼忧
这篇文章主要为大家详细介绍了java实现微信扫码支付功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了java实现微信扫码支付的具体代码,供大家参考,具体内容如下
1、maven项目的pom.xml中添加如下jar包:
<dependency> <groupId>com.github.wxpay</groupId> <artifactId>wxpay-sdk</artifactId> <version>0.0.3</version> </dependency>
2、编写WeWxConfig类:
package com.xx.wxpay;
import com.github.wxpay.sdk.WXPayConfig;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
import java.io.InputStream;
/**
* 描述:微信支付配置信息
*
* @author ssl
* @create 2018/04/24 19:25
*/
@Component
public class WeWxConfig implements WXPayConfig {
@Value("${wechat.public.appid}")
private String appId;
@Value("${wechat.merchant}")
private String mchId;
@Value("${wechat.public.apikey}")
private String apiKey;
/**
* 公众账号ID:微信支付分配的公众账号ID(企业号corpid即为此appId)
*
* @return
*/
@Override
public String getAppID() {
return appId;
}
/**
* 商户号:微信支付分配的商户号
*
* @return
*/
@Override
public String getMchID() {
return mchId;
}
/**
* @return
*/
@Override
public String getKey() {
return apiKey;
}
@Override
public InputStream getCertStream() {
return null;
}
@Override
public int getHttpConnectTimeoutMs() {
return 0;
}
@Override
public int getHttpReadTimeoutMs() {
return 0;
}
}
3、编写WeWxPayService:
package com.xx.wxpay;
import com.alibaba.fastjson.JSONObject;
import com.github.wxpay.sdk.WXPay;
import com.google.common.collect.Maps;
import com.xx.model.Order;
import com.xx.model.Product;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.stereotype.Component;
import org.springframework.stereotype.Service;
import java.text.MessageFormat;
import java.util.HashMap;
import java.util.Map;
/**
* 描述:
*
* @author ssl
* @create 2018/04/24 20:15
*/
@Service
public class WeWxPayService {
protected Logger logger = LoggerFactory.getLogger(this.getClass());
@Value("${project.url}")
private String projectUrl;
@Autowired
private WeWxConfig weWxConfig;
/**
* 统一下单
*
* @param product
* @param order
* @return
*/
public Map<String, String> unifiedOrder(Product product, Order order) {
Map<String, String> data = Maps.newHashMap();
WXPay wxpay = new WXPay(weWxConfig);
data.put("body", "XX-" + product.getName());
data.put("detail", "详细信息");
data.put("out_trade_no", order.getOrderNo());
data.put("device_info", "WEB");
data.put("fee_type", "CNY");
data.put("total_fee", order.getAmount() + "");
data.put("spbill_create_ip", "127.0.0.1");
data.put("notify_url", projectUrl + "/base/order/notifyUrl");
data.put("trade_type", "NATIVE"); // 此处指定为扫码支付
data.put("product_id", product.getId() + "");
try {
Map<String, String> resp = wxpay.unifiedOrder(data);
logger.debug(JSONObject.toJSONString(resp));
return resp;
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
/**
* 订单查询
*
* @param orderNo:订单号
* @return
*/
public Map<String, String> orderQuery(String orderNo) {
Map<String, String> reqData = Maps.newHashMap();
reqData.put("out_trade_no", orderNo);
WXPay wxpay = new WXPay(weWxConfig);
try {
Map<String, String> resp = wxpay.orderQuery(reqData);
logger.debug(JSONObject.toJSONString(resp));
return resp;
} catch (Exception e) {
e.printStackTrace();
}
return null;
}
public static String getUrl() {
WXPay wxpay = new WXPay(new WeWxConfig());
Map<String, String> data = new HashMap<String, String>();
data.put("body", "上屏名称");
data.put("detail", "商品详情");
data.put("out_trade_no", "2ab9071b06b9f739b950ddb41db2690d");
data.put("device_info", "");
data.put("fee_type", "CNY");
data.put("total_fee", "1");
data.put("spbill_create_ip", "218.17.160.245");
data.put("notify_url", "http://www.example.com/wxpay/notify");
data.put("trade_type", "NATIVE"); // 此处指定为扫码支付
data.put("product_id", "12");
try {
Map<String, String> resp = wxpay.unifiedOrder(data);
System.out.println(resp);
} catch (Exception e) {
e.printStackTrace();
}
return "";
}
}
4、调用:
/** 向微信支付系统下单,并得到二维码返回给用户 */ Map<String, String> resData = weWxPayService.unifiedOrder(product, order);
5、resData.get("code_url")为微信下单成功后返回的二维码地址,页面中用QRCode.js来显示该二维码,且该页面用定时器定时查询订单支付状态
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
