Một file nén ZIP có thể có 2 mật khẩu? Tại sao lại như vậy?

File nén ZIP có cài mật khẩu là phương thức phổ biến để nén và chia sẻ các file một cách an toàn, từ dữ liệu nhạy cảm đến mã độc...

Tuy nhiên, bạn có biết rằng một file ZIP có thể có tới 2 mật khẩu chính xác và cả hai đều tạo ra cùng một kết quả khi file ZIP được giải nén?

Một file ZIP có thể có hai mật khẩu?

Arseniy Sharoglazov, một nhà nghiên cứu an ninh mạng tại Positive Technologies, đã chia sẻ vào cuối tuần qua một thử nghiệm tưởng đơn giản nhưng lại khá thần kỳ. Trong đó, anh tạo ra một file ZIP được bảo vệ bởi mật khẩu có tên x.zip.

Mật khẩu mà Sharoglazov chọn để mã hóa file ZIP là một cách chơi chữ của bản hit Never Gonna Give You Up năm 1987 của Rick Astley, thứ đã trở thành một meme phổ biến trong làng công nghệ:

Nev1r-G0nna-G2ve-Y8u-Up-N5v1r-G1nna-Let-Y4u-D1wn-N8v4r-G5nna-D0sert-You

Nhưng nhà nghiên cứu còn chứng minh rằng khi giải nén file x.zip bằng một mật khẩu hoàn toàn khác, anh không hề gặp bất cứ lỗi nào.

Trên thực tế, việc sử dụng mật khẩu khác cho phép trích xuất thành công file ZIP, nội dung ban đầu còn nguyên vẹn:

pkH8a0AqNbHcdw8GrmSp
Một file ZIP có thể mở bằng hai mật khẩu
Một file ZIP có thể mở bằng hai mật khẩu

Điều này diễn ra như thế nào?

Làm thế nào mà Sharoglazov có thể sử dụng hai mật khẩu cho một file ZIP? Một người dùng Twitter có tên Unblvr giải thích: Khi tạo một file ZIP có mật khẩu với chế độ AES-256 được bật, định dạng ZIP sử dụng thuật toán PBKDF2 và băm mật khẩu do người dùng cung cấp, nếu mật khẩu quá dài. Mật khẩu trên 64 bytes (ký tự) sẽ là quá dài.

Lúc đó, thay vì mật khẩu đã chọn của người dùng (trong trường hợp này là "Nev1r-G0nna-G2ve-...", hàm băm mới vừa được tính toán sẽ trở thành mật khẩu thực sự của file.

Khi người dùng giải nén file và nhập mật khẩu dài hơn 64 bytes ("Nev1r-G0nna-G2ve-..."), những gì người dùng nhập vào một lần nữa sẽ được ứng dụng ZIP băm và so sánh một lần nữa với mật khẩu chính xác (mật khẩu giờ đây là một hàm băm). Kết quả so sánh phù hợp nên việc trích xuất tệp thành công.

Mật khẩu thay thế được sử dụng trong ví vụ này ("pkH8a0AqNbHcdw8GrmSp") trên thực tế là biểu diễn ASCII của hàm băm SHA-1 của mật khẩu dài ("Nev1r-G0nna-G2ve-...").

Checksum SHA-1 của "Nev1r-G0nna-G2ve-..." = 706b4838613041714e62486364773847726d5370.

Checksum này sau khi được chuyển đổi thành ASCII sẽ tạo ra: pkH8a0AqNbHcdw8GrmSp.

Tuy nhiên, bạn cần lưu ý rằng khi mã hóa hoặc giải mã một file, quá trình băm chỉ xảy ra nếu độ dài của mật khẩu lớn hơn 64 ký tự.

Nói cách khác, mật khẩu ngắn hơn sẽ không được băm ở cả hai giai đoạn nén và giải nén file ZIP.

Dẫu vậy, bạn cần phải chú ý rằng không phải lúc nào biểu diễn ASCII của hàm băm SHA-1 của một mật khẩu dài cũng là chuỗi ký tự và số. Đôi khi, nó tạo ra một tập hợp các byte vô nghĩa, không thể nhập được vào ô mật khẩu.

Chính Sharoglazov cũng phải sử dụng một công cụ khôi phục mật khẩu nguồn mở hashcat với một chút sửa đổi để tìm ra mật khẩu có biểu diễn ASCII hợp lý. Anh đã thử các biến thể "Nev0r, Nev1r, Nev2r..." cho tới khi tìm ra mật khẩu sạch chỉ bao gồm các ký tự và số (pkH8a0AqNbHcdw8GrmSp).

Với người dùng thông thường, việc sử dụng file ZIP với mật khẩu là đã đảm bảo được sự an toàn. Tuy nhiên, thử nghiệm này cung cấp cho bạn cái nhìn về một trong những bí ẩn xung quanh việc file ZIP được mã hóa cũng như cách làm thế nào để có 2 mật khẩu cho file ZIP của bạn.

Thứ Hai, 22/08/2022 09:26
52 👨 1.165
1 Bình luận
Sắp xếp theo
  • Nguyễn Hồng Chuyên
    Nguyễn Hồng Chuyên

    vậy là giờ mình tạo 1 file zip với mật khẩu là:
    Nev1r-G0nna-G2ve-Y8u-Up-N5v1r-G1nna-Let-Y4u-D1wn-N8v4r-G5nna-D0sert-You
    thì có thể mở khoá bằng chính mât khẩu đó, cộng thêm, cả mật khẩu:
    pkH8a0AqNbHcdw8GrmSp
    à anh?


    Thích Phản hồi 22/08/22
    ❖ Chuyện công nghệ