婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > asp.net 生成隨機密碼的具體代碼

asp.net 生成隨機密碼的具體代碼

熱門標簽:辦理400電話證件 寧波自動外呼系統代理 手機地圖標注如何刪除 外呼系統費用一年 怎么給超市做地圖標注入駐店 巫師3為什么地圖標注的財寶沒有 外呼系統代理品牌 十堰正規電銷機器人系統 世紀佳緣地圖標注怎么去掉
復制代碼 代碼如下:

public static class RandomPassword
   {
       // Define default min and max password lengths.
       private static int DEFAULT_MIN_PASSWORD_LENGTH = 8;
       private static int DEFAULT_MAX_PASSWORD_LENGTH = 10;

       // Define supported password characters divided into groups.
       private static string PASSWORD_CHARS_LCASE = "abcdefgijkmnopqrstwxyz";
       private static string PASSWORD_CHARS_UCASE = "ABCDEFGHJKLMNPQRSTWXYZ";
       private static string PASSWORD_CHARS_NUMERIC = "23456789";
       private static string PASSWORD_CHARS_SPECIAL = "*$-+?_=!%{}/";

       /// summary>
       /// Generates a random password.
       /// /summary>
       /// returns>
       /// Randomly generated password.
       /// /returns>
       /// remarks>
       /// The length of the generated password will be determined at
       /// random. It will be no shorter than the minimum default and
       /// no longer than maximum default.
       /// /remarks>
       public static string Generate()
       {
           return Generate(DEFAULT_MIN_PASSWORD_LENGTH,
                           DEFAULT_MAX_PASSWORD_LENGTH);
       }

       /// summary>
       /// Generates a random password of the exact length.
       /// /summary>
       /// param name="length">
       /// Exact password length.
       /// /param>
       /// returns>
       /// Randomly generated password.
       /// /returns>
       public static string Generate(int length)
       {
           return Generate(length, length);
       }

       /// summary>
       /// Generates a random password.
       /// /summary>
       /// param name="minLength">
       /// Minimum password length.
       /// /param>
       /// param name="maxLength">
       /// Maximum password length.
       /// /param>
       /// returns>
       /// Randomly generated password.
       /// /returns>
       /// remarks>
       /// The length of the generated password will be determined at
       /// random and it will fall with the range determined by the
       /// function parameters.
       /// /remarks>
       public static string Generate(int minLength,
                                     int maxLength)
       {
           // Make sure that input parameters are valid.
           if (minLength = 0 || maxLength = 0 || minLength > maxLength)
               return null;

           // Create a local array containing supported password characters
           // grouped by types. You can remove character groups from this
           // array, but doing so will weaken the password strength.
           char[][] charGroups = new char[][]
       {
           PASSWORD_CHARS_LCASE.ToCharArray(),
           PASSWORD_CHARS_UCASE.ToCharArray(),
           PASSWORD_CHARS_NUMERIC.ToCharArray(),
           PASSWORD_CHARS_SPECIAL.ToCharArray()
       };

           // Use this array to track the number of unused characters in each
           // character group.
           int[] charsLeftInGroup = new int[charGroups.Length];

           // Initially, all characters in each group are not used.
           for (int i = 0; i charsLeftInGroup.Length; i++)
               charsLeftInGroup[i] = charGroups[i].Length;

           // Use this array to track (iterate through) unused character groups.
           int[] leftGroupsOrder = new int[charGroups.Length];

           // Initially, all character groups are not used.
           for (int i = 0; i leftGroupsOrder.Length; i++)
               leftGroupsOrder[i] = i;

           // Because we cannot use the default randomizer, which is based on the
           // current time (it will produce the same "random" number within a
           // second), we will use a random number generator to seed the
           // randomizer.

           // Use a 4-byte array to fill it with random bytes and convert it then
           // to an integer value.
           byte[] randomBytes = new byte[4];

           // Generate 4 random bytes.
           RNGCryptoServiceProvider rng = new RNGCryptoServiceProvider();
           rng.GetBytes(randomBytes);

           // Convert 4 bytes into a 32-bit integer value.
           int seed = (randomBytes[0] 0x7f) 24 |
                       randomBytes[1] 16 |
                       randomBytes[2] 8 |
                       randomBytes[3];

           Random random = new Random(seed);
           char[] password = null;

           // Allocate appropriate memory for the password.
           if (minLength maxLength)
               password = new char[random.Next(minLength, maxLength + 1)];
           else
               password = new char[minLength];

           // Index of the next character to be added to password.
           int nextCharIdx;

           // Index of the next character group to be processed.
           int nextGroupIdx;

           // Index which will be used to track not processed character groups.
           int nextLeftGroupsOrderIdx;

           // Index of the last non-processed character in a group.
           int lastCharIdx;

           // Index of the last non-processed group.
           int lastLeftGroupsOrderIdx = leftGroupsOrder.Length - 1;

           // Generate password characters one at a time.
           for (int i = 0; i password.Length; i++)
           {
               // If only one character group remained unprocessed, process it;
               // otherwise, pick a random character group from the unprocessed
               // group list. To allow a special character to appear in the
               // first position, increment the second parameter of the Next
               // function call by one, i.e. lastLeftGroupsOrderIdx + 1.
               if (lastLeftGroupsOrderIdx == 0)
                   nextLeftGroupsOrderIdx = 0;
               else
                   nextLeftGroupsOrderIdx = random.Next(0,
                                                        lastLeftGroupsOrderIdx);

               // Get the actual index of the character group, from which we will
               // pick the next character.
               nextGroupIdx = leftGroupsOrder[nextLeftGroupsOrderIdx];

               // Get the index of the last unprocessed characters in this group.
               lastCharIdx = charsLeftInGroup[nextGroupIdx] - 1;

               // If only one unprocessed character is left, pick it; otherwise,
               // get a random character from the unused character list.
               if (lastCharIdx == 0)
                   nextCharIdx = 0;
               else
                   nextCharIdx = random.Next(0, lastCharIdx + 1);

               // Add this character to the password.
               password[i] = charGroups[nextGroupIdx][nextCharIdx];

               // If we processed the last character in this group, start over.
               if (lastCharIdx == 0)
                   charsLeftInGroup[nextGroupIdx] =
                                             charGroups[nextGroupIdx].Length;
               // There are more unprocessed characters left.
               else
               {
                   // Swap processed character with the last unprocessed character
                   // so that we don't pick it until we process all characters in
                   // this group.
                   if (lastCharIdx != nextCharIdx)
                   {
                       char temp = charGroups[nextGroupIdx][lastCharIdx];
                       charGroups[nextGroupIdx][lastCharIdx] =
                                   charGroups[nextGroupIdx][nextCharIdx];
                       charGroups[nextGroupIdx][nextCharIdx] = temp;
                   }
                   // Decrement the number of unprocessed characters in
                   // this group.
                   charsLeftInGroup[nextGroupIdx]--;
               }

               // If we processed the last group, start all over.
               if (lastLeftGroupsOrderIdx == 0)
                   lastLeftGroupsOrderIdx = leftGroupsOrder.Length - 1;
               // There are more unprocessed groups left.
               else
               {
                   // Swap processed group with the last unprocessed group
                   // so that we don't pick it until we process all groups.
                   if (lastLeftGroupsOrderIdx != nextLeftGroupsOrderIdx)
                   {
                       int temp = leftGroupsOrder[lastLeftGroupsOrderIdx];
                       leftGroupsOrder[lastLeftGroupsOrderIdx] =
                                   leftGroupsOrder[nextLeftGroupsOrderIdx];
                       leftGroupsOrder[nextLeftGroupsOrderIdx] = temp;
                   }
                   // Decrement the number of unprocessed groups.
                   lastLeftGroupsOrderIdx--;
               }
           }

           // Convert password characters into a string and return the result.
           return new string(password);
       }
   }
