JAVA 解决URLEncoder加密后,%后的字母变成小写

本文涉及的产品
密钥管理服务KMS,1000个密钥,100个凭据,1个月
简介: JAVA 解决URLEncoder加密后,%后的字母变成小写

前言



当你搜到这篇文章,我感觉多半是因为对接了.NET的相关接口。


在C#里面,使用HttpUtility.UrlEncode(xxx); 出来的值,% 后面的字母是小写的;


而在java里面,URLEncoder.encode(xxx, "utf-8"); 出来的值, % 后面的字母是大写的;


正文



加密


将url编码函数加密后的值,% 后面的字母转为小写, 使其与C# 使用

HttpUtility.UrlEncode(xxx)的值一样:


    public static String getEncode(String needEncodeStr) throws UnsupportedEncodingException {
        String encodeStr = URLEncoder.encode(needEncodeStr, "utf-8");
        String[] uppercase = new String[0XFF + 1];
        String[] lowercase = new String[0XFF + 1];
        for (int i = 0; i <= 0XFF; i++) {
            uppercase[i] = "%" + String.format("%02x", i);
            lowercase[i] = uppercase[i];
            uppercase[i] = uppercase[i].toUpperCase();
        }
      return   StringUtils.replaceEach(encodeStr, uppercase, lowercase);
// StringUtils.replaceEac :org.apache.commons.lang3.StringUtils;
    }


测试,可以看到如愿,%后的大写字母已经变成小写,而且是针对特殊的符合转换的那一部分:


    public static void main(String[] args) throws UnsupportedEncodingException {
        String needEncodeStr="https://jcTest.com";
        String encodeStr = URLEncoder.encode(needEncodeStr, "utf-8");
        System.out.println("正常java的url编码函数加密后:"+encodeStr);
        String encodeStrNew = getEncode(needEncodeStr);
        System.out.println("大写字母变小写的处理后:"+encodeStrNew);
    }

image.png

解密


那么如果涉及到url编码函数解密,上面得到的小写字母值,


用java的URLDecoder.decode(xxx,"UTF-8");


        String encodeStr="https%3a%2f%2fjcTest.com";
        String decode = URLDecoder.decode(encodeStr, "UTF-8");
        System.out.println(decode);


测试结果:


image.png


可以看到解密的时候,%后面的小写大写并没有什么影响,还是能正常解密。

 

但是如果你不放心,那么可以先将%后面的小写字母重新转换回大写,再进行解密,也是可以的。


        String encodeStr="https%3a%2f%2fjcTest.com";
        String decode1 = getDecode(encodeStr);
        System.out.println(decode1);


    public static String getDecode(String encodeStr) throws UnsupportedEncodingException {
        String[] uppercase = new String[0XFF + 1];
        String[] lowercase = new String[0XFF + 1];
        for (int i = 0; i <= 0XFF; i++) {
            uppercase[i] = "%" + String.format("%02x", i);
            lowercase[i] = uppercase[i];
            uppercase[i] = uppercase[i].toUpperCase();
        }
        String s = StringUtils.replaceEach(encodeStr, lowercase, uppercase);
        return   URLDecoder.decode(s,"UTF-8");
    }


测试结果:


image.png

相关文章
|
15天前
|
JSON 前端开发 Java
【Bug合集】——Java大小写引起传参失败,获取值为null的解决方案
类中成员变量命名问题引起传送json字符串,但是变量为null的情况做出解释,@Data注解(Spring自动生成的get和set方法)和@JsonProperty
|
3月前
|
Java Maven 数据安全/隐私保护
如何实现Java打包程序的加密代码混淆,避免被反编译?
【10月更文挑战第15天】如何实现Java打包程序的加密代码混淆,避免被反编译?
464 2
|
3月前
|
安全 算法 Java
数据库信息/密码加盐加密 —— Java代码手写+集成两种方式,手把手教学!保证能用!
本文提供了在数据库中对密码等敏感信息进行加盐加密的详细教程,包括手写MD5加密算法和使用Spring Security的BCryptPasswordEncoder进行加密,并强调了使用BCryptPasswordEncoder时需要注意的Spring Security配置问题。
233 0
数据库信息/密码加盐加密 —— Java代码手写+集成两种方式,手把手教学!保证能用!
|
4月前
|
安全 Java 数据安全/隐私保护
- 代码加密混淆工具-Java 编程安全性
在Java编程领域,保护代码安全与知识产权至关重要。本文探讨了代码加密混淆工具的重要性,并介绍了五款流行工具:ProGuard、DexGuard、Jscrambler、DashO 和 Ipa Guard。这些工具通过压缩、优化、混淆和加密等手段,提升代码安全性,保护知识产权。ProGuard 是开源工具,用于压缩和混淆Java代码;DexGuard 专为Android应用程序设计,提供强大加密功能;Jscrambler 基于云,保护Web和移动应用的JavaScript及HTML5代码;DashO 支持多种Java平台和
277 1
|
5月前
|
安全 Java 应用服务中间件
网络安全的护城河:漏洞防御与加密技术深入浅出Java并发编程
【8月更文挑战第31天】在数字世界的棋盘上,每一次点击都可能是一步棋。网络安全的战场无声却激烈,漏洞如同裂缝中的风,悄无声息地侵袭着数据的堡垒。本文将揭示网络漏洞的隐蔽角落,探讨如何通过加密技术筑起防线,同时提升个人和组织的安全意识,共同守护我们的数字家园。
|
5月前
|
安全 算法 Java
java系列之~~网络通信安全 非对称加密算法的介绍说明
这篇文章介绍了非对称加密算法,包括其定义、加密解密过程、数字签名功能,以及与对称加密算法的比较,并解释了非对称加密在网络安全中的应用,特别是在公钥基础设施和信任网络中的重要性。
|
存储 算法 前端开发
一文带你学会国产加密算法SM4的java实现方案
今天给大家带来一个国产SM4加密解密算法的java后端解决方案,代码完整,可以直接使用,希望给大家带来帮助,尤其是做政府系统的开发人员,可以直接应用到项目中进行加密解密。
3164 1
|
5天前
|
监控 Java
java异步判断线程池所有任务是否执行完
通过上述步骤,您可以在Java中实现异步判断线程池所有任务是否执行完毕。这种方法使用了 `CompletionService`来监控任务的完成情况,并通过一个独立线程异步检查所有任务的执行状态。这种设计不仅简洁高效,还能确保在大量任务处理时程序的稳定性和可维护性。希望本文能为您的开发工作提供实用的指导和帮助。
42 17
|
15天前
|
Java
Java—多线程实现生产消费者
本文介绍了多线程实现生产消费者模式的三个版本。Version1包含四个类:`Producer`(生产者)、`Consumer`(消费者)、`Resource`(公共资源)和`TestMain`(测试类)。通过`synchronized`和`wait/notify`机制控制线程同步,但存在多个生产者或消费者时可能出现多次生产和消费的问题。 Version2将`if`改为`while`,解决了多次生产和消费的问题,但仍可能因`notify()`随机唤醒线程而导致死锁。因此,引入了`notifyAll()`来唤醒所有等待线程,但这会带来性能问题。
Java—多线程实现生产消费者
|
1天前
|
缓存 安全 算法
Java 多线程 面试题
Java 多线程 相关基础面试题