spring boot 接口生成Sign签名

public class SignUtils {

    public static String getSign(Map<String, String> requestMap, String appKey) {
        return hmacSHA256Encrypt(requestMap2Str(requestMap), appKey);
    }


    private static String hmacSHA256Encrypt(String encryptText, String encryptKey) {
        byte[] result = null;
        try {
            //根据给定的字节数组构造一个密钥,第二参数指定一个密钥算法的名称
            SecretKeySpec signinKey = new SecretKeySpec(encryptKey.getBytes("UTF-8"), "HmacSHA256");
            //生成一个指定 Mac 算法 的 Mac 对象
            Mac mac = Mac.getInstance("HmacSHA256");
            //用给定密钥初始化 Mac 对象
            mac.init(signinKey);
            //完成 Mac 操作
            byte[] rawHmac = mac.doFinal(encryptText.getBytes("UTF-8"));
            return ByteFormat.bytesToHexString(rawHmac);
        } catch (Exception e) {
            e.printStackTrace();
        }
        return null;
    }


    private static String requestMap2Str(Map<String, String> requestMap) {
        String[] keys = requestMap.keySet().toArray(new String[0]);
        Arrays.sort(keys);
        StringBuilder stringBuilder = new StringBuilder();
        for (String str : keys) {
            if (!str.equals("sign")) {
                stringBuilder.append(str).append(requestMap.get(str));
            }
        }
        return stringBuilder.toString();
    }

}
/**
 * 格式化操作类
 */
public class ByteFormat {
    private static final char[] HEX = new char[]{'0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F'};

    public ByteFormat() {
    }

    public static final String bytesToHexString(byte[] bArray) {
        StringBuffer sb = new StringBuffer(bArray.length);

        for (int i = 0; i < bArray.length; ++i) {
            String sTemp = Integer.toHexString(255 & bArray[i]);
            if (sTemp.length() < 2) {
                sb.append(0);
            }

            sb.append(sTemp.toUpperCase());
        }

        return sb.toString();
    }

    public static byte[] hexToBytes(String str) {
        if (str == null) {
            return null;
        } else {
            char[] hex = str.toCharArray();
            int length = hex.length / 2;
            byte[] raw = new byte[length];

            for (int i = 0; i < length; ++i) {
                int high = Character.digit(hex[i * 2], 16);
                int low = Character.digit(hex[i * 2 + 1], 16);
                int value = high << 4 | low;
                if (value > 127) {
                    value -= 256;
                }

                raw[i] = (byte) value;
            }

            return raw;
        }
    }
}
public static void main(String[] args) {

		String appKey = "123";
		Map<String, String> params = new HashMap<String, String>();
		params.put("token", "123");
		params.put("appId", "123");
		String sign = SignUtils.getSign(params, appKey);
		String sign1 = SignUtils.getSign(params, appKey);
		System.out.println("sign: " +sign);
		System.out.println("sign1: " +sign1);
		System.out.println(sign1.equals(sign)?"密钥相等":"签名错误");

	}

在对外暴露的API当中 某些比较严谨的API为了方式是别人篡改或者恶意添加参数可以添加Sign 签名去保证接口不被篡改

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
下面是一个使用Spring Boot实现企业级微信支付接口的代码示例: 1. 配置文件(application.properties): ``` # 微信支付配置 wechat.pay.appId=your_appId wechat.pay.mchId=your_mchId wechat.pay.key=your_key wechat.pay.notifyUrl=your_notifyUrl wechat.pay.certPath=/path/to/your_cert.p12 ``` 2. 支付参数实体类(PayParams.java): ```java public class PayParams { private String body; // 商品描述 private String outTradeNo; // 商户订单号 private int totalFee; // 订单总金额(单位:分) // 其他参数... // getter和setter方法... } ``` 3. 支付回调实体类(PayCallback.java): ```java public class PayCallback { private String returnCode; // 返回状态码 private String returnMsg; // 返回信息 // 其他参数... // getter和setter方法... } ``` 4. 支付服务类(PayService.java): ```java @Service public class PayService { @Value("${wechat.pay.appId}") private String appId; @Value("${wechat.pay.mchId}") private String mchId; @Value("${wechat.pay.key}") private String key; @Value("${wechat.pay.notifyUrl}") private String notifyUrl; @Value("${wechat.pay.certPath}") private String certPath; public String unifiedOrder(PayParams payParams) throws Exception { // 构建统一下单请求参数 Map<String, String> data = new HashMap<>(); data.put("appid", appId); data.put("mch_id", mchId); data.put("nonce_str", WXPayUtil.generateNonceStr()); data.put("body", payParams.getBody()); data.put("out_trade_no", payParams.getOutTradeNo()); data.put("total_fee", String.valueOf(payParams.getTotalFee())); // 其他参数... // 生成签名 String sign = WXPayUtil.generateSignature(data, key); data.put("sign", sign); // 发起统一下单请求 WXPayRequest wxPayRequest = new WXPayRequest(); Map<String, String> result = wxPayRequest.requestWithCert("/pay/unifiedorder", data, certPath, mchId); // 处理返回结果 if ("SUCCESS".equals(result.get("return_code")) && "SUCCESS".equals(result.get("result_code"))) { return result.get("prepay_id"); } else { throw new Exception(result.get("return_msg")); } } public PayCallback parsePayCallback(String xmlData) throws Exception { // 解析支付回调数据 Map<String, String> map = WXPayUtil.xmlToMap(xmlData); // 验证签名 if (WXPayUtil.isSignatureValid(map, key)) { PayCallback payCallback = new PayCallback(); payCallback.setReturnCode(map.get("return_code")); payCallback.setReturnMsg(map.get("return_msg")); // 其他参数... return payCallback; } else { throw new Exception("Invalid signature"); } } } ``` 5. 支付控制器类(PayController.java): ```java @RestController @RequestMapping("/pay") public class PayController { @Autowired private PayService payService; @PostMapping("/unifiedOrder") public String unifiedOrder(@RequestBody PayParams payParams) throws Exception { return payService.unifiedOrder(payParams); } @PostMapping("/callback") public String callback(HttpServletRequest request) throws Exception { String xmlData = IOUtils.toString(request.getInputStream(), "UTF-8"); PayCallback payCallback = payService.parsePayCallback(xmlData); // 处理支付结果,更新订单状态等逻辑... return "<xml><return_code><![CDATA[SUCCESS]]></return_code><return_msg><![CDATA[OK]]></return_msg></xml>"; } } ``` 以上代码示例使用了微信支付的Java SDK:`com.github.wxpay.sdk`,你需要添加相应的依赖。 这只是一个简单的示例,实际开发中还需要根据业务需求进行适当的调整和扩展。同时,还需要保证支付过程的安全性和正确性,例如验证回调通知的有效性、处理支付结果等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值