av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

java - 關于字符串編碼。

瀏覽:112日期: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[]轉換成String時,有些字節是未必能轉換成字符的,比如第一個-106、第二個-85就是,所以轉換成String時前兩個就變成了未知字符(表面上會顯示?,但實際上是一個Unicode字符),再轉成byte[](你這邊defaultCharset應該是UTF-8吧),每個未知字符就變成3個字節了。

如果用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]

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

標簽: java
相關文章:
主站蜘蛛池模板: 精品无码久久久久久国产 | 一区二区中文 | 麻豆视频在线免费看 | 久久国产一区二区三区 | 日韩91| 亚洲一区中文字幕在线观看 | 91精品久久久久久久久久小网站 | 欧美黄色小视频 | 99热欧美 | 午夜小电影 | 欧美一级大片免费看 | 免费观看色 | 亚洲一区二区三区乱码aⅴ 四虎在线视频 | 久久精品免费 | 中文字幕在线一区二区三区 | 日本精品一区 | 亚洲精品一区二区三区中文字幕 | 亚洲精品精品 | 欧美一区二区三区视频 | 在线观看免费av网站 | 欧美啪啪| 国产性网 | 免费影视在线观看 | 国产欧美在线观看 | 日韩理论电影在线观看 | 久久久亚洲一区 | 亚洲欧美中文日韩在线v日本 | 91麻豆精品国产91久久久更新资源速度超快 | 91观看 | 99久久婷婷| 视频一区二区在线观看 | 日本特黄a级高清免费大片 成年人黄色小视频 | 日韩在线观看精品 | 欧美精品欧美精品系列 | 国产aaaaav久久久一区二区 | 久久久久久蜜桃一区二区 | 成人二区 | 日日操夜夜干 | 久久久精品一区 | 精品视频网 | 欧美成人高清 |