PDA

View Full Version : سوال: ساختن رمز تصادفی



programer1389
پنج شنبه 11 شهریور 1389, 13:48 عصر
یک چیزی شبیه به این عکس میخواهم مثلا بهش بگی محدوده تا 6 کاراکتر و اون کل کاراکترهای این محدوده رو بسازه اگه نمونش تو سایت هست لطفا لینک بدین یا راهنمایی کنید تا خودم بنویسمش

sinashahab
پنج شنبه 11 شهریور 1389, 14:32 عصر
می تونی از کلاس Random استفاده کنی .

s.khoshfekran
پنج شنبه 11 شهریور 1389, 15:21 عصر
میتونی از کلاس Random استفاده کنی و اعدادی که بدست میاد رو به کاراکتر تبدیل کنی!!
http://www.c-sharpcorner.com/UploadFile/mahesh/RandomNumber11232005010428AM/RandomNumber.aspx

ricky22
پنج شنبه 11 شهریور 1389, 17:13 عصر
SAMPLE: Generates random password, which complies with the strong password
// rules and does not contain ambiguous characters.
//
// To run this sample, create a new Visual C# project using the Console
// Application template and replace the contents of the Class1.cs file with
// the code below.
//
// THIS CODE AND INFORMATION IS PROVIDED "AS IS" WITHOUT WARRANTY OF ANY KIND,
// EITHER EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE IMPLIED
// WARRANTIES OF MERCHANTABILITY AND/OR FITNESS FOR A PARTICULAR PURPOSE.
//
// Copyright (C) 2004 Obviex(TM) (http://www.obviex.com/Legal.aspx#Samples). All rights reserved.
//
using System;
using System.Security.Cryptography;

/// <summary>
/// This class can generate random passwords, which do not include ambiguous
/// characters, such as I, l, and 1. The generated password will be made of
/// 7-bit ASCII symbols. Every four characters will include one lower case
/// character, one upper case character, one number, and one special symbol
/// (such as '%') in a random order. The password will always start with an
/// alpha-numeric character; it will not start with a special symbol (we do
/// this because some back-end systems do not like certain special
/// characters in the first position).
/// </summary>
public 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.
// You can add (or remove) characters to (from) these 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];

// Now, this is real randomization.
Random random = new Random(seed);

// This array will hold password characters.
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);
}
}

/// <summary>
/// Illustrates the use of the RandomPassword class.
/// </summary>
public class RandomPasswordTest
{
/// <summary>
/// The main entry point for the application.
/// </summary>
[STAThread]
static void Main(string[] args)
{
// Print 100 randomly generated passwords (8-to-10 char long).
for (int i=0; i<100; i++)
Console.WriteLine(RandomPassword.Generate(8, 10));
}
}
//
// END OF FILE

http://www.obviex.com/Samples/Password.aspx


می تونی از کلاس Random استفاده کنی .
حداقل می گفتی کلاس random + کد اسکی که دوستمون بهتر متوجه بشه/

morteza271
پنج شنبه 11 شهریور 1389, 17:15 عصر
اینطوری هم میشه عمل کرد(البته تقریبا دوستان گفتن):چشمک:

1- اول تمام کارکترهایی که توی محدوده ی انتخاب شده هستند رو توی یه آرایه بریزی.
2 -سپس با استفاده از رندوم یه عدد انتخاب کنی و کاراکتر خونه ی آرایه(اندیسش همون عددی که انتخاب شد) رو به متغیرت اضافه کنی...
3- مرحله 2 رو به تعداد کاراکتر های رمزی که میخوای تکرار کن...

موفق باشی...

programer1389
شنبه 13 شهریور 1389, 10:39 صبح
ممنون از همه دوستان سوالی بود مجدد میپرسم

programer1389
یک شنبه 14 شهریور 1389, 11:11 صبح
یک سوال برام پیش اومد اون هم اینکه کلاس Random یک عدد تصادفی ایجاد میکنه حالا میخواهم بدونم اگه بخواهم رمز ها پشت سرهم ایجاد بشن چکار باید کرد یعنی شبیه به این
a
ab
abc
abcd
abcde
abcdef
a1
a1b
a1c
a1d
اینجوری میتون بفهمم که همه رشته های یک مجموعه مثلا 6 کاراکتری ساخته شدن یا نه و دوم میتونم اون رو ذخیره کنم تا در دفعات بعد مجبور نشم رشته رو از اول بسازم و ادامه کار رو دنبال میکنم
ممنون از همه دوستان که کمکم میکنن

programer1389
دوشنبه 15 شهریور 1389, 13:05 عصر
لطفا مدیران سایت جواب مار و هم بدین کارم گیره

hojjatshariffam
جمعه 10 دی 1389, 00:15 صبح
فکر کنم شما نیاز به همه کاراکتر های قابل تولید رو می خوای
اگه منظورت همینه که کار ساده ای یه ، باید از اولین کاراکت شروع کنی و یک یک کارکتر ها را یکی یکی عوض کنی و بعد نوبت کاراکتر بعدی می رسه و بعد دوباره از اول
در واقع باید همه زیر مجموعه های توانی یک مجموعه از کاراکتر را بدست بیاری که تعدادش برابر با 2 به توان N (تعداد کاراکتر مد نظر گرفته شده برای رمز تولیدی) می باشد ، البته بدون احتصاب تکراریا.
اگه منظورت این بود بیشتر و واضح تر توضیح بده تا بقیه هم بتونن صحیح تر و زودتر جوابتو بدن

hojjatshariffam
جمعه 10 دی 1389, 00:25 صبح
طبق الگوی زیر
aaaa
aaab
aaac
....
...
..
aaba
aabb
aabc
aabd
....
..
.
zzzz

اینا تمامی جمله های فقط چهار کارکتری قابل تولید از حروف a تا z بودند

quantomquery
جمعه 10 دی 1389, 11:32 صبح
ممنون از همه دوستان سوالی بود مجدد میپرسم

سلام

ولی بجای یه تاپیک واسه تشکر کردن
می تونستین از گزینه "تشکر کردن" استفاده کنین
ممنون دوست عزیز