Microsoft & .NETVisual BasicGenerate Memorable Passwords, Automatically!

Generate Memorable Passwords, Automatically!

Generating automatic passwords for your users is a common programming scenario. However, due to the techniques typically employed, most autogenerated passwords end up looking like YPSWW9441—which, although highly secure, also end up completely unmemorable.

The following function generates a password using alternating friendly consonants and vowels, making for much more memorable passwords. Asking the function to generate a five-character password, for example, may result in BONES or LAMOT.

To use this function, call GeneratePassword, passing in the length of your desired password. The final password will be returned as a string:

Public Function GeneratePassword(ByVal Length As Integer) As String
   ' Creates a memorable password of the specified Length
   Dim blnOnVowel As Boolean
   Dim strTempLetter As String
   Dim strPassword As String
   Dim intCount As Integer
   For intCount = 1 To Length
      If blnOnVowel = False Then
         ' Choose a nice consonant - no C, X, Z, or Q
         strTempLetter = CType(Choose(CType(GetRandomNumber(1, _
                               17), _
                               Double), _
            "B", "D", "F", "G", "H", "J", "K", "L", "M", _
            "N", "P", "R", "S", "T", "V", "W", "Y"), String)
         ' Append it to the password string
         strPassword += strTempLetter
         ' Swich to vowel mode
         blnOnVowel = True
      Else
         ' Choose a vowel
         strTempLetter = CType(Choose(CType(GetRandomNumber(1, 5), _
                                      Double), _
           "A", "E", "I", "O", "U"), String)
         ' Append it to the password string
         strPassword += strTempLetter
         ' Switch back again, ready for next loop round
         blnOnVowel = False
      End If
   Next
   Return strPassword
End Function

Dim objRandom As New System.Random(CType((System.DateTime.Now. _
                                   Ticks _
   Mod System.Int32.MaxValue), Integer))
Public Function GetRandomNumber(Optional ByVal Low As Integer _
       = 1, _
   Optional ByVal High As Integer = 100) As Integer
   ' Returns a random number,
   ' between the optional Low and High parameters
   Return objRandom.Next(Low, High + 1)
End Function

You could use the GeneratePassword function as so:

Dim MyPassword As String
MyPassword = GeneratePassword(5)
MessageBox.Show(MyPassword)

About the Author

Karl Moore (MCSD, MVP) is an experience author living in Yorkshire, England. He is author of numerous technology books, including the new Ultimate VB .NET and ASP.NET Code Book (ISBN 1-59059-106-2, $49.99), plus regularly features at industry conferences and on BBC radio. Moore also runs his own creative consultancy, White Cliff Computing Ltd. Visit his official Web site at www.karlmoore.com.

Get the Free Newsletter!
Subscribe to Developer Insider for top news, trends & analysis
This email address is invalid.
Get the Free Newsletter!
Subscribe to Developer Insider for top news, trends & analysis
This email address is invalid.

Latest Posts

Related Stories