查询订单接口
接口说明:
-
请求方式:GET
-
请求路径:/order/{id}
-
请求参数:id,订单编号
-
返回结果:Order,订单的json对象
测试:
结果:
更新订单状态
接口说明:
-
请求参数:PUT
-
请求路径:/order/{id}/{status}
-
请求参数:
-
id:订单编号,String类型,不能为空
-
status:订单状态,不能为空
-
-
返回结果:null
测试:
结果:
数据库中也发生了改变:
分页查询订单
接口说明:
-
请求方式:Get
-
请求路径:/order/list
-
请求参数:
-
page:当前页,Integer类型,默认为1
-
rows:每页大小,Integer类型,默认为5
-
status:订单状态,String类型,默认查询全部状态订单
-
-
返回结果:PageResult 对象,包含下面属性:
-
total:总条数
-
items:当前页订单数组
-
订单对象
-
-
测试:
结果:
生成微信付款链接
接口说明:
-
请求方式:Get
-
请求路径:/order/url/{id}
-
请求参数:id,订单编号
-
返回结果:String类型,生成的微信支付链接
测试:
结果:
微信支付工具
PayHelper
@Component
public class PayHelper {
private WXPay wxPay;
private static final Logger logger = LoggerFactory.getLogger(PayHelper.class);
@Autowired
private StringRedisTemplate redisTemplate;
@Autowired
private OrderService orderService;
public PayHelper(PayConfig payConfig) {
// 真实开发时
wxPay = new WXPay(payConfig);
// 测试时
// wxPay = new WXPay(payConfig, WXPayConstants.SignType.MD5, true);
}
public String createPayUrl(Long orderId) {
String key = "ly.pay.url." + orderId;
try {
String url = this.redisTemplate.opsForValue().get(key);
if (StringUtils.isNotBlank(url)) {
return url;
}
} catch (Exception e) {
logger.error("查询缓存付款链接异常,订单编号:{}", orderId, e);
}
try {
Map<String, String> data = new HashMap<>();
// 商品描述
data.put("body", "商城测试");
// 订单号
data.put("out_trade_no", orderId.toString());
//货币
data.put("fee_type", "CNY");
//金额,单位是分
data.put("total_fee", "1");
//调用微信支付的终端IP(estore商城的IP)
data.put("spbill_create_ip", "127.0.0.1");
//回调地址
data.put("notify_url", "http://test.learn.com/wxpay/notify");
// 交易类型为扫码支付
data.put("trade_type", "NATIVE");
//商品id,使用假数据
data.put("product_id", "1234567");
Map<String, String> result = this.wxPay.unifiedOrder(data);
if ("SUCCESS".equals(result.get("return_code"))) {
String url = result.get("code_url");
// 将付款地址缓存,时间为10分钟
try {
this.redisTemplate.opsForValue().set(key, url, 10, TimeUnit.MINUTES);
} catch (Exception e) {
logger.error("缓存付款链接异常,订单编号:{}", orderId, e);
}
return url;
} else {
logger.error("创建预交易订单失败,错误信息:{}", result.get("return_msg"));
return null;
}
} catch (Exception e) {
logger.error("创建预交易订单异常", e);
return null;
}
}
/**
* 查询订单状态
*
* @param orderId
* @return
*/
public PayState queryOrder(Long orderId) {
Map<String, String> data = new HashMap<>();
// 订单号
data.put("out_trade_no", orderId.toString());
try {
Map<String, String> result = this.wxPay.orderQuery(data);
if (result == null) {
// 未查询到结果,认为是未付款
return PayState.NOT_PAY;
}
String state = result.get("trade_state");
if ("SUCCESS".equals(state)) {
// success,则认为付款成功
// 修改订单状态
this.orderService.updateStatus(orderId, 2);
return PayState.SUCCESS;
} else if (StringUtils.equals("USERPAYING", state)
|| StringUtils.equals("NOTPAY", state)) {
// 未付款或正在付款,都认为是未付款
return PayState.NOT_PAY;
} else {
// 其它状态认为是付款失败
return PayState.FAIL;
}
} catch (Exception e) {
logger.error("查询订单状态异常", e);
return PayState.NOT_PAY;
}
}
}
查询支付状态
接口说明:
-
请求方式: Get
-
请求路径: /state/{id}
-
请求参数: id,订单编号
-
返回结果:0, 未查询到支付信息 1,支付成功 2,支付失败(查询失败,或者订单过期)
未付款
未付款时查询,测试:
结果: