首页 >> 大全

java 加密结果不一致的各个坑

2023-10-10 大全 32 作者:考证青年

java 加密结果不一致的各个坑

1.的 byte[] ()

2.转字符

3.jdk的版本,jvm运行环境的配置

4.是否使用第三方加密类

5.操作系统版本

1、的 byte[] ()方法

此方法作用:使用平台(程序的运行环境)的默认字符集将此 编码字节序列,并将结果存储到新的字节数组中

此方法常用重载方法: byte[] ( ),即使用指定的字符集,将编码为字节序列,并将结果存储到新的字节数组中

加密中的坑点:在加密中,.()是常用方法,如果不指定字符集,此方法将使用平台默认的字符集来进行编码,这样在接口对接中,很可能因为平台默认编码字符集不一致而加密得到不一致的结果,特别是中带有中文时

查看平台默认编码集

System.out.println("默认编码:" + System.getProperty("file.encoding"));

可通过IDEA配置JVM编码集

-Dfile.encoding=GBK

验证效果如图(当前默认编码集为UTF-8)

配置idea默认编码集

由以上运行结果可以发现,对于英文来说GBK,UTF-8编码结果是一致的,但是中文编码结果不一致

2、编码

参考资料:

1.什么是?

2.编码出现换行符

3.百度百科

是一种字符串编码格式,能将任意资料用64种(可打印字符)字元组合(A-Z、a-z、0-9、+、/(还有补位符=)。

的编码规则(规定):

1.把每三个8Bit的字节转换为四个6Bit的字节,原字节数非3倍数,先转6bit,剩余用=补齐(可参照百度百科)

2.每76个字符需要加上一个回车换行

3.最后的结束符也要处理

加密中的坑点:坑点其实就是编码规则中的第二条,每76个字符需要加上一个回车换行,但是不是所有的编码包都遵循这个规范

import sun.misc.BASE64Decoder;
import sun.misc.BASE64Encoder;import java.io.IOException;
import java.util.Base64;public class test {public static void main(String[] args) throws IOException {System.out.println("默认编码:" + System.getProperty("file.encoding"));String englishText = "LisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisaLisa";String chineseText = "李四";//1.jdk rt.jar自带的sun.misc.BASE64EncoderString s = new BASE64Encoder().encodeBuffer(englishText.getBytes());String r = new String(new BASE64Decoder().decodeBuffer(s));//2.jdk rt.jar自带的java.util.Base64String s1 = Base64.getEncoder().encodeToString(englishText.getBytes());String r1 = new String(Base64.getDecoder().decode(s1));//3.Apache Commons CodecString s2 = org.apache.commons.codec.binary.Base64.encodeBase64String(englishText.getBytes());String r2 = new String(org.apache.commons.codec.binary.Base64.decodeBase64(s2));System.out.println("------------------------------------");System.out.println("sun.misc.BASE64Encoder加密:\n"+s);System.out.println("sun.misc.BASE64Decoder解密:\n"+r);System.out.println("------------------------------------");System.out.println("java.util.Base64加密:\n"+s1);System.out.println("java.util.Base64解密:\n"+r1);System.out.println("------------------------------------");System.out.println("org.apache.commons.codec.binary.Base64加密:\n"+s2);System.out.println("org.apache.commons.codec.binary.Base64解密:\n"+r2);System.out.println("------------------------------------");}
}

java加密技术__java加密与解密的艺术

运行结果如下:

由以上运行结果可以发现,

sun.misc.加密,每76个字符会加上回车换行,末尾也会加上回车换行java.util.和mons.codec..运行结果是一致的,不包含回车换行

经过测试 java.util.解析sun.misc.会解析失败,所以使用mons.codec..来转为佳,不用担心效率问题以及编码包之间的差异 3、编码

各中间件url传输的默认编码可能不一致

默认的在url传输时是用iso-8859-1编码。

解决方案一:

在使用get传输参数时,将参数中的中文转换成url格式,也就是使用和来传输,使用这种方式就是把中文转换成以%开头的编码在url中传输。

使用这种方法时,要注意两点。

1.前台使用,在后台相应的使用(浏览器在后台会自动执行一次 )。

2.使用的内容是参数内空。千万要注意,他是会把等于号等符号也给转换了。所以,最好是先把参数传换后再进行拼接。而不是把url拼接好再去转换。

解决方案二:

配置,使用其在url传输过程中使用相应的支持中文的编码。一般国内的喜欢用gbk或。我个人建议使用utf-8

在的/conf/.xml文件中,找到以下这一行。

这行的意思也就是使用8080端口来接收html的请求。在这里可以加几个参数来配置不同的效果。

=“UTF-8”设置url传输时对url内容的编码格式

关于我们

最火推荐

小编推荐

联系我们


版权声明:本站内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 88@qq.com 举报,一经查实,本站将立刻删除。备案号:桂ICP备2021009421号
Powered By Z-BlogPHP.
复制成功
微信号:
我知道了