【Java中将List和Map互相包含的对象的key全部转为小写】

本文介绍了在Java中如何编写一个工具类,通过递归方法处理各种复杂情况,如Map和List嵌套,确保对外接口参数的key值全部转换为小写。

Java中将List和Map互相包含的对象的key全部转为小写

需求

系统对外暴漏接口出参需要规范统一为key值全部小写,但是考虑到业务中出参有字符串、MapListMap包含ListList包含Map的情况,所以写了个Object转换key值工具类

实现思路

使用递归方式调用转换,根据对象类型,使用不同方式遍历转换

实现代码

public static Object convertKeysToLower(Object object) {
        //map类型遍历转换key值
        if (object instanceof Map) {
            Map<String, Object> data = (Map<String, Object>) object;
            Map<String, Object> newData = new HashMap<>();
            for (Map.Entry<String, Object> entry : data.entrySet()) {
                String newKey = entry.getKey().toLowerCase();
                //value值回调自身
                Object newValue = convertKeysToLower(entry.getValue());
                newData.put(newKey, newValue);
            }
            return newData;
            //list类型遍历后循环回调自身
        } else if (object instanceof List) {
            List<Object> data = (List<Object>) object;
            List<Object> newList = new ArrayList<>();
            for (Object item : data) {
                Object newItem = convertKeysToLower(item);
                newList.add(newItem);
            }
            return newList;
            //若为其他类型,如字符串,直接返回
        } else {
            return object;
        }
    }

结语

不知道有没有不通的情况,帮我多测测^^

方案 1:自定义 ResultHandler(推荐) 实现原理:通过实现 MyBatis 的 ResultHandler 接口,在结果集处理阶段直接修改 Map 数据。 适用场景:需要针对特定查询进行字段过滤。 实现步骤: 创建自定义结果处理器: Java public class MapFieldFilterResultHandler implements ResultHandler<Map<String, Object>> { private final List<Map<String, Object>> results = new ArrayList<>(); private final Set<String> excludeFields; public MapFieldFilterResultHandler(Set<String> excludeFields) { this.excludeFields = excludeFields; } @Override public void handleResult(ResultContext<? extends Map<String, Object>> resultContext) { Map<String, Object> originalMap = resultContext.getResultObject(); // 创建新 Map 并过滤字段 Map<String, Object> filteredMap = new LinkedHashMap<>(); originalMap.forEach((key, value) -> { if (!excludeFields.contains(key.toLowerCase())) { // 忽略大小写 filteredMap.put(key, value); } }); results.add(filteredMap); } public List<Map<String, Object>> getFilteredResults() { return results; } } 在 Mapper 接口中使用处理器: Java public List<Map<String, Object>> selectUsersWithoutSensitiveFields() { MapFieldFilterResultHandler resultHandler = new MapFieldFilterResultHandler(Set.of("password", "salt")); // 指定要排除的字段 sqlSession.select("selectUsers", resultHandler); // "selectUsers" 是对应的 SQL ID return resultHandler.getFilteredResults(); } SQL 映射文件保持简单查询: Xml <select id="selectUsers" resultType="map"> SELECT * FROM user <!-- 直接查询所有字段 --> </select> 优势: 代码侵入性低,可精准控制特定查询 支持动态过滤规则 兼容所有 MyBatis 版本 你这个方案在java8怎么实现?
03-29
评论 1
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值