PHP 7 - CSPRNG
PHP 7 में, क्रॉस प्लेटफ़ॉर्म तरीके से क्रिप्टोग्राफ़िक रूप से सुरक्षित पूर्णांकों और तारों को उत्पन्न करने के लिए दो नए कार्यों का पालन किया जाता है।
random_bytes() - क्रिप्टोग्राफिक रूप से सुरक्षित छद्म यादृच्छिक बाइट्स उत्पन्न करता है।
random_int() - क्रिप्टोग्राफिक रूप से सुरक्षित छद्म यादृच्छिक पूर्णांक उत्पन्न करता है।
random_bytes ()
random_bytes () क्रिप्टोग्राफ़िक यादृच्छिक बाइट्स की एक मनमाना-लंबाई वाली स्ट्रिंग उत्पन्न करता है जो क्रिप्टोग्राफ़िक उपयोग के लिए उपयुक्त हैं, जैसे कि लवण, कुंजियाँ या आरंभीकरण वैक्टर उत्पन्न करना।
वाक्य - विन्यास
string random_bytes ( int $length )
मापदंडों
length - यादृच्छिक स्ट्रिंग की लंबाई जो बाइट्स में वापस आनी चाहिए।
वापसी मान
क्रिप्टोग्राफिक रूप से सुरक्षित यादृच्छिक बाइट्स की अनुरोधित संख्या युक्त स्ट्रिंग लौटाता है।
त्रुटियाँ / अपवाद
यदि यादृच्छिकता का एक उपयुक्त स्रोत नहीं मिल सकता है, तो एक अपवाद फेंक दिया जाएगा।
यदि अमान्य पैरामीटर दिए गए हैं, तो ए TypeError फेंक दिया जाएगा।
यदि बाइट की अमान्य लंबाई दी गई है, तो एक त्रुटि डाली जाएगी।
उदाहरण
<?php
$bytes = random_bytes(5);
print(bin2hex($bytes));
?>
यह निम्न ब्राउज़र आउटपुट का उत्पादन करता है -
54cc305593
random_int ()
random_int() क्रिप्टोग्राफ़िक यादृच्छिक पूर्णांक उत्पन्न करता है जो उपयोग के लिए उपयुक्त हैं जहां निष्पक्ष परिणाम महत्वपूर्ण हैं।
वाक्य - विन्यास
int random_int ( int $min , int $max )
मापदंडों
min - लौटाए जाने के लिए सबसे कम मूल्य, जो होना चाहिए PHP_INT_MIN या ऊँचा।
max - लौटाया जाने वाला उच्चतम मूल्य, जो उससे कम या उसके बराबर होना चाहिए PHP_INT_MAX।
वापसी मान
अधिकतम, समावेशी सीमा में क्रिप्टोग्राफिक रूप से सुरक्षित यादृच्छिक पूर्णांक देता है।
त्रुटियाँ / अपवाद
यदि यादृच्छिकता का उपयुक्त स्रोत नहीं पाया जा सकता है, तो Exception फेंक दिया जाएगा।
यदि अमान्य पैरामीटर दिए गए हैं, तो ए TypeError फेंक दिया जाएगा।
यदि अधिकतम न्यूनतम से कम है, तो ए Error फेंक दिया जाएगा।
उदाहरण
<?php
print(random_int(100, 999));
print("");
print(random_int(-1000, 0));
?>
यह निम्न ब्राउज़र आउटपुट का उत्पादन करता है -
614
-882