123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171 |
- package com.keao.edu.controller;
- import com.alibaba.fastjson.JSON;
- import com.alibaba.fastjson.JSONObject;
- import com.keao.edu.auth.api.client.SysUserFeignService;
- import com.keao.edu.auth.api.entity.SysUser;
- import com.keao.edu.common.controller.BaseController;
- import com.keao.edu.common.entity.HttpResponseResult;
- import com.keao.edu.thirdparty.adapay.ConfigInit;
- import com.keao.edu.thirdparty.adapay.Payment;
- import com.keao.edu.user.dto.ExamPaymentInfo;
- import com.keao.edu.user.entity.ExamRegistrationPayment;
- import com.keao.edu.user.service.ExamRegistrationPaymentService;
- import com.keao.edu.util.date.DateUtil;
- import com.keao.edu.util.http.HttpUtil;
- import io.swagger.annotations.Api;
- import io.swagger.annotations.ApiImplicitParam;
- import io.swagger.annotations.ApiImplicitParams;
- import io.swagger.annotations.ApiOperation;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.util.DigestUtils;
- import org.springframework.web.bind.annotation.GetMapping;
- import org.springframework.web.bind.annotation.PostMapping;
- import org.springframework.web.bind.annotation.RequestMapping;
- import org.springframework.web.bind.annotation.RestController;
- import java.math.BigDecimal;
- import java.text.SimpleDateFormat;
- import java.util.*;
- @RestController
- @Api(tags = "报名订单服务")
- @RequestMapping(value = "examOrder")
- public class ExamOrderController extends BaseController {
- @Autowired
- private ExamRegistrationPaymentService examRegistrationPaymentService;
- @Autowired
- private SysUserFeignService sysUserFeignService;
- @ApiOperation("获取用户项目未支付的订单")
- @ApiImplicitParams({
- @ApiImplicitParam(name = "examinationBasicId", value = "项目id", required = true, dataType = "Integer")})
- @GetMapping(value = "/getExamIngOrder")
- public HttpResponseResult<ExamRegistrationPayment> getExamIngOrder(Long examinationBasicId) {
- SysUser sysUser = sysUserFeignService.queryUserInfo();
- return succeed(examRegistrationPaymentService.getExamIngOrder(examinationBasicId, sysUser.getId()));
- }
- @ApiOperation(value = "台牌支付")
- @PostMapping("/executePayment")
- @ApiImplicitParams({
- @ApiImplicitParam(name = "amount", value = "支付金额", required = true, dataType = "BigDecimal"),
- @ApiImplicitParam(name = "orderNo", value = "订单号", required = true, dataType = "String"),
- @ApiImplicitParam(name = "payChannel", value = "支付方式", required = true, dataType = "String"),
- @ApiImplicitParam(name = "returnUrl", value = "返回页面", required = true, dataType = "String"),
- @ApiImplicitParam(name = "orderSubject", value = "订单标题", required = true, dataType = "String"),
- @ApiImplicitParam(name = "orderBody", value = "订单内容", required = true, dataType = "String"),
- @ApiImplicitParam(name = "sign", value = "sign", required = true, dataType = "String"),
- @ApiImplicitParam(name = "code", value = "code", required = true, dataType = "String")
- })
- public Object executePayment(BigDecimal amount, String orderNo, String payChannel, String returnUrl,String notifyUrl, String orderSubject, String orderBody, String sign, String code, String platform) throws Exception {
- Map<String, Object> signParams = new LinkedHashMap<>();
- signParams.put("appId", ConfigInit.appId);
- signParams.put("amount", amount);
- signParams.put("orderNo", orderNo);
- // signParams.put("notifyUrl", notifyUrl);
- // signParams.put("returnUrl", returnUrl);
- signParams.put("orderSubject", orderSubject);
- signParams.put("orderBody", orderBody);
- signParams.put("wxAppId", ConfigInit.wxAppId);
- String originalStr = JSONObject.toJSONString(signParams);
- String newSign = DigestUtils.md5DigestAsHex(originalStr.getBytes());
- if(!sign.equals(newSign)){
- return failed("请勿非法请求");
- }
- String openId = "";
- if (payChannel.equals("wx_pub")) {
- if (code == null || code.isEmpty()) {
- return failed("微信支付请先授权");
- }
- String wxMpOAuth2AccessTokenUrl = String.format(ConfigInit.wxMpOAuth2AccessTokenUrl, ConfigInit.wxAppId, ConfigInit.wxAppSecret, code);
- Map<String, String> weChatRes = JSON.parseObject(HttpUtil.get(wxMpOAuth2AccessTokenUrl, new HashMap<>()), Map.class);
- if (!weChatRes.containsKey("openid")) {
- return failed("授权失败,请重新授权");
- }
- openId = weChatRes.get("openid");
- }
- ExamRegistrationPayment examRegistrationPayment = examRegistrationPaymentService.getByOrderNo(orderNo);
- if (examRegistrationPayment == null) {
- return failed("订单不存在,请勿非法请求");
- }
- String merNos = examRegistrationPayment.getMerNo();
- Date createTime = examRegistrationPayment.getCreateTime();
- Calendar beforeTime = Calendar.getInstance();
- beforeTime.add(Calendar.MINUTE, -28);// 28 分钟之前的时间
- Date beforeDate = beforeTime.getTime();
- if (createTime.before(beforeDate)) {
- return failed("订单已超时,请重新下单");
- }
- amount = examRegistrationPayment.getTransAmount().setScale(2,BigDecimal.ROUND_HALF_UP);
- Date expireDate = DateUtil.addMinutes(createTime, 30);
- String timeExpire = new SimpleDateFormat("yyyyMMddHHmmss").format(expireDate);
- Map<String, Object> paymentParams = new HashMap<>();
- paymentParams.put("app_id", ConfigInit.appId);
- paymentParams.put("order_no", orderNo);
- paymentParams.put("pay_channel", payChannel);
- paymentParams.put("pay_amt", amount);
- paymentParams.put("goods_title", orderSubject);
- paymentParams.put("goods_desc", orderBody);
- paymentParams.put("time_expire", timeExpire);
- if (!merNos.equals(ConfigInit.merNo)) {
- List<Map<String, Object>> divMembers = new ArrayList<>();
- Map<String, Object> divMember = new HashMap<>();
- divMember.put("member_id", merNos);//分佣账户
- divMember.put("amount", amount);//分佣金额
- divMember.put("fee_flag", "Y"); //承担手续费
- divMembers.add(divMember);
- paymentParams.put("div_members", JSON.toJSONString(divMembers));
- }
- Map<String, Object> expendParams = new HashMap<>(5);
- expendParams.put("open_id", openId);
- expendParams.put("is_raw", "1");
- expendParams.put("callback_url", returnUrl);
- expendParams.put("limit_pay", "1");
- paymentParams.put("expend", expendParams);
- Map<String, Object> payment = Payment.executePayment(paymentParams);
- examRegistrationPayment.setTransNo((String) payment.get("id"));
- examRegistrationPaymentService.update(examRegistrationPayment);
- return succeed(payment);
- }
- @ApiOperation(value = "获取订单状态及订单信息")
- @GetMapping(value = "/paymentResult")
- @ApiImplicitParams({
- @ApiImplicitParam(name = "orderNo", value = "订单编号", required = true, dataType = "String")})
- public HttpResponseResult<ExamPaymentInfo> getExamOrderInfo(String orderNo) {
- return succeed(examRegistrationPaymentService.getExamOrderInfo(orderNo));
- }
- @PostMapping(value = "orderSuccess")
- public HttpResponseResult orderSuccess(String orderNo){
- Map<String, String> notifyMap = new HashMap<>();
- notifyMap.put("channelType", "Alipay");
- notifyMap.put("memo", "手动回调");
- notifyMap.put("transStatus", "SUCCESS");
- notifyMap.put("orderNo", orderNo);
- notifyMap.put("transNo", UUID.randomUUID().toString());
- examRegistrationPaymentService.updateOrder(notifyMap);
- return succeed();
- }
- @ApiOperation(value = "关闭订单")
- @PostMapping("/closeOrder")
- public HttpResponseResult closeOrder(String orderNo){
- return succeed(examRegistrationPaymentService.closeOrder(orderNo));
- }
- }
|