map排序工具类java_Java | Map排序,工具类改进

packageutil;importjava.util.ArrayList;importjava.util.Collections;importjava.util.Comparator;importjava.util.Date;importjava.util.LinkedHashMap;importjava.util.List;importjava.util.Map;importjava.util.Map.Entry;/***

*

*@authorYangChaoJie

**/

public classReqUtil {/***

* 将请求对象传入,进行对象转Map,排序,进行MD5加密;

*

*@paramreq

*@return

*/

private staticStringBuilder stringBuilder;private staticString currTime;/***

* hashCode加密字符串

*

*@return

*/

public static LinkedHashMapParameToMap(Object reqData) {

stringBuilder= newStringBuilder();

stringBuilder.append("he3yun.com-");

@SuppressWarnings("unchecked")

LinkedHashMap map =ZJ_BeanToMapUtils.toMap(reqData);

List> list = new ArrayList>(map.entrySet());

Collections.sort(list,new Comparator>() {public int compare(Entry o1, Entryo2) {returnString.valueOf(o1.getValue()).toLowerCase()

.compareTo(String.valueOf(o2.getValue()).toLowerCase());

}

});returnCheckData(reqData, list);

}/***

* 根据不同的构造方法参数生成对应Map对象,进行加密

*

*@paramreqData

*@paramlist

*@return

*/

private static LinkedHashMap CheckData(Object reqData, List>list) {

LinkedHashMap dataMap = new LinkedHashMap();returntraverseEntryToMap(reqData, dataMap, list);

}/***

* 提高复用写的方法

*

*@paramdataMap

*@paramlist

*@return

*/

private static LinkedHashMaptraverseEntryToMap(Object reqData,

LinkedHashMap dataMap, List>list) {for (Entrymapping : list) {if (mapping.getValue() != null) {

stringBuilder.append(String.valueOf(mapping.getValue())+ "-");

dataMap.put(mapping.getKey(), mapping.getValue());

}

}

getCurrTime();

stringBuilder.append(currTime);

dataMap.put("hashCode", MD5Util.stringToMD5(String.valueOf(stringBuilder)));

dataMap.put("timestamp", currTime);returndataMap;

}public static voidgetCurrTime() {

currTime= String.valueOf(newDate().getTime());

}/*** MAP排序

*@parammap*/

public static LinkedHashMap sortMap(LinkedHashMapmap) {

List> list = new ArrayList>(map.entrySet());

Collections.sort(list,new Comparator>() {public int compare(Entry o1, Entryo2) {returnString.valueOf(o1.getValue()).toLowerCase()

.compareTo(String.valueOf(o2.getValue()).toLowerCase());

}

});returnmap;

}

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值