All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.xkcoding.http.util.MapUtil Maven / Gradle / Ivy

Go to download

修复 HttpClientImpl timeout 配置失效问题, forked from https://github.com/xkcoding/simple-http, 简单的 http 实现

The newest version!
/*
 * Copyright (c) 2019-2029, xkcoding & Yangkai.Shen & 沈扬凯 ([email protected] & xkcoding.com).
 * 

* Licensed under the GNU LESSER GENERAL PUBLIC LICENSE 3.0; * you may not use this file except in compliance with the License. * You may obtain a copy of the License at *

* http://www.gnu.org/licenses/lgpl.html *

* Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.xkcoding.http.util; import com.xkcoding.http.constants.Constants; import lombok.experimental.UtilityClass; import java.util.*; import java.util.function.BiConsumer; /** *

* Map 工具类 *

* * @author yangkai.shen * @date Created in 2019/12/24 21:07 */ @UtilityClass public class MapUtil { /** * 判断 map 不为空 * * @param map map * @return {@code true} - 不为空,{@code false} - 空 */ public boolean isNotEmpty(Map map) { return map != null && !map.isEmpty(); } /** * 判断 map 为空 * * @param map map * @return {@code true} - 空,{@code false} - 不为空 */ public boolean isEmpty(Map map) { return !isNotEmpty(map); } /** * 遍历 * * @param map 待遍历的 map * @param action 操作 * @param map键泛型 * @param map值泛型 */ public void forEach(Map map, BiConsumer action) { if (isEmpty(map) || action == null) { return; } for (Map.Entry entry : map.entrySet()) { K k; V v; try { k = entry.getKey(); v = entry.getValue(); } catch (IllegalStateException ise) { // this usually means the entry is no longer in the map. throw new ConcurrentModificationException(ise); } action.accept(k, v); } } /** * map转字符串,转换后的字符串格式为 {@code xxx=xxx&xxx=xxx} * * @param params 待转换的map * @param encode 是否转码 * @return str */ public String parseMapToString(Map params, boolean encode) { List paramList = new ArrayList<>(); forEach(params, (k, v) -> { if (v == null) { paramList.add(k + "="); } else { paramList.add(k + "=" + (encode ? UrlUtil.urlEncode(v) : v)); } }); return String.join("&", paramList); } /** * 字符串转map,字符串格式为 {@code xxx=xxx&xxx=xxx} * * @param str 待转换的字符串 * @param decode 是否解码 * @return map */ public Map parseStringToMap(String str, boolean decode) { str = preProcess(str); Map params = new HashMap<>(16); if (StringUtil.isEmpty(str)) { return params; } if (!str.contains("&")) { params.put(decode(str, decode), Constants.EMPTY); return params; } final int len = str.length(); String name = null; // 未处理字符开始位置 int pos = 0; // 未处理字符结束位置 int i; // 当前字符 char c; for (i = 0; i < len; i++) { c = str.charAt(i); // 键值对的分界点 if (c == '=') { if (null == name) { // name可以是"" name = str.substring(pos, i); } pos = i + 1; } // 参数对的分界点 else if (c == '&') { if (null == name && pos != i) { // 对于像&a&这类无参数值的字符串,我们将name为a的值设为"" addParam(params, str.substring(pos, i), Constants.EMPTY, decode); } else if (name != null) { addParam(params, name, str.substring(pos, i), decode); name = null; } pos = i + 1; } } // 处理结尾 if (pos != i) { if (name == null) { addParam(params, str.substring(pos, i), Constants.EMPTY, decode); } else { addParam(params, name, str.substring(pos, i), decode); } } else if (name != null) { addParam(params, name, Constants.EMPTY, decode); } return params; } private void addParam(Map params, String key, String value, boolean decode) { key = decode(key, decode); value = decode(value, decode); if (params.containsKey(key)) { params.put(key, params.get(key) + "," + value); } else { params.put(key, value); } } private String decode(String str, boolean decode) { return decode ? UrlUtil.urlDecode(str) : str; } private String preProcess(String str) { if (StringUtil.isEmpty(str)) { return str; } // 去除 URL 路径信息 int beginPos = str.indexOf("?"); if (beginPos > -1) { str = str.substring(beginPos + 1); } // 去除 # 后面的内容 int endPos = str.indexOf("#"); if (endPos > -1) { str = str.substring(0, endPos); } return str; } }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy