成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Java 獲得文件的指紋

開發 前端
在文件上傳到服務器的時候,我們希望能夠獲得文件的指紋以確定文件沒有被篡改過。常用的算法最開始使用的是 MD5,隨后隨著技術的發展,MD5 算法已經被確定是不安全的了。

在文件上傳到服務器的時候,我們希望能夠獲得文件的指紋以確定文件沒有被篡改過。

常用的算法最開始使用的是 MD5,隨后隨著技術的發展,MD5 算法已經被確定是不安全的了。

目前可能使用更多的是 HSA3_256 哈希算法。

哈希算法通常有以下幾個特點:

  • 正像快速:原始數據可以快速計算出哈希值
  • 逆向困難:通過哈希值基本不可能推導出原始數據
  • 輸入敏感:原始數據只要有一點變動,得到的哈希值差別很大
  • 沖突避免:很難找到不同的原始數據得到相同的哈希值

哈希算法主要有MD4、MD5、SHA。

  • MD4 1990年 輸出128位 (已經不安全)
  • MD5 1991年 輸出128位 (已經不安全)
  • SHA-0 1993年 輸出160位 (發布之后很快就被NSA撤回,是SHA-1的前身)
  • SHA-1 1995年 輸出160位 (已經不安全)
  • SHA-2包括SHA-224、SHA-256、SHA-384,和 SHA-512,分別輸出224、256、384、512位。 (目前安全)

在 Java 中,可以使用 Apache 提供的 Apache Commons Codec,非常容易的獲得文件的哈希字符串指紋。

方法也非常簡單,第一步就是需要將文件讀取為 InputStream。

如果自己寫的話,可能這一步有點代碼。

你可以使用 Apache 提供的

  1. FileUtils.openInputStream 

就可以直接將文件讀取為 InputStream 了。

考察下面的代碼:

  1. InputStream is = FileUtils.openInputStream(new  
  2. File(SCOConstants.PATH_DATA_EXCHANGE + "Estimated vs Original Manual 
  3.  (JIRA) 10-23-20.csv")); 

MD5 哈希

 

Java 獲得文件的指紋

600px-MD5_algorithm.svg600×659 18.4 KB

在文件讀取后,你只需要使用 Apache Commons Codec 提供的 DigestUtils 方法就可以了。

 

  1. /** 
  2.   * Test to get file's MD5 Hash 
  3.   * 
  4.   * @throws Exception 
  5.   */ 
  6.  @Test 
  7.  public void fileMD5Test() throws Exception { 
  8.  
  9.      String md5 = StringUtils.EMPTY; 
  10.  
  11.      try { 
  12.          InputStream is = FileUtils.openInputStream(new File(SCOConstants.PATH_DATA_EXCHANGE + "Estimated vs Original Manual (JIRA) 10-23-20.csv")); 
  13.          md5 = DigestUtils.md5Hex(is); 
  14.      } catch (Exception e) { 
  15.          e.printStackTrace(); 
  16.      } 
  17.      logger.debug("MD5 for File: {}", md5); 
  18.  } 

上面的代碼就可以直接獲得 InputStream 的 MD5 哈希。

程序的輸出為:

  1. 09:32:31.522 [main] DEBUG c.i.s.c.t.utilities.CodecUtilsTest - MD5  
  2. for File: 1ec6473fc1bd50a982767f555734af64 

SHA3 256

與 MD5 哈希算法是一致的。

 

Java 獲得文件的指紋

Sha-3_11280×668 43 KB

你需要首先也將文件讀取為 InputStream ,然后使用 Apache 提供的 DigestUtils.sha3_256Hex(is); 就可以了。

考察下面的代碼:

 

  1. /** 
  2.    * Test to get file's SHA3_256Hex Hash 
  3.    * 
  4.    * @throws Exception 
  5.    */ 
  6.   @Test 
  7.   public void fileSHA3_256HexTest() throws Exception { 
  8.  
  9.       String sha3Hex256 = StringUtils.EMPTY; 
  10.  
  11.       try { 
  12.           InputStream is = FileUtils.openInputStream(new File(SCOConstants.PATH_DATA_EXCHANGE + "Estimated vs Original Manual (JIRA) 10-23-20.csv")); 
  13.           sha3Hex256 = DigestUtils.sha3_256Hex(is); 
  14.       } catch (Exception e) { 
  15.           e.printStackTrace(); 
  16.       } 
  17.       logger.debug("SHA3_256Hex for File: {}", sha3Hex256); 
  18.   } 

運行程序的輸出為: 

  1. 09:35:48.093 [main] DEBUG c.i.s.c.t.utilities.CodecUtilsTest - 
  2. SHA3_256Hex for File: 
  3. 47ec963787f3acf88747ca7a37ccac9e2cc9b05c87eda1852cb4bc3b0273a431 

 

責任編輯:未麗燕 來源: 今日頭知
相關推薦

2014-08-05 10:30:58

tripwirelinux

2009-06-18 10:11:59

指紋Web安全

2012-12-24 15:00:56

sis塞班

2018-12-25 23:01:14

2015-12-14 11:42:27

指紋安全指紋掃描指紋識別

2021-05-27 13:19:21

人工智能物聯網大數據

2014-12-30 13:29:00

指紋識別生物識別身份驗證

2015-07-06 14:32:10

2021-03-05 06:39:54

指紋Web識別

2020-03-18 10:04:34

存儲機器學習服務器

2010-05-14 14:30:07

安裝MySQL

2010-09-02 14:43:25

RHCE

2010-10-11 11:46:20

MySQL主鍵

2012-03-07 16:58:32

專利

2014-11-27 17:10:46

身份認證認知指紋生物識別

2011-06-02 11:13:07

2021-02-20 09:03:47

SSH密鑰指紋

2013-12-30 14:17:22

WAFWAF指紋探測WAF檢測

2021-11-06 07:42:04

驗證開發流程

2019-01-10 09:20:26

OEM PCWindowsLinux
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 欧美一二区 | 精品福利在线 | 国产999精品久久久久久 | 蜜桃臀av一区二区三区 | 91久久久久久久久久久久久 | 美女视频黄的免费 | 国产精品久久久久久久免费大片 | 亚洲欧美日韩网站 | 91国内精品久久 | 999免费网站 | 日韩欧美在线播放 | 国内精品久久精品 | 精品日韩一区二区 | 国产精产国品一二三产区视频 | 精品国产视频 | 久久国产婷婷国产香蕉 | 91精品国产一区二区三区 | 麻豆毛片| 亚州精品天堂中文字幕 | 中文字幕不卡在线观看 | 国产精品美女久久久久久久网站 | 欧美成人激情视频 | 91精品国产91久久久久久最新 | 国产精品亚洲成在人线 | 久久亚洲一区二区 | 2019天天干夜夜操 | av资源在线看 | 精品一区二区三区四区 | 国产成人免费视频网站高清观看视频 | 精品国产一区二区三区在线观看 | 国产精品久久久久aaaa九色 | 奇色影视 | 中文字幕成人av | 亚洲精品视频在线 | 国产在线观看一区二区三区 | 精品视频国产 | 毛片一区 | 欧美久久免费观看 | 综合伊人| 久久精品69 | 亚洲高清视频在线观看 |