136 lines
5.9 KiB
Java
136 lines
5.9 KiB
Java
|
/*
|
|||
|
* Copyright 2019-2025 Zheng Jie
|
|||
|
*
|
|||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|||
|
* you may not use this file except in compliance with the License.
|
|||
|
* You may obtain a copy of the License at
|
|||
|
*
|
|||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|||
|
*
|
|||
|
* Unless required by applicable law or agreed to in writing, software
|
|||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|||
|
* See the License for the specific language governing permissions and
|
|||
|
* limitations under the License.
|
|||
|
*/
|
|||
|
package com.fuyuanshen.rest;
|
|||
|
|
|||
|
import io.swagger.annotations.Api;
|
|||
|
import io.swagger.annotations.ApiOperation;
|
|||
|
import lombok.RequiredArgsConstructor;
|
|||
|
import lombok.extern.slf4j.Slf4j;
|
|||
|
import com.fuyuanshen.annotation.rest.AnonymousAccess;
|
|||
|
import com.fuyuanshen.annotation.Log;
|
|||
|
import com.fuyuanshen.annotation.rest.AnonymousGetMapping;
|
|||
|
import com.fuyuanshen.domain.dto.TradeDto;
|
|||
|
import com.fuyuanshen.domain.AlipayConfig;
|
|||
|
import com.fuyuanshen.domain.enums.AliPayStatusEnum;
|
|||
|
import com.fuyuanshen.utils.AlipayUtils;
|
|||
|
import com.fuyuanshen.service.AliPayService;
|
|||
|
import org.springframework.http.HttpStatus;
|
|||
|
import org.springframework.http.ResponseEntity;
|
|||
|
import org.springframework.validation.annotation.Validated;
|
|||
|
import org.springframework.web.bind.annotation.*;
|
|||
|
import springfox.documentation.annotations.ApiIgnore;
|
|||
|
|
|||
|
import javax.servlet.http.HttpServletRequest;
|
|||
|
import javax.servlet.http.HttpServletResponse;
|
|||
|
import java.nio.charset.StandardCharsets;
|
|||
|
import java.util.Map;
|
|||
|
|
|||
|
/**
|
|||
|
* @author Zheng Jie
|
|||
|
* @date 2018-12-31
|
|||
|
*/
|
|||
|
@Slf4j
|
|||
|
@RestController
|
|||
|
@RequiredArgsConstructor
|
|||
|
@RequestMapping("/api/aliPay")
|
|||
|
@Api(tags = "工具:支付宝管理")
|
|||
|
public class AliPayController {
|
|||
|
|
|||
|
private final AlipayUtils alipayUtils;
|
|||
|
private final AliPayService alipayService;
|
|||
|
|
|||
|
@GetMapping
|
|||
|
public ResponseEntity<AlipayConfig> queryAliConfig() {
|
|||
|
return new ResponseEntity<>(alipayService.find(), HttpStatus.OK);
|
|||
|
}
|
|||
|
|
|||
|
@Log("配置支付宝")
|
|||
|
@ApiOperation("配置支付宝")
|
|||
|
@PutMapping
|
|||
|
public ResponseEntity<Object> updateAliPayConfig(@Validated @RequestBody AlipayConfig alipayConfig) {
|
|||
|
alipayService.config(alipayConfig);
|
|||
|
return new ResponseEntity<>(HttpStatus.OK);
|
|||
|
}
|
|||
|
|
|||
|
@Log("支付宝PC网页支付")
|
|||
|
@ApiOperation("PC网页支付")
|
|||
|
@PostMapping(value = "/toPayAsPC")
|
|||
|
public ResponseEntity<String> toPayAsPc(@Validated @RequestBody TradeDto trade) throws Exception {
|
|||
|
AlipayConfig aliPay = alipayService.find();
|
|||
|
trade.setOutTradeNo(alipayUtils.getOrderCode());
|
|||
|
String payUrl = alipayService.toPayAsPc(aliPay, trade);
|
|||
|
return ResponseEntity.ok(payUrl);
|
|||
|
}
|
|||
|
|
|||
|
@Log("支付宝手机网页支付")
|
|||
|
@ApiOperation("手机网页支付")
|
|||
|
@PostMapping(value = "/toPayAsWeb")
|
|||
|
public ResponseEntity<String> toPayAsWeb(@Validated @RequestBody TradeDto trade) throws Exception {
|
|||
|
AlipayConfig alipay = alipayService.find();
|
|||
|
trade.setOutTradeNo(alipayUtils.getOrderCode());
|
|||
|
String payUrl = alipayService.toPayAsWeb(alipay, trade);
|
|||
|
return ResponseEntity.ok(payUrl);
|
|||
|
}
|
|||
|
|
|||
|
@ApiIgnore
|
|||
|
@AnonymousGetMapping("/return")
|
|||
|
@ApiOperation("支付之后跳转的链接")
|
|||
|
public ResponseEntity<String> returnPage(HttpServletRequest request, HttpServletResponse response) {
|
|||
|
AlipayConfig alipay = alipayService.find();
|
|||
|
response.setContentType("text/html;charset=" + alipay.getCharset());
|
|||
|
//内容验签,防止黑客篡改参数
|
|||
|
if (alipayUtils.rsaCheck(request, alipay)) {
|
|||
|
//商户订单号
|
|||
|
String outTradeNo = new String(request.getParameter("out_trade_no").getBytes(StandardCharsets.ISO_8859_1), StandardCharsets.UTF_8);
|
|||
|
//支付宝交易号
|
|||
|
String tradeNo = new String(request.getParameter("trade_no").getBytes(StandardCharsets.ISO_8859_1), StandardCharsets.UTF_8);
|
|||
|
System.out.println("商户订单号" + outTradeNo + " " + "第三方交易号" + tradeNo);
|
|||
|
|
|||
|
// 根据业务需要返回数据,这里统一返回OK
|
|||
|
return new ResponseEntity<>("payment successful", HttpStatus.OK);
|
|||
|
} else {
|
|||
|
// 根据业务需要返回数据
|
|||
|
return new ResponseEntity<>(HttpStatus.BAD_REQUEST);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
@ApiIgnore
|
|||
|
@RequestMapping("/notify")
|
|||
|
@AnonymousAccess
|
|||
|
@ApiOperation("支付异步通知(要公网访问),接收异步通知,检查通知内容app_id、out_trade_no、total_amount是否与请求中的一致,根据trade_status进行后续业务处理")
|
|||
|
public ResponseEntity<Object> notify(HttpServletRequest request) {
|
|||
|
AlipayConfig alipay = alipayService.find();
|
|||
|
Map<String, String[]> parameterMap = request.getParameterMap();
|
|||
|
//内容验签,防止黑客篡改参数
|
|||
|
if (alipayUtils.rsaCheck(request, alipay)) {
|
|||
|
//交易状态
|
|||
|
String tradeStatus = new String(request.getParameter("trade_status").getBytes(StandardCharsets.ISO_8859_1), StandardCharsets.UTF_8);
|
|||
|
// 商户订单号
|
|||
|
String outTradeNo = new String(request.getParameter("out_trade_no").getBytes(StandardCharsets.ISO_8859_1), StandardCharsets.UTF_8);
|
|||
|
//支付宝交易号
|
|||
|
String tradeNo = new String(request.getParameter("trade_no").getBytes(StandardCharsets.ISO_8859_1), StandardCharsets.UTF_8);
|
|||
|
//付款金额
|
|||
|
String totalAmount = new String(request.getParameter("total_amount").getBytes(StandardCharsets.ISO_8859_1), StandardCharsets.UTF_8);
|
|||
|
//验证
|
|||
|
if (tradeStatus.equals(AliPayStatusEnum.SUCCESS.getValue()) || tradeStatus.equals(AliPayStatusEnum.FINISHED.getValue())) {
|
|||
|
// 验证通过后应该根据业务需要处理订单
|
|||
|
}
|
|||
|
return new ResponseEntity<>(HttpStatus.OK);
|
|||
|
}
|
|||
|
return new ResponseEntity<>(HttpStatus.BAD_REQUEST);
|
|||
|
}
|
|||
|
}
|