支付项目中如何防止请求参数被篡改

背景:支付项目中如何防止数据被篡改?可以使用验证签名功能,如果返回false,说明数据被篡改,不应该执行后面的功能。验证签名功能也可以应用在微服务项目中,放在网关中做拦截过滤请求参数…

1.maven中引入

	<dependency>
			<groupId>commons-codec</groupId>
			<artifactId>commons-codec</artifactId>
			<version>1.11</version>
	</dependency>

2.项目引入SignUtil工具类

package com.test.sign;

import java.io.UnsupportedEncodingException;
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;

import org.apache.commons.codec.digest.DigestUtils;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

/**
 * 参数验证签名工具类
 */
public class SignUtil {
   

	private static Logger logger = LoggerFactory.getLogger(SignUtil.class);

	/** 加密密钥 */
	private final static String APP_KEY = "mykey123456";

	public final static String SECRET_KEY = "mysecret123456";

	/** 字符编码 */
	private final static String INPUT_CHARSET = "UTF-8";

	/** 超时时间 */
	private final static int TIME_OUT = 30 * 60 * 1000;

	/**
	 * 请求参数Map转换验证Map
	 *
	 * @param requestParams
	 *            请求参数Map
	 * @param charset
	 *            是否要转utf8编码
	 * @return
	 * @throws UnsupportedEncodingException
	 */
	public static Map<String, String> toVerifyMap(Map<String, String[]> requestParams, boolean charset) {
   
		Map<String, String> params = new HashMap<>();
		for (Iterator iter = requestParams.keySet().iterator(); iter.hasNext();) {
   
			String name = (String) iter.next();
			String[] values = requestParams.get(name);
			String valueStr = "";
			for (int i = 0; i < values.length; i++) {
   
				valueStr = (i == values.length - 
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值