import java.util.Arrays;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
public class ConverUitl {
    /**
     *
     * map转str
     * @param map
     * @return
     */
    public static String getMapToString(Map<String, String> map) {
        Set<String> keySet = map.keySet();
        // 将set集合转换为数组
        String[] keyArray = keySet.toArray(new String[keySet.size()]);
        // 给数组排序(升序)
        Arrays.sort(keyArray);
        // 因为String拼接效率会很低的,所以转用StringBuilder。博主会在这篇博文发后不久,会更新一篇String与StringBuilder开发时的抉择的博文。
        StringBuilder sb = new StringBuilder();
        for (int i = 0; i < keyArray.length; i++) {
            // 参数值为空,则不参与签名 这个方法trim()是去空格
            if (map.get(keyArray[i]).trim().length() > 0) {
                sb.append(keyArray[i]).append("=").append(map.get(keyArray[i]).trim());
            }
            if (i != keyArray.length - 1) {
                sb.append("&");
            }
        }
        return sb.toString();
    }
    /**
     * String转map
     * @param str
     * @return
     */
    public static Map<String, String> getStringToMap(String str) {
        // 感谢bojueyou指出的问题
        // 判断str是否有值
        if (null == str || "".equals(str)) {
            return null;
        }
        // 根据&截取
        String[] strings = str.split("&");
        // 设置HashMap长度
        int mapLength = strings.length;
        // 判断hashMap的长度是否是2的幂。
        if ((strings.length % 2) != 0) {
            mapLength = mapLength + 1;
        }
        Map<String, String> map = new HashMap<>(mapLength);
        // 循环加入map集合
        for (int i = 0; i < strings.length; i++) {
            // 截取一组字符串
            String[] strArray = strings[i].split("=");
            // strArray[0]为KEY strArray[1]为值
            map.put(strArray[0], strArray[1]);
        }
        return map;
    }
}