Hướng dẫn random permutation generator python - python trình tạo hoán vị ngẫu nhiên
Xem bây giờ hướng dẫn này có một khóa học video liên quan được tạo bởi nhóm Python thực sự. Xem cùng với hướng dẫn bằng văn bản để hiểu sâu hơn về sự hiểu biết của bạn: Tạo dữ liệu ngẫu nhiên trong Python This tutorial has a related video course created by the Real Python team. Watch it together with the written tutorial to deepen your understanding: Generating Random Data in Python This tutorial has a related video course created by the Real Python team. Watch it together with the written tutorial to deepen your understanding: Generating Random Data in Python Show
Nội dung chính ShowShow
Làm thế nào ngẫu nhiên là ngẫu nhiên? Đây là một câu hỏi kỳ lạ để hỏi, nhưng nó là một trong những tầm quan trọng tối quan trọng trong trường hợp có liên quan đến bảo mật thông tin. Bất cứ khi nào bạn tạo ra dữ liệu, chuỗi hoặc số ngẫu nhiên trong Python, thì một ý tưởng tốt là có ít nhất một ý tưởng sơ bộ về cách tạo dữ liệu đó. Tại đây, bạn sẽ bao gồm một số ít các tùy chọn khác nhau để tạo dữ liệu ngẫu nhiên trong Python, và sau đó xây dựng để so sánh từng loại về mức độ bảo mật, tính linh hoạt, mục đích và tốc độ của nó. Tôi hứa rằng hướng dẫn này sẽ không phải là một bài học về toán học hay mật mã, mà tôi sẽ được trang bị tốt để giảng bài ngay từ đầu. Bạn sẽ nhận được nhiều môn toán như cần thiết, và không còn nữa. Làm thế nào ngẫu nhiên là ngẫu nhiên?Những gì là bảo mật về mặt mật mã học là gì?pseudorandom: generated with a pseudorandom number generator (PRNG), which is essentially any algorithm for generating seemingly random but still reproducible data. Những gì bạn sẽ bao gồm ở đây Prngs trong Python PRNG, thường được thực hiện với phần mềm thay vì phần cứng, hoạt động hơi khác nhau. Ở đây, một mô tả ngắn gọn:
Bạn có thể đã được nói với những người đọc các tài liệu! ở một điểm nào đó. Vâng, những người đó không sai. Ở đây, một đoạn trích đặc biệt đáng chú ý từ tài liệu mô -đun 2 mà bạn không muốn bỏ lỡ:
Bạn có thể đã nhìn thấy 3, 4, hoặc tương tự, trong Python. Cuộc gọi chức năng này đang gieo hạt trình tạo số ngẫu nhiên cơ bản được sử dụng bởi mô -đun Python từ 2. Đó là những gì thực hiện các cuộc gọi tiếp theo để tạo ra các số ngẫu nhiên xác định: Đầu vào A luôn tạo ra đầu ra B. Phước lành này cũng có thể là một lời nguyền nếu nó được sử dụng một cách độc hại.Có lẽ các thuật ngữ ngẫu nhiên của người Hồi giáo và người xác định có vẻ như chúng không thể tồn tại bên cạnh nhau. Để làm cho điều đó rõ ràng hơn, ở đây, một phiên bản cực kỳ được cắt giảm của 6 mà lặp đi lặp lại một số ngẫu nhiên của người Hồi giáo bằng cách sử dụng 7. 8 ban đầu được định nghĩa là giá trị hạt giống và sau đó biến thành một chuỗi số xác định dựa trên hạt giống đó:
Don Tiết lấy ví dụ này theo nghĩa đen, vì nó có nghĩa là chủ yếu để minh họa cho khái niệm này. Nếu bạn sử dụng giá trị hạt giống 1234, chuỗi các cuộc gọi tiếp theo đến 6 phải luôn giống hệt nhau:>>>
Bạn sẽ thấy một minh họa nghiêm túc hơn về điều này trong thời gian ngắn. Những gì là bảo mật về mặt mật mã học là gì?Nếu bạn đã có đủ với các từ viết tắt của RNG RNG, hãy để Lừa ném thêm một bản vào hỗn hợp: CSPRNG hoặc PRNG an toàn bằng mã hóa. CSPRNGS phù hợp để tạo dữ liệu nhạy cảm như mật khẩu, trình xác thực và mã thông báo. Đưa ra một chuỗi ngẫu nhiên, thực tế không có cách nào để joe độc hại để xác định chuỗi nào đến trước hoặc sau chuỗi đó theo một chuỗi các chuỗi ngẫu nhiên. Một thuật ngữ khác mà bạn có thể thấy là entropy. Tóm lại, điều này đề cập đến số lượng ngẫu nhiên được giới thiệu hoặc mong muốn. Ví dụ: một mô -đun Python mà bạn sẽ bao gồm ở đây xác định 00, số byte để trả về theo mặc định. Các nhà phát triển cho rằng đây là những người đủ điều kiện là một lượng lớn tiếng ồn.entropy. In a nutshell, this refers to the amount of randomness introduced or desired. For example, one Python module that you’ll cover here defines 00, the number of bytes to return by default. The developers deem this to be “enough” bytes to be a sufficient amount of noise.entropy. In a nutshell, this refers to the amount of randomness introduced or desired. For example, one Python module that you’ll cover here defines 00, the number of bytes to return by default. The developers deem this to be “enough” bytes to be a sufficient amount of noise.Một điểm quan trọng về CSPRNGS là chúng vẫn còn giả. Chúng được thiết kế theo một cách nào đó có tính quyết định nội bộ, nhưng chúng thêm một số biến khác hoặc có một số tài sản làm cho chúng đủ ngẫu nhiên để cấm hỗ trợ vào bất kỳ chức năng nào thực thi chủ nghĩa quyết định. Những gì bạn sẽ bao gồm ở đâyTrong các thuật ngữ thực tế, điều này có nghĩa là bạn nên sử dụng các PRNG đơn giản để mô hình hóa, mô phỏng và mô hình hóa thống kê có thể tái tạo dữ liệu ngẫu nhiên. Họ cũng nhanh hơn đáng kể so với CSPRNG, như bạn sẽ thấy sau này. Sử dụng CSPRNG cho các ứng dụng bảo mật và mật mã trong đó độ nhạy dữ liệu là bắt buộc. Ngoài việc mở rộng các trường hợp sử dụng ở trên, trong hướng dẫn này, bạn sẽ đi sâu vào các công cụ Python để sử dụng cả PRNG và CSPRNGS:
Bạn có thể chạm vào tất cả những điều trên và kết thúc với một so sánh cấp cao. Prngs trong PythonMô -đun >>> random.seed(444) >>> random.random() 0.3088946587429545 >>> random.random() 0.01323751590501987 >>> random.seed(444) # Re-seed >>> random.random() 0.3088946587429545 >>> random.random() 0.01323751590501987 2Có lẽ công cụ được biết đến rộng rãi nhất để tạo dữ liệu ngẫu nhiên trong Python là mô -đun ____32 của nó, sử dụng thuật toán PRNG của Mersenne Twister làm trình tạo lõi của nó. Trước đó, bạn đã chạm vào một thời gian ngắn trên 08, và bây giờ là thời điểm tốt để xem nó hoạt động như thế nào. Đầu tiên, hãy để xây dựng một số dữ liệu ngẫu nhiên mà không cần gieo hạt. Hàm 09 trả về một chiếc phao ngẫu nhiên trong khoảng [0,0, 1.0). Kết quả sẽ luôn luôn nhỏ hơn điểm cuối bên phải (1.0). Điều này còn được gọi là phạm vi bán mở:>>> 9Nếu bạn tự chạy mã này, tôi sẽ đặt cược tiết kiệm cuộc sống của mình rằng các số được trả lại trên máy của bạn sẽ khác. Mặc định khi bạn don hạt giống máy phát điện là sử dụng thời gian hệ thống hiện tại của bạn hoặc nguồn ngẫu nhiên của bạn từ hệ điều hành của bạn nếu có sẵn. Với 08, bạn có thể tạo ra kết quả có thể tái tạo và chuỗi cuộc gọi sau 08 sẽ tạo ra cùng một dấu vết dữ liệu:>>>
Nếu bạn tự chạy mã này, tôi sẽ đặt cược tiết kiệm cuộc sống của mình rằng các số được trả lại trên máy của bạn sẽ khác. Mặc định khi bạn don hạt giống máy phát điện là sử dụng thời gian hệ thống hiện tại của bạn hoặc nguồn ngẫu nhiên của bạn từ hệ điều hành của bạn nếu có sẵn. Với 08, bạn có thể tạo ra kết quả có thể tái tạo và chuỗi cuộc gọi sau 08 sẽ tạo ra cùng một dấu vết dữ liệu:>>> 0Nếu bạn tự chạy mã này, tôi sẽ đặt cược tiết kiệm cuộc sống của mình rằng các số được trả lại trên máy của bạn sẽ khác. Mặc định khi bạn don hạt giống máy phát điện là sử dụng thời gian hệ thống hiện tại của bạn hoặc nguồn ngẫu nhiên của bạn từ hệ điều hành của bạn nếu có sẵn. >>> 6Nếu bạn tự chạy mã này, tôi sẽ đặt cược tiết kiệm cuộc sống của mình rằng các số được trả lại trên máy của bạn sẽ khác. Mặc định khi bạn don hạt giống máy phát điện là sử dụng thời gian hệ thống hiện tại của bạn hoặc nguồn ngẫu nhiên của bạn từ hệ điều hành của bạn nếu có sẵn. >>> 7Nếu bạn tự chạy mã này, tôi sẽ đặt cược tiết kiệm cuộc sống của mình rằng các số được trả lại trên máy của bạn sẽ khác. Mặc định khi bạn don hạt giống máy phát điện là sử dụng thời gian hệ thống hiện tại của bạn hoặc nguồn ngẫu nhiên của bạn từ hệ điều hành của bạn nếu có sẵn. 8Với 08, bạn có thể tạo ra kết quả có thể tái tạo và chuỗi cuộc gọi sau 08 sẽ tạo ra cùng một dấu vết dữ liệu:>>> 1Nếu bạn tự chạy mã này, tôi sẽ đặt cược tiết kiệm cuộc sống của mình rằng các số được trả lại trên máy của bạn sẽ khác. Mặc định khi bạn don hạt giống máy phát điện là sử dụng thời gian hệ thống hiện tại của bạn hoặc nguồn ngẫu nhiên của bạn từ hệ điều hành của bạn nếu có sẵn. >>> 2Nếu bạn tự chạy mã này, tôi sẽ đặt cược tiết kiệm cuộc sống của mình rằng các số được trả lại trên máy của bạn sẽ khác. Mặc định khi bạn don hạt giống máy phát điện là sử dụng thời gian hệ thống hiện tại của bạn hoặc nguồn ngẫu nhiên của bạn từ hệ điều hành của bạn nếu có sẵn. Với 08, bạn có thể tạo ra kết quả có thể tái tạo và chuỗi cuộc gọi sau 08 sẽ tạo ra cùng một dấu vết dữ liệu:Lưu ý sự lặp lại của các số ngẫu nhiên của người Viking. Trình tự các số ngẫu nhiên trở thành xác định hoặc được xác định hoàn toàn bởi giá trị hạt giống, 444. 0Hãy cùng xem một số chức năng cơ bản hơn của 2. Ở trên, bạn tạo ra một chiếc phao ngẫu nhiên. Bạn có thể tạo một số nguyên ngẫu nhiên giữa hai điểm cuối trong Python với hàm 63. Điều này kéo dài khoảng [x, y] đầy đủ và có thể bao gồm cả hai điểm cuối:Với 08, bạn có thể tạo ra kết quả có thể tái tạo và chuỗi cuộc gọi sau 08 sẽ tạo ra cùng một dấu vết dữ liệu:>>> 1Nếu bạn tự chạy mã này, tôi sẽ đặt cược tiết kiệm cuộc sống của mình rằng các số được trả lại trên máy của bạn sẽ khác. Mặc định khi bạn don hạt giống máy phát điện là sử dụng thời gian hệ thống hiện tại của bạn hoặc nguồn ngẫu nhiên của bạn từ hệ điều hành của bạn nếu có sẵn. VớiLưu ý sự lặp lại của các số ngẫu nhiên của người Viking. Trình tự các số ngẫu nhiên trở thành xác định hoặc được xác định hoàn toàn bởi giá trị hạt giống, 444. >>> 2Nếu bạn tự chạy mã này, tôi sẽ đặt cược tiết kiệm cuộc sống của mình rằng các số được trả lại trên máy của bạn sẽ khác. Mặc định khi bạn don hạt giống máy phát điện là sử dụng thời gian hệ thống hiện tại của bạn hoặc nguồn ngẫu nhiên của bạn từ hệ điều hành của bạn nếu có sẵn. Với 08, bạn có thể tạo ra kết quả có thể tái tạo và chuỗi cuộc gọi sau 08 sẽ tạo ra cùng một dấu vết dữ liệu:>>> 3Lưu ý sự lặp lại của các số ngẫu nhiên của người Viking. Trình tự các số ngẫu nhiên trở thành xác định hoặc được xác định hoàn toàn bởi giá trị hạt giống, 444. >>> Hãy cùng xem một số chức năng cơ bản hơn của 2. Ở trên, bạn tạo ra một chiếc phao ngẫu nhiên. Bạn có thể tạo một số nguyên ngẫu nhiên giữa hai điểm cuối trong Python với hàm 63. Điều này kéo dài khoảng [x, y] đầy đủ và có thể bao gồm cả hai điểm cuối: 64, bạn có thể loại trừ phía bên phải của khoảng thời gian, có nghĩa là số được tạo luôn nằm trong [x, y) và sẽ luôn nhỏ hơn điểm cuối bên phải:Một hoạt động phổ biến khác là tạo ra một chuỗi các giá trị boolean ngẫu nhiên, 13 hoặc 14. Một cách để làm điều này sẽ là với 15. Tuy nhiên, nó thực sự nhanh hơn khoảng 4 lần để chọn từ 16 và sau đó xem các số nguyên này đến các giá trị boolean tương ứng của chúng:>>> 5Điều gì về việc tạo dữ liệu tương quan? Hãy nói rằng bạn muốn mô phỏng hai chuỗi thời gian tương quan. Một cách để đi về điều này là với chức năng Numpy từ ____87, có tính đến một ma trận hiệp phương sai. Nói cách khác, để rút ra từ một biến ngẫu nhiên được phân phối thông thường, bạn cần chỉ định giá trị trung bình và phương sai của nó (hoặc độ lệch chuẩn). Để lấy mẫu từ phân phối bình thường đa biến, bạn chỉ định ma trận phương pháp và hiệp phương sai, và bạn kết thúc với nhiều chuỗi dữ liệu tương quan, mỗi chuỗi được phân phối gần như bình thường. Tuy nhiên, thay vì hiệp phương sai, mối tương quan là một biện pháp quen thuộc và trực quan hơn với hầu hết. Nó có sự hiệp phương sai được chuẩn hóa bởi sản phẩm của độ lệch chuẩn, và do đó bạn cũng có thể xác định hiệp phương sai về mặt tương quan và độ lệch chuẩn: Vì vậy, bạn có thể vẽ các mẫu ngẫu nhiên từ phân phối bình thường đa biến bằng cách chỉ định một ma trận tương quan và độ lệch chuẩn? Có, nhưng bạn sẽ cần phải đưa các mẫu trên vào mẫu ma trận trước tiên. Ở đây, S là một vectơ của độ lệch chuẩn, p là ma trận tương quan của chúng và C là ma trận hiệp phương sai (vuông) kết quả (vuông):S is a vector of the standard deviations, P is their correlation matrix, and C is the resulting (square) covariance matrix:S is a vector of the standard deviations, P is their correlation matrix, and C is the resulting (square) covariance matrix: Điều này có thể được thể hiện trong Numpy như sau: 6Bây giờ, bạn có thể tạo hai chuỗi thời gian tương quan nhưng vẫn ngẫu nhiên: >>> 7Điều gì về việc tạo dữ liệu tương quan? Hãy nói rằng bạn muốn mô phỏng hai chuỗi thời gian tương quan. Một cách để đi về điều này là với chức năng Numpy từ ____87, có tính đến một ma trận hiệp phương sai. Nói cách khác, để rút ra từ một biến ngẫu nhiên được phân phối thông thường, bạn cần chỉ định giá trị trung bình và phương sai của nó (hoặc độ lệch chuẩn). Để lấy mẫu từ phân phối bình thường đa biến, bạn chỉ định ma trận phương pháp và hiệp phương sai, và bạn kết thúc với nhiều chuỗi dữ liệu tương quan, mỗi chuỗi được phân phối gần như bình thường.>>> 8Điều gì về việc tạo dữ liệu tương quan? Hãy nói rằng bạn muốn mô phỏng hai chuỗi thời gian tương quan. Một cách để đi về điều này là với chức năng Numpy từ ____87, có tính đến một ma trận hiệp phương sai. Nói cách khác, để rút ra từ một biến ngẫu nhiên được phân phối thông thường, bạn cần chỉ định giá trị trung bình và phương sai của nó (hoặc độ lệch chuẩn). Để lấy mẫu từ phân phối bình thường đa biến, bạn chỉ định ma trận phương pháp và hiệp phương sai, và bạn kết thúc với nhiều chuỗi dữ liệu tương quan, mỗi chuỗi được phân phối gần như bình thường.
20Các yếu tố ngẫu nhiên >>> random.seed(444) >>> random.random() 0.3088946587429545 >>> random.random() 0.01323751590501987 >>> random.seed(444) # Re-seed >>> random.random() 0.3088946587429545 >>> random.random() 0.01323751590501987 78 từ >>> seed(1234) >>> [random() for _ in range(10)] [16, 10, 11, 14, 4, 12, 17, 13, 1, 3] >>> seed(1234) >>> [random() for _ in range(10)] [16, 10, 11, 14, 4, 12, 17, 13, 1, 3] 05 với sự thay thế>>> seed(1234) >>> [random() for _ in range(10)] [16, 10, 11, 14, 4, 12, 17, 13, 1, 3] >>> seed(1234) >>> [random() for _ in range(10)] [16, 10, 11, 14, 4, 12, 17, 13, 1, 3] 10 04 với 12
Xáo trộn chuỗi 8 tại chỗ 18 hoặc 19 >>> 9Mẫu từ phân phối bình thường với trung bình >>> seed(1234) >>> [random() for _ in range(10)] [16, 10, 11, 14, 4, 12, 17, 13, 1, 3] >>> seed(1234) >>> [random() for _ in range(10)] [16, 10, 11, 14, 4, 12, 17, 13, 1, 3] 21 và độ lệch chuẩn >>> seed(1234) >>> [random() for _ in range(10)] [16, 10, 11, 14, 4, 12, 17, 13, 1, 3] >>> seed(1234) >>> [random() for _ in range(10)] [16, 10, 11, 14, 4, 12, 17, 13, 1, 3] 22 Bây giờ, bạn đã bao gồm hai tùy chọn cơ bản cho PRNG, hãy để Lôi chuyển sang một vài điều chỉnh an toàn hơn.>>> 90CSPRNGS trong Python 23: về ngẫu nhiên khi nó nhận đượcChức năng Python sườn ____ ____123 được sử dụng bởi cả 04 và 05 (cả hai bạn sẽ thấy ở đây trong một khoảnh khắc). Không đi sâu vào quá nhiều chi tiết, 23 tạo ra các byte ngẫu nhiên phụ thuộc hệ điều hành có thể được gọi một cách an toàn về mặt mật mã:>>> 91Nhưng làm thế nào điều này cuối cùng được biến thành một con trăn 77 hoặc chuỗi số?Đầu tiên, nhớ lại một trong những khái niệm cơ bản của điện toán, đó là một byte được tạo thành từ 8 bit. Bạn có thể nghĩ một chút như một chữ số duy nhất là 0 hoặc 1. Một byte chọn hiệu quả trong khoảng từ 0 đến 1 tám lần, do đó, cả 36 và 37 có thể đại diện cho byte. Hãy thử điều này, sử dụng các chuỗi Python F được giới thiệu trong Python 3.6, trong phiên dịch của bạn:Điều này tương đương với 38, với một số định dạng đặc biệt. 39 chuyển đổi một số nguyên thành biểu diễn nhị phân của nó dưới dạng chuỗi.Điều đó để chúng ta ở đâu? Sử dụng 40 ở trên không phải là một lựa chọn ngẫu nhiên. .>>> 92Nhưng làm thế nào điều này cuối cùng được biến thành một con trăn 77 hoặc chuỗi số?>>> 93Nhưng làm thế nào điều này cuối cùng được biến thành một con trăn 77 hoặc chuỗi số?Đầu tiên, nhớ lại một trong những khái niệm cơ bản của điện toán, đó là một byte được tạo thành từ 8 bit. Bạn có thể nghĩ một chút như một chữ số duy nhất là 0 hoặc 1. Một byte chọn hiệu quả trong khoảng từ 0 đến 1 tám lần, do đó, cả 36 và 37 có thể đại diện cho byte. Hãy thử điều này, sử dụng các chuỗi Python F được giới thiệu trong Python 3.6, trong phiên dịch của bạn:Điều này tương đương với 38, với một số định dạng đặc biệt. 39 chuyển đổi một số nguyên thành biểu diễn nhị phân của nó dưới dạng chuỗi.>>> 94Điều đó để chúng ta ở đâu? Sử dụng 40 ở trên không phải là một lựa chọn ngẫu nhiên. . 7 7 hoặc chuỗi số?Điều này có nghĩa là mỗi byte ánh xạ tới một số nguyên từ 0 đến 255. Nói cách khác, chúng ta sẽ cần hơn 8 bit để thể hiện số nguyên 256. Bạn có thể xác minh điều này bằng cách kiểm tra rằng 42 hiện là 9 chứ không phải 8.Được rồi, bây giờ hãy để Lừa quay lại kiểu dữ liệu >>> seed(1234) >>> [random() for _ in range(10)] [16, 10, 11, 14, 4, 12, 17, 13, 1, 3] >>> seed(1234) >>> [random() for _ in range(10)] [16, 10, 11, 14, 4, 12, 17, 13, 1, 3] 31 mà bạn đã thấy ở trên, bằng cách xây dựng chuỗi các byte tương ứng với các số nguyên từ 0 đến 255:Nếu bạn gọi >>> seed(1234) >>> [random() for _ in range(10)] [16, 10, 11, 14, 4, 12, 17, 13, 1, 3] >>> seed(1234) >>> [random() for _ in range(10)] [16, 10, 11, 14, 4, 12, 17, 13, 1, 3] 44, bạn sẽ quay lại danh sách Python chạy từ 0 đến 255. Nhưng nếu bạn chỉ in >>> seed(1234) >>> [random() for _ in range(10)] [16, 10, 11, 14, 4, 12, 17, 13, 1, 3] >>> seed(1234) >>> [random() for _ in range(10)] [16, 10, 11, 14, 4, 12, 17, 13, 1, 3] 45, bạn sẽ có một chuỗi trông xấu xí nằm rải rác với các dấu gạch chéo ngược: Những dấu gạch chéo ngược này là các chuỗi thoát và 46 đại diện cho ký tự có giá trị hex 47. Một số yếu tố của 45 được hiển thị theo nghĩa đen (các ký tự có thể in như chữ cái, số và dấu câu). Hầu hết được thể hiện với Escapes. 49 đại diện cho một bàn phím Bàn phím, trong khi 50 là một sự trở lại vận chuyển (một phần của dòng mới, trên Windows Systems).>>> 95Nếu bạn cần một sự bồi dưỡng trên thập lục phân, mã Charles Petzold,: Ngôn ngữ ẩn là một nơi tuyệt vời cho điều đó. Hex là một hệ thống đánh số cơ sở-16, thay vì sử dụng 0 đến 9, sử dụng 0 đến 9 và A đến F làm chữ số cơ bản của nó. Cuối cùng, hãy để Lừa quay trở lại nơi bạn bắt đầu, với chuỗi các byte ngẫu nhiên 8. Hy vọng điều này có ý nghĩa hơn một chút bây giờ. Gọi 52 trên đối tượng 31 cho 77 số thập lục phân, với mỗi số tương ứng với số thập phân từ 0 đến 255:Một câu hỏi cuối cùng: Làm thế nào short.ly. Here’s a function to get you started with your service: 96 55 12 ký tự ở trên, mặc dù 8 chỉ là 6 byte? Điều này là do hai chữ số thập lục phân tương ứng chính xác với một byte duy nhất. Phiên bản 77 của 31 sẽ luôn dài gấp đôi so với mắt chúng ta có liên quan.short.ly. Here’s a function to get you started with your service: 96Ngay cả khi byte (chẳng hạn như 59) không cần được biểu diễn 8 bit đầy đủ, 55 sẽ luôn sử dụng hai chữ số hex trên byte, do đó, số 1 sẽ được biểu diễn là 61 thay vì chỉ 62. Tuy nhiên, về mặt toán học, cả hai đều có cùng kích thước.Với điều đó dưới vành đai của bạn, hãy để cảm ứng trên một mô-đun được giới thiệu gần đây, >>> 97 04, giúp tạo ra các mã thông báo an toàn thân thiện với người dùng hơn nhiều. 04Python sườn tốt nhất giữMột ứng cử viên cuối cùng: >>> random.randint(0, 10) 7 >>> random.randint(500, 50000) 18601 5 Một tùy chọn cuối cùng để tạo mã thông báo ngẫu nhiên là hàm>>> 98Điều tuyệt vời là tất cả các chức năng của ____ 45 tạo ra một thể hiện của lớp 76, gói gọn ID và có các thuộc tính như 77, 78 và 79:>>> 99Điều tuyệt vời là tất cả các chức năng của ____ 45 tạo ra một thể hiện của lớp 76, gói gọn ID và có các thuộc tính như 77, 78 và 79:
81 và 82 đều lấy một định danh không gian tên và một tên. Cái trước sử dụng băm MD5 và cái sau sử dụng SHA-1. 70, ngược lại, hoàn toàn giả (hoặc ngẫu nhiên). Nó bao gồm nhận được 16 byte thông qua 23, chuyển đổi nó thành một số nguyên lớn và thực hiện một số hoạt động bitwise để tuân thủ đặc điểm kỹ thuật chính thức.Hy vọng rằng, bây giờ bạn có một ý tưởng tốt về sự khác biệt giữa các loại dữ liệu ngẫu nhiên khác nhau và cách tạo chúng. Tuy nhiên, một vấn đề khác có thể xuất hiện trong đầu là va chạm. Trong trường hợp này, một vụ va chạm chỉ đơn giản là đề cập đến việc tạo ra hai UUID phù hợp. Cơ hội của điều đó là gì? Chà, về mặt kỹ thuật không phải là bằng không, nhưng có lẽ nó đủ gần: có 89 hoặc 340 giá trị 90 có thể. Vì vậy, tôi sẽ để nó để bạn đánh giá xem điều này có đủ đảm bảo để ngủ ngon hay không.Một cách sử dụng phổ biến của >>> random.randint(0, 10) 7 >>> random.randint(500, 50000) 18601 5 là ở Django, có >>> seed(1234) >>> [random() for _ in range(10)] [16, 10, 11, 14, 4, 12, 17, 13, 1, 3] >>> seed(1234) >>> [random() for _ in range(10)] [16, 10, 11, 14, 4, 12, 17, 13, 1, 3] 92 thường được sử dụng làm khóa chính trong cơ sở dữ liệu quan hệ cơ bản của mô hình.Tại sao không chỉ là mặc định của người Viking 93?Ngoài các mô-đun an toàn được thảo luận ở đây như 04, mô-đun Python, ____32 thực sự có một lớp ít được sử dụng gọi là 93 sử dụng 23. .Tại thời điểm này, bạn có thể tự hỏi mình tại sao bạn sẽ chỉ mặc định vào phiên bản này? Tại sao không phải là người luôn luôn an toàn, thay vì mặc định các chức năng 2 xác định mà aren không an toàn về mặt mật mã?Tôi đã đề cập đến một lý do: Đôi khi bạn muốn dữ liệu của mình có thể xác định và có thể tái tạo cho những người khác theo dõi. 0Nhưng lý do thứ hai là CSPRNG, ít nhất là trong Python, có xu hướng chậm hơn có ý nghĩa so với PRNG. Hãy để thử nghiệm rằng với một tập lệnh, 902, so sánh các phiên bản PRNG và CSPRNG của 00 bằng cách sử dụng Python tựa 904: 1Bây giờ để thực hiện điều này từ shell: Sự khác biệt về thời gian 5X chắc chắn là một sự cân nhắc hợp lệ ngoài bảo mật mật mã khi chọn giữa hai.Tỷ lệ cược và kết thúc: băm Một khái niệm đã nhận được nhiều sự chú ý trong hướng dẫn này là của băm, có thể được thực hiện với mô -đun Python tựa 905. Một hàm băm được thiết kế là ánh xạ một chiều từ giá trị đầu vào sang chuỗi có kích thước cố định hầu như không thể đảo ngược kỹ sư. Do đó, trong khi kết quả của hàm băm có thể giống như dữ liệu ngẫu nhiên, nhưng nó không thực sự đủ điều kiện theo định nghĩa ở đây.Tóm tắt lại
04Được thiết kế để trở thành mô -đun thực tế Python sườn để tạo ra các số ngẫu nhiên, byte và chuỗi an toàn
Xem bây giờ hướng dẫn này có một khóa học video liên quan được tạo bởi nhóm Python thực sự. Xem cùng với hướng dẫn bằng văn bản để hiểu sâu hơn về sự hiểu biết của bạn: Tạo dữ liệu ngẫu nhiên trong Python This tutorial has a related video course created by the Real Python team. Watch it together with the written tutorial to deepen your understanding: Generating Random Data in Python This tutorial has a related video course created by the Real Python team. Watch it together with the written tutorial to deepen your understanding: Generating Random Data in Python |