Hướng dẫn dùng salting security trong PHP
Tìm hiểu khi sử dụng các hàm băm tạo dữ liệu lưu trữ passwordKhi lưu trữ password vào CSDL thường sẽ sử dụng các hàm băm khác nhau được hỗ trợ bởi hệ CSDL hoặc ngôn ngữ lập trình (như MD5, SHA1 ...) để tạo dữ liệu mã hóa, dữ liệu mã hóa đó được lưu vào CSDL. Ví dụ: Show
$raw_password = 'abc123'; $crypt = md5($raw_password); //e99a18c428cb38d5f260853678922e03 Ví dụ trên, đã sử dụng hàm băm của PHP là Bởi vì hàm băm tạo ra các giá trị không thể dịch ngược (không có thuật toán để giải
giá trị hash Sử dụng Salt tăng cường an toàn cho mật khẩuĐể phức tạp hóa mật khẩu lưu trữ, thì các mật khẩu gốc trước khi mã hóa được nối thêm các chuỗi, các
chuỗi thêm này gọi là Ví dụ: $raw_password = 'abc123'; //Sinh ra chuỗi dài 32 ngẫu nhiên, cũng cần lưu chuỗi này vào một cột trong DB $salt = random_bytes(32); //Sử dụng thêm một salt cố định $staticSalt = 'G4334#'; $crypt = md5($staticSalt.$raw_password.$salt); Giờ mật khẩu lưu trữ ở trên phức tạp hơn rất nhiều. Biết được Trước khi bạn làm bất cứ điều gì thêm, hãy tìm hiểu sự khác biệt giữa mã hóa và xác thực , và tại sao bạn có thể muốn mã hóa được xác thực hơn là chỉ mã hóa . Để thực hiện mã hóa đã xác thực, bạn muốn Mã hóa rồi MAC. Thứ tự mã hóa và xác thực là rất quan trọng! Một trong những câu trả lời hiện có cho câu hỏi này đã mắc lỗi này; cũng như nhiều thư viện mật mã được viết bằng PHP. Bạn nên tránh triển khai mật mã của riêng mình và thay vào đó hãy sử dụng thư viện an toàn được viết bởi các chuyên gia mật mã.
Sử dụng libsodium nếu bạn có quyền truy cập PECL (hoặc
sodium_compat nếu bạn muốn libsodium mà không có PECL); nếu không thì ... Cả hai thư viện được liên kết ở trên giúp bạn dễ dàng triển khai mã hóa đã xác thực vào thư viện của riêng mình. Nếu bạn vẫn muốn viết và triển khai thư viện mật mã của riêng mình, chống lại sự khôn ngoan thông thường của mọi chuyên gia mật mã trên Internet, đây là các bước bạn sẽ phải thực hiện. Mã hóa:
Giải mã:
Cân nhắc thiết kế khác:
Ngay cả khi bạn làm theo lời khuyên được đưa ra ở đây, rất nhiều điều có thể xảy ra với tiền mã hóa. Luôn có chuyên gia mật mã xem xét việc triển khai của bạn. Nếu bạn không đủ may mắn để làm bạn với một sinh viên mật mã tại trường đại học địa phương của bạn, bạn luôn có thể thử diễn đàn Cryptography Stack Exchange để được tư vấn. Nếu bạn cần một phân tích chuyên nghiệp về việc triển khai của mình, bạn luôn có thể thuê một nhóm tư vấn bảo mật có uy tín để xem xét mã mật mã PHP của bạn (tiết lộ: công ty của tôi). Quan trọng: Khi nào không sử dụng mã hóaKhông mã hóa mật khẩu . Thay vào đó,bạn muốn băm chúng bằng cách sử dụng một trong các thuật toán băm mật khẩu sau:
Không bao giờ sử dụng hàm băm có mục đích chung (MD5, SHA256) để lưu trữ mật khẩu. Không mã hóa Tham số URL . Đó là công cụ sai cho công việc. Ví dụ về mã hóa chuỗi PHP với LibsodiumNếu bạn đang sử dụng PHP <7.2 hoặc không cài đặt libsodium, bạn có thể sử dụng sodium_compat để đạt được kết quả tương tự (mặc dù chậm hơn).
Sau đó, để kiểm tra nó ra:
Halite - Libsodium được tạo ra dễ dàng hơnMột trong những dự án mà tôi đang thực hiện là một thư viện mã hóa có tên là Halite , nhằm mục đích làm cho libsodium trở nên dễ dàng và trực quan hơn.
Tất cả các mật mã cơ bản được xử lý bởi libsodium. Ví dụ với mã hóa defuse / php
Lưu ý : Quản lý khóa mã hóaNếu bạn muốn sử dụng "mật khẩu", hãy dừng lại ngay bây giờ. Bạn cần một khóa mã hóa 128 bit ngẫu nhiên, không phải một mật khẩu dễ nhớ của con người. Bạn có thể lưu trữ một khóa mã hóa để sử dụng lâu dài như sau:
Và, theo yêu cầu, bạn có thể truy xuất nó như sau:
Tôi mạnh mẽ khuyên bạn nên chỉ lưu trữ một chìa khóa được tạo ra một cách ngẫu nhiên để sử dụng lâu dài thay vì bất kỳ loại mật khẩu là chìa khóa (hoặc để lấy được chìa khóa). Nếu bạn đang sử dụng thư viện của Defuse:
"Nhưng tôi thực sự muốn sử dụng mật khẩu."Đó là một ý tưởng tồi, nhưng không sao, đây là cách thực hiện điều đó một cách an toàn. Đầu tiên, tạo một khóa ngẫu nhiên và lưu trữ nó trong một hằng số.
Lưu ý rằng bạn đang làm thêm công việc và chỉ có thể sử dụng hằng số này làm chìa khóa và giúp bản thân đỡ đau lòng hơn! Sau đó, sử dụng PBKDF2 (giống như vậy) để lấy khóa mã hóa phù hợp từ mật khẩu của bạn thay vì mã hóa trực tiếp bằng mật khẩu của bạn.
Đừng chỉ sử dụng mật khẩu 16 ký tự. Khóa mã hóa của bạn sẽ bị hỏng một cách hài hước. 445 hữu ích 5 bình luận chia sẻ |