在微信或支付宝等应用接入过程中,经常会用到传递参数的验证操作,以下就是最常用的一种:
import java.net.URLEncoder; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; import java.util.Map; import org.apache.commons.lang3.StringUtils; /** * @Description 测试 * @Notes 未填写备注 * @author ming.li * @Date 2018年3月28日 上午11:02:05 * @version 1.0 * @since JDK 1.8 */ public class Test { /** * @description 验证 * @param paraMap * @return * @returnType boolean * @author ming.li */ private boolean check(Map<String, Object> paraMap) { try { String signUrl = formatUrlMap(paraMap, false, true); String serverSign = md5Str(signUrl); } catch (Exception e) { e.printStackTrace(); } return false; } /** * MD5计算 * * @param url * @return */ public static String md5Str(String url) { try { // 得到一个信息摘要器 MessageDigest digest = MessageDigest.getInstance("md5"); byte[] result = digest.digest(url.getBytes()); StringBuffer buffer = new StringBuffer(); // 把每一个byte 做一个与运算 0xff; for (byte b : result) { // 与运算 int number = b & 0xff;// 加盐 String str = Integer.toHexString(number); if (str.length() == 1) { buffer.append("0"); } buffer.append(str); } // 标准的md5加密后的结果 return buffer.toString().toUpperCase(); } catch (NoSuchAlgorithmException e) { e.printStackTrace(); return ""; } } /** * 格式化排序 * * @param paraMap * @param urlEncode * @param keyToLower * @return */ public static String formatUrlMap(Map<String, Object> paraMap, boolean urlEncode, boolean keyToLower) { String buff = ""; Map<String, Object> tmpMap = paraMap; try { List<Map.Entry<String, Object>> infoIds = new ArrayList<Map.Entry<String, Object>>(tmpMap.entrySet()); // 对所有传入参数按照字段名的 ASCII 码从小到大排序(字典序) Collections.sort(infoIds, new Comparator<Map.Entry<String, Object>>() { @Override public int compare(Map.Entry<String, Object> o1, Map.Entry<String, Object> o2) { return (o1.getKey()).toString().compareTo(o2.getKey()); } }); // 构造URL 键值对的格式 StringBuilder buf = new StringBuilder(); for (Map.Entry<String, Object> item : infoIds) { if (!StringUtils.isEmpty(item.getKey())) { String key = item.getKey(); String val = String.valueOf(item.getValue()); if (urlEncode) { val = URLEncoder.encode(val, "utf-8"); } if (keyToLower) { buf.append(key.toLowerCase() + "=" + val); } else { buf.append(key + "=" + val); } buf.append("&"); } } buff = buf.toString(); if (buff.isEmpty() == false) { buff = buff.substring(0, buff.length() - 1); } } catch (Exception e) { return null; } return buff; } }
首先,将参数进行名称排序。
然后,计算MD5摘要值。
最后,进行比对判断。
相关推荐
实现当前主流签名机制。 对请求参数进行排序 并添加协议key值 进行Md5加密
"jquert特效表单排序"这个主题主要涉及如何利用jQuery实现动态的表单元素排序功能,使得用户可以交互式地调整表单字段的顺序。 首先,我们需要理解jQuery的基本概念。jQuery通过一个"$"符号作为其主要的入口点,...
这个"JAVA-SHA256withRSA.java"文件提供了一个完整的工具类RSAUtils,包含了加签、验签、公钥加密和私钥解密的功能。以下是关于这些知识点的详细解释: 1. **签名(Signing)**: 使用SHA256withRSA进行签名是将...
常用排序算法总结常用排序算法总结常用排序算法总结常用排序算法总结常用排序算法总结常用排序算法总结常用排序算法总结常用排序算法总结常用排序算法总结常用排序算法总结
该程序包含7大排序算法: # sort.bubbleSort() #冒泡排序 # sort.shellSort() #希尔排序 # sort.insertionSort() #插入排序 # sort.Selectionsort1() #选择排序 # sort.heapSort() #堆排序 # sort.countSort() ...
在本主题中,我们将深入探讨如何使用JavaScript对表单数据进行排序。表单数据排序是网页应用中常见的需求,例如,用户可能需要按照特定字段对搜索结果或列表进行升序或降序排列。 首先,理解表单的基本结构至关重要...
在Java编程中,有时我们需要对一组参数按照字典顺序(ASCII码值从小到大)进行排序,例如在创建签名或构建URL查询字符串时。这里提供了一个名为`createSign`的方法,它接受一个`Map, Object>`类型的参数,并返回一个...
(1) 完成5种常用内部排序算法的演示,5种排序算法为:快速排序,直接插入排序,选择排序,堆排序,希尔排序; (2) 待排序元素为整数,排序序列存储在数据文件中,要求排序元素不少于30个; (3) 演示程序开始,...
1) 对以下6种常用的内部排序算法进行比较:起泡排序,直接插入排序,简单选择排序,快速排序,希尔排序,堆排序。 2) 待排序记录的文件个数不小于1000( 其数据用伪随机数产生),至少用5组不同的输入数据作比较;比较...
邹昕光等著作的关于使用HTTP协议进行隐蔽网络通信的参数排序算法,对通信隐藏是一个较大的参考
常用排序算法的动态演示系统 在本系统中,我们主要实现了五种常用的排序算法:冒泡排序法、快速排序法、直接插入排序法、折半插入排序法和树形选择排序法。这些算法都是在计算机科学中最基本和最重要的排序算法,...
本话题主要探讨六种内部排序算法:直接插入排序、希尔排序、冒泡排序、快速排序、选择排序以及堆排序。这六种排序算法各有优劣,适用于不同的场景,接下来我们将逐一进行详细阐述。 1. **直接插入排序**: 直接...
在这个例子中,`sortTable`函数接受两个参数:要排序的列索引(columnIndex)和排序方向(ascending)。它首先获取表格,然后通过循环比较相邻行的指定列值进行排序。如果发现需要交换位置的行,就执行交换操作并...
本文将深入探讨标题"常用排序算法java演示"中涉及的知识点,包括排序算法的原理、Java实现方式以及其在实际应用中的图形演示。 首先,让我们逐一了解几种常见的排序算法: 1. **冒泡排序(Bubble Sort)**:这是一...
这里我们将深入探讨七种常用的排序算法,并通过C++语言实现它们。这七种算法分别是:冒泡排序、选择排序、直接插入排序、希尔排序、堆排序、归并排序和快速排序。 1. **冒泡排序**: 冒泡排序是最基础的排序算法之...
将map按ASCII码排序,适用于将请求头的参数转为map,map内可再含有map,递归排序,无遗漏。运行demo里main方法即可进行验证。
各种常用c++排序算法,包括插入排序、冒泡排序、选择排序、快速排序、归并排序、希尔排序等
插入排序是一种简单直观的排序算法,它的工作原理是通过构建有序序列,对于未排序数据,在已排序序列中从后向前扫描,找到相应位置并插入。插入排序在实现上,通常采用in-place排序(即只需用到O(1)的额外空间的排序...
数据结构-排序(包括常用的插入排序,选择排序,冒泡排序等)
比如在对接第三方支付的时候,第三方会要求参数按照ASCII码从小到大排序。 2、文章: https://blog.csdn.net/z929118967/article/details/108195721 3、【可选】针对签名数组ASCII码排序进行优化(先按照数组元素的...