Jednokratna lozinka (OTP) je lozinka koja vrijedi za samo jednu sesiju prijave ili transakciju na računalnom sustavu ili drugom digitalnom uređaju. Za više detalja Pogledajte ovaj . Algoritam Nasumično odaberite likove iz svih naših mogućnosti i generiraju niz željene duljine iz njega. OTP-ovi su uglavnom dugi 6-7 znakova, a slučajnost u 6-7 znakova gotovo jamči siguran način prijave.
OTP-ovi se široko koriste na web stranicama poput- Facebook Google WiFi- pristup željezničkim portalu za prijavu itd.
Kako se generira?
Pa, velika je mogućnost da koriste isti algoritam kao što se generira OTP. Ako je slučajno (vrlo rijedak) generirani jedinstveni niz već generirani i povezan je s drugim kodom, tada se koristi drugi slučajni niz. Prema sada, čini se da se samo šest znakova generira nasumično za jedinstvenu identifikaciju svih kodova. Doći će vrijeme kada se mogu iscrpiti sve moguće žice od šest znakova. Dakle, da, čak se i stvari povezane s web također u velikoj mjeri oslanjaju na slučajnost.
Vjerojatnost sudara od dva OTP -a
- Duljina OTP -a je 6, a postavljena veličina svih mogućih znakova u OTP -u je 62. godine. Dakle, ukupni broj mogućih skupova para OTP -a je 62 12 .
- Neki od njih su - [{aaaaaaaaaa} {aaaaaaaaaaaab} ..... {456789 456788} {456789 456789}]
- Ali mogući skupovi jednakog para OTP -a su: 62 6 . Neki od njih su - [{aaaaaaaaaa} {aaaaab aaaaaab} ..... {456788 456788} {456789 456789}]
- Otuda vjerojatnost sudara od dva OTP -a je: 62 6 / 62 12 = 1/62 6 = 1/56800235584 = 1.7605561 -11
Dakle vjerojatnost Od dva OTP -ova su sudaranje manje vjerojatna kao i postojanje vašeg života na Zemlji (omjer broja godina u kojem ćete živjeti u broju godina od početka svemira i svega što postoji). Dakle, Yesotps su puno sigurniji od statičkih lozinki! Provedba
CPP// A C/C++ Program to generate OTP (One Time Password) #include using namespace std; // A Function to generate a unique OTP everytime string generateOTP(int len) { // All possible characters of my OTP string str = 'abcdefghijklmnopqrstuvwxyzABCD' 'EFGHIJKLMNOPQRSTUVWXYZ0123456789'; int n = str.length(); // String to hold my OTP string OTP; for (int i=1; i<=len; i++) OTP.push_back(str[rand() % n]); return(OTP); } // Driver Program to test above functions int main() { // For different values each time we run the code srand(time(NULL)); // Declare the length of OTP int len = 6; printf('Your OTP is - %s' generateOTP(len).c_str()); return(0); }
Java // A Java Program to generate OTP (One Time Password) class GFG{ // A Function to generate a unique OTP everytime static String generateOTP(int len) { // All possible characters of my OTP String str = 'abcdefghijklmnopqrstuvwxyzABCD' +'EFGHIJKLMNOPQRSTUVWXYZ0123456789'; int n = str.length(); // String to hold my OTP String OTP=''; for (int i = 1; i <= len; i++) OTP += (str.charAt((int) ((Math.random()*10) % n))); return(OTP); } // Driver code public static void main(String[] args) { // Declare the length of OTP int len = 6; System.out.printf('Your OTP is - %s' generateOTP(len)); } } // This code is contributed by PrinciRaj1992
Python # A Python3 Program to generate OTP (One Time Password) import random # A Function to generate a unique OTP everytime def generateOTP(length): # All possible characters of my OTP str = 'abcdefghijklmnopqrstuvwxyzAB CDEFGHIJKLMNOPQRSTUVWXYZ0123456789'; n = len(str); # String to hold my OTP OTP = ''; for i in range(1length+1): OTP += str[int(random.random()*10) % n]; return (OTP); # Driver code if __name__ == '__main__': # Declare the length of OTP length = 6; print('Your OTP is - ' generateOTP(length)); # This code contributed by Rajput-Ji
C# // A C# Program to generate OTP (One Time Password) using System; class GFG { // A Function to generate a unique OTP everytime static string generateOTP(int len) { // All possible characters of my OTP string str = 'abcdefghijklmnopqrstuvwxyzABCD' + 'EFGHIJKLMNOPQRSTUVWXYZ0123456789'; int n = str.Length; // Creating a new Random object Random rand = new Random(); // String to hold my OTP string OTP = ''; for (int i = 1; i <= len; i++) OTP += (str[((int)((rand.Next() * 10) % n))]); return (OTP); } // Driver code public static void Main(string[] args) { // Declare the length of OTP int len = 6; Console.WriteLine('Your OTP is - ' + generateOTP(len)); } } // This code is contributed by phasing17
JavaScript // JavaScript Program to generate OTP (One Time Password) // A Function to generate a unique OTP everytime function generateOTP(length) { // All possible characters of my OTP let str = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789'; let n = str.length; // String to hold my OTP let OTP = ''; for (var i = 1; i <= length; i++) OTP += str[(Math.floor(Math.random() * 10) % n)]; return (OTP); } // Driver code // Declare the length of OTP let length = 6; console.log('Your OTP is - ' generateOTP(length)); // This code is contributed by phasing17
Izlaz (može biti različit za svaku vožnju):
Your OTP is - 8qOtzy
Vremenska složenost: O (n) gdje je n = broj znakova u našem OTP -u Pomoćni prostor: Osim niza koji imaju sve moguće znakove, potreban nam je (n) prostor da zadrži OTP gdje je n = broj znakova u našem OTP -u ako volite GeeksforGeeks i želite doprinijeti, možete i napisati članak koristeći koristeći članak koristeći i članak koristeći članak koristeći članak koristeći i članak koristeći članak koristeći i članak koristeći članak koristeći i članak koristeći i članak koristeći i članak write.geeksforgeeks.org Ili pošaljite svoj članak na [email protected]. Pogledajte svoj članak koji se pojavljuje na glavnoj stranici GeeksforGeeks i pomozite drugim štreberima. Napišite komentare ako pronađete nešto netočno ili želite podijeliti više informacija o gore opisanoj temi.