亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術(shù)文章
文章詳情頁

java - 關(guān)于字符串編碼。

瀏覽:109日期:2023-11-15 08:10:59

問題描述

public static void main(String[] args) throws Exception { String str = 'resource'; System.out.println(Arrays.toString(getHash(str,'MD5').getBytes()));//使用默認解碼后輸出}public static String getHash(String str, String hashType) { try {MessageDigest digest = MessageDigest.getInstance(hashType);digest.reset();byte[] b = digest.digest(str.getBytes());System.out.println(Arrays.toString(b)); //編碼前輸出return new String(b); //使用默認編碼 } catch (NoSuchAlgorithmException e) {e.printStackTrace(); } return str;}

輸出:[-106, -85, 78, 22, 63, 78, -32, 58, -86, 77, 16, 81, -86, 81, -46, 4]

[-17, -65, -67, -17, -65, -67, 78, 22, 63, 78, -17, -65, -67, 58, -17, -65, -67, 77, 16, 81, -17, -65, -67, 81, -17, -65, -67, 4]

為什么編碼前和編碼后再解碼所輸出的不一樣?

問題解答

回答1:

你可能認為(new String(b)).getBytes().equals(b),實際上并非如此。(盡管new String(s.getBytes()).equals(s)一定是。)

因為byte[]轉(zhuǎn)換成String時,有些字節(jié)是未必能轉(zhuǎn)換成字符的,比如第一個-106、第二個-85就是,所以轉(zhuǎn)換成String時前兩個就變成了未知字符(表面上會顯示?,但實際上是一個Unicode字符),再轉(zhuǎn)成byte[](你這邊defaultCharset應(yīng)該是UTF-8吧),每個未知字符就變成3個字節(jié)了。

如果用GBK的話,情況還算好,但還是略有不同:

[-106, -85, 78, 22, 63, 78, -32, 58, -86, 77, 16, 81, -86, 81, -46, 4][-106, -85, 78, 22, 63, 78, 63, 58, -86, 77, 16, 81, -86, 81, 63, 4]

所以結(jié)論是:如果用String表示一個Hash值,不能把byte[]強轉(zhuǎn)換成String,而是按慣例轉(zhuǎn)換成16進制表示

標簽: java
相關(guān)文章:
主站蜘蛛池模板: 一级片在线播放 | 亚洲国产精品久久日 | 免费人成年短视频在线观看网站 | 国产深夜福利 | 久草高清视频 | 99国产精品热久久久久久夜夜嗨 | 在线观看视频一区 | 在线毛片一区二区不卡视频 | 中国黄色一级大片 | 萌白酱粉嫩jk福利在线观看 | 在线播放亚洲视频 | 亚洲国产精品一区二区首页 | 一个人看的www日本高清视频 | 一级毛片aaaaaa免费看 | 鸥美性生交xxxxx久久久 | 国产一区二区亚洲精品天堂 | 天天综合色一区二区三区 | 欧美亚洲国产成人精品 | 国产盗摄视频 | 欧美一级片免费 | 久久精品爱国产免费久久 | 亚洲天堂免费 | 99视频免费在线 | 成人免费观看网欧美片 | www.av网| 日韩欧美在线观看视频 | 亚洲精品综合欧美一区二区三区 | 玖玖国产在线 | 又黄又www | 国产精品久久久久免费 | 久久久久久久久久久9精品视频 | www黄网| 日韩三级在线播放 | 中文字幕亚洲国产 | 亚洲精品成人在线 | 国产欧美va欧美va香蕉在线 | 国产精品欧美韩国日本久久 | 2019天天操天天干天天透 | 久久精品国产亚洲高清 | 久久精品免视看国产明星 | 91精品国产爱久久久久 |