您可能感興趣的文章:
  • ASP.NET MVC5網站開發之添加\刪除\重置密碼\修改密碼\列表瀏覽管理員篇2(六)
  • ASP.NET MVC5網站開發用戶修改資料和密碼(六)
  • asp.net利用cookie保存用戶密碼實現自動登錄的方法
  • ASP.NET 回發密碼框清空問題處理方法
  • 解讀ASP.NET密碼強度驗證代碼實例分享
  • asp.net中使用cookie與md5加密實現記住密碼功能的實現代碼
  • 淺析ASP.NET生成隨機密碼函數
  • asp.net membership 密碼重設
  • ASP.net中md5加密碼的方法
  • ASP.NET jQuery 實例13 原創jQuery文本框字符限制插件-TextArea Counter
  • ASp.net 文本框(TextBox)計算,判斷輸入的是否是數字
  • ASP.NET文本框密碼賦默認值的方法

標簽:平涼 牡丹江 山西 通遼 景德鎮 嘉興 泰州 天門

巨人網絡通訊聲明:本文標題《asp.net 生成隨機密碼的具體代碼》,本文關鍵詞  asp.net,生成,隨機,密碼,的,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《asp.net 生成隨機密碼的具體代碼》相關的同類信息!
  • 本頁收集關于asp.net 生成隨機密碼的具體代碼的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 平遥县| 奉新县| 绩溪县| 山阴县| 仙游县| 正安县| 临汾市| 安岳县| 库车县| 汾阳市| 黎平县| 浠水县| 朝阳市| 会东县| 蒲城县| 蓝田县| 龙里县| 临夏市| 云龙县| 黎川县| 泾源县| 徐水县| 霍山县| 都昌县| 胶州市| 巴南区| 黎平县| 溆浦县| 定安县| 新平| 若羌县| 礼泉县| 台前县| 陆丰市| 莱州市| 玉田县| 安平县| 昔阳县| 修文县| 桐城市| 隆安县|