برای مشاهده مفیدترین ارسال در این موضوع اینجا کلیک کنید

نمایش نتایج: از شماره 1 تا 6 از مجموع 6
  1. #1
    Moderator
    تاریخ عضویت
    2012 November
    ارسال ها
    128
    تشکر
    28
    تشکر شده 173 بار در 77 پست


    2 امتياز مثبت از 2 راي
    آيا اين پست براي شما سودمند بود؟ بله | خیر

    رمز نگاری متقارن در دات نت به کمک c#

    ترم قبل در درس برنامه نویسی سیستم پروژه ای داشتم که مربوط به رمزنگاری فایل های PDF میشد ، تا قبل از این پروژه اطلاعات زیادی در مورد رمزنگاری نداشتم ، وقتی تو اینترنت جستجو کردم با فقدان اطلاعات و منابع فارسی در این زمینه مواجه شدم و مجبور شدم چندین مقاله ی انگلیسی که در سایت های مختلف در مورد رمزنگاری متقارن در دات نت منتشر شده بود را مطالعه کنم تا پروژه را انجام بدم ، بعد از این ماجرا تصمیم گرفتن مقاله ای مختصر به فارسی در مورد رمز نگاری متقارن و پیاده سازی آن در دات نت بنویسم که در تاپیکی با همین عنوان در سایت برنامه نویس گذاشتم ، حالا که این ترم زیاد در این مورد ازم سوال پرسیده شده کپی همان نوشتار را در این سایت هم میزارم تا بچه های دانشگاه ازش استفاده کنند...

    از اونجایی که منابع فارسی زیادی در مورد رمز نگاری متقارن در دات نت پیدا نکردم(دقیقا بر عکس انگلیسی که به وفور یافت میشد) و خودم با این موضوع سرو کار داشتم ، تصمیم گرفتم یک آموزش کوچیکی در این مورد در این تاپیک بزارم...
    سعی می کنیم از تعریف مفاهیم خیلی سریع عبور کنیم تا از خواندن این مطلب خسته نشید اما چند تا تعریف کوچک برای مقدمه فکر کنم بد نباشه :
    رمز نگاری چیست!؟
    رمزنگاری عبارت است از بهم ریختگی اطلاعات به طوری که برای کسی قابل فهم نباشد. فن آوری رمزنگاری امکان مشاهده، مطالعه و تفسیر پیام‌های ارسالی توسط افراد غیر مجاز را سلب می‌نماید. از رمزنگاری به منظور حفاظت داده‌ها در شبکه‌های عمومی نظیر اینترنت استفاده می‌گردد. در این رابطه از الگوریتم‌های پیشرفته ریاضی به منظور رمزنمودن پیام‌ها و ضمائم مربوطه، استفاده می‌شود.
    رمز نگاری متقارن(کلید خصوصی) چیست!؟
    منداولترین نوع رمزنگاری مبتنی بر کلید، رمزنگاری "کلید خصوصی" است. به این نوع رمزنگاری، متقارن، سنتی، رمز مشترک، کلید رمز نیز گفته می‌شود. در این نوع رمزنگاری، فرستنده و گیرنده از کلید استفاده شده به منظور رمزنگاری اطلاعات آگاهی دارند. رمزنگاری کلیدخصوصی، گزینه‌ای مناسب به منظور مبادله اطلاعات بر روی اینترنت و یا ذخیره سازی اطلاعات حساس در یک بانک اطلاعاتی و یا یک فایل می‌باشد.
    قابل به ذکر که در این روش هم سمت فرستنده (رمز کننده داده) و هم دریافت کننده (رمز گشا) از یک کلید رمز استفاده می کنند.
    رمز نگاری نامتقارن (کلید عمومی) چیست!؟
    رمزنگاری کلید عمومی که از آن با نام رمزنگاری نامتقارن نیز یاد می‌گردد، از دو کلید متفاوت برای رمزنگاری استفاده می‌نماید : یک کلید برای رمزنگاری و کلیدی دیگر برای رمزگشائی. در رمزنگاری کلید عمومی، با استفاده از یک روش کاملا" ایمن یک کلید برای ارسال کننده اطلاعات ایجاد و وی با استفاده از کلید فوق، اقدام به رمزنگاری و ارسال پیام رمز شده برای گیرنده می‌نماید. امکان رمزگشائی پیام رمز شده صرفا" توسط دریافت کننده، امکان پذیر خواهد بود. در رمزنگاری کلید عمومی، سیستم یک زوج کلید خصوصی و عمومی ایجاد می‌نماید. کلید عمومی برای شخصی که از آن به منظور رمزنگاری یک پیام استفاده می‌نماید، ارسال می‌گردد. وی پس از رمزنگاری پیام با استفاده از کلید عمومی، پیام رمز شده را ارسال می‌نماید. دریافت کننده با استفاده از کلید خصوصی، اقدام به رمزگشائی پیام می‌نماید.(
    ما در این آموزش فقط بر روی رمز نگاری متقارن کار می کنیم...
    در رمز نگاری متقارن ما دو نوع الگوریتم معروف داریم که به الگوریتم DES و Rijndeal (AES) مشهورند...
    AES و Rijndeal در واقع یک الگوریتمند ، که تفاوت بسیار جزئی دارند....
    ما در مورد اینکه پشت این الگوریتم ها چه می گذرد ، چیزی نمی گیم ، چون اگر بخوام بگم باید یک کتاب در این مورد بنویسم و من هم اونقدر سواد ریاضی بالایی ندارم ، پیشنهاد می کنم لینک ها یی که داده شده را مطالعه کنید ؛ البته اگر علاقه دارید ، یا یک کتاب تخصصی در این مورد بخوانید یا اگر اونقدر حوصله ندارید و کتاب مهندسی اینترنت دکتر احسان ملکیان را در اختیار دارید ، فصل 11 این کتاب رو مطالعه کنید...
    در ضمن ممکنه این نوشته ، جشنواره ای از اشتباهات املایی ، نگارشی ، تایپی و فنی باشه ، پیشاپیش عذر میخوام...
    و در آخر هم این نکته رو هم بگم ، برای یکپارچه ماندن آموزش ، اگر سوالی ، انتقادی ، اشتباهی و... را خواستید به من اطلاع بدید لطفا ار پیام خصوصی استفاده کنید...

    ویرایش توسط returnx : 8th May 2013 در ساعت 12:14 AM

  2. #2
    Moderator
    تاریخ عضویت
    2012 November
    ارسال ها
    128
    تشکر
    28
    تشکر شده 173 بار در 77 پست


    2 امتياز مثبت از 2 راي
    آيا اين پست براي شما سودمند بود؟ بله | خیر
    ابتدا بريم سراغ الگوريتم DES در دات نت:
    بايد بگيم که براي اينکه از کلاس هاي آماده شده رمزنگاري در دات نت استفاده کنيد بايد فضاي نام System.Security.Cryptography را به پروژتون اضافه کنيد...
    خوب حالا يک کلاس جديد بسيازيد و فضاي نام بالا رو به کلاستون اضافه کنيد ، حالا يک متد جديد ايجاد کنيد ، اين متد قرار آدرس يک فايل ورودي را به همراه آدرس يک فايل خروجي و يک کليد گرفته و فايل وردي را رمز کرده و يک فايل خروجي رمز شده جديد توليد کرده...
    در نتيجه ، امضاي متد شما بايد به اين شکل باشه :

    public void encrypt_file(string input_file_address,string output_file_address,string key)

    نکته مهمي که در اينجا وجود دارد اين هست که ، کليد رمز در اين الگوريتم حتما بايد 64 بيتي باشه!!(اين نکته به برجسته ترين ضعف اين الگوريتم بدل شد!!)
    براي استفاده از الگوريتم DES بايد از کلاس DESCryptoServiceProvider استفاده کنيم اما قبل از آن بايد دو تا FileStream بسازيم ، يکي براي فايل ورودي و ديگري براي فايل خروجي و يک Binary Reader براي خواندن از فايل ورودي و يک Binary Writer براي نوشتن در فايل خروجي پس در نتيجه کد هايي مشابه کد زير به متدتون اضافه کنيد:

    FileStream input_f_stream = new FileStream(input_file_address, FileMode.Open, FileAccess.Read);

    FileStream output_f_stream = new FileStream(output_file_address, FileMode.Create, FileAccess.Write);

    BinaryReader i_reader = new BinaryReader(input_f_stream);

    BinaryWriter i_writer = new BinaryWriter(output_f_stream);

    خوب حالا نوبت به اين ميرسه که از کلاس DESCryptoServiceProvider استفاده کنيم براي استفاده از الگوريتم DES و Set کردن کليد رمز از کد زير استفاده مي کنيم :

    DESCryptoServiceProvider i_des = new DESCryptoServiceProvider();

    i_des.Key = Encoding.ASCII.GetBytes(key);

    i_des.IV = Encoding.ASCII.GetBytes(key);

    باید به این نکته توجه کنیم که اگر ما Key و IV را مقدار دهی نکنیم ، بصورت تصادفی مقدار دهی میشن ، که این کار خیلی جالب نیست ، به این دلیل که ما کلید رمز را برای رمز گشایی نخواهیم داشت!!
    در مورد IV یا initialization vector در مستندات MSDN چیز زیادی بجز این چند خط گفته نشده (یا شایدم من ندیدم):
    Note that you must also provide the initialization vector (IV). This value is used as part of the encryption. Like the key, the IV is randomly generated if you do not provide the value. Because the values must be the same for the encryption and the decryption, you must not permit random generation of these values.
    حالا زمان این رسیده که ما با استفاده از رابط(اینترفیس) ، ICryptoTransform مشخص کنیم که از این الگوریتم می خواهیم در رمز نگاری استفاده کنیم یا رمز گشایی ، برای اینکار از کد زیر استفاده می کنیم:
    ICryptoTransformi_cryptotransform=i_des.CreateEncryptor();

    و حالا نوبت به خواندن و نوشتن در فایل میرسه ، برای اینکه بتونیم فایل ورودی را رمز یا رمزگشایی کنیم از کلاس CryptoStream استفاده می کنیم تا یک جریان رمز نگاری ایجاد کرده باشیم، این کلاس در زمان رمزنگاری ، رمز کردن و نوشتن اطلاعات خوانده شده را در فایل خروجی داره که به این صورت انجام میدیم:

    CryptoStreamencrypt_stream=newCryptoStream(i_writer.BaseStream, i_cryptotransform, CryptoStreamMode.Write);

    در زمان رمز گشایی ، دقیقا این کلاس عکس این عمل را انجام میده و پارامتر آخر باید در حالت Read تنظیم شود...
    و حالا باید از فایل ورودی بخوانیم و از کلاس CryptoStream بخوایم که برای ما در فایل خروجی بنویسه:

    byte[] i_buffer=newbyte[2048];//Buffering 2Mb of file

    while (i_reader.BaseStream.Position<i_reader.BaseStream.Length)




    {



    i_reader.Read(i_buffer, 0, i_buffer.Length);

    encrypt_stream.Write(i_buffer, 0, i_buffer.Length);




    }




    قابل بذکر که این کار رو میشه به دو صورت انجام داد یا فایل رو یکجا بخونیم و یکجا بنویسیم ، یا اینکه فایل را Buffer کنیم بعد بنویسیم ، که این روش پیشنهاد میشه به این دلیل که اگر فضای Ram کمی داشته باشیم ، نمی توانیم فایل های بزرگ را بخوانیم....( در کد نهایی متد هر دو روش موجود هست ، اما روش اول بصورت Comment در آورده شده)
    و مرحله ی آخر بستن تمام جریان ها :


    encrypt_stream.Close();

    input_f_stream.Close();

    i_writer.Close();

    i_reader.Close();

    output_f_stream.Close();

    به دلیل ، محدودیت 300000 کارکتری در هر پست ، کد کامل این متد در پست بعدی گذاشته می شود...

    ویرایش توسط returnx : 8th May 2013 در ساعت 12:16 AM

  3. #3
    Moderator
    تاریخ عضویت
    2012 November
    ارسال ها
    128
    تشکر
    28
    تشکر شده 173 بار در 77 پست


    1 امتياز مثبت از 1 راي
    آيا اين پست براي شما سودمند بود؟ بله | خیر
    تمام کد متد بالا بصورت یکپارچه:
     public void encrypt_file(string input_file_address,string output_file_address,string key)//Encrypt File
    {
    //File Streams:
    FileStream input_f_stream = new FileStream(input_file_address, FileMode.Open, FileAccess.Read);
    FileStream output_f_stream = new FileStream(output_file_address, FileMode.Create, FileAccess.Write);
    BinaryReader i_reader = new BinaryReader(input_f_stream);
    BinaryWriter i_writer = new BinaryWriter(output_f_stream);
    //Create Algorithms Provider:
    DESCryptoServiceProvider i_des = new DESCryptoServiceProvider();
    i_des.Key = Encoding.ASCII.GetBytes(key);
    i_des.IV = Encoding.ASCII.GetBytes(key);
    ICryptoTransform i_cryptotransform = i_des.CreateEncryptor();
    //Read Orginal File And Encrypting Then Save To Secondery file:
    CryptoStream encrypt_stream = new CryptoStream(i_writer.BaseStream, i_cryptotransform, CryptoStreamMode.Write);
    /*
    byte[] i_buffer = new byte[input_f_stream.Length];
    i_reader.Read(i_buffer, 0, i_buffer.Length);
    encrypt_stream.Write(i_buffer, 0, i_buffer.Length);
    */
    byte[] i_buffer = new byte[2048];//Buffering 2Mb of file
    while (i_reader.BaseStream.Position < i_reader.BaseStream.Length)
    {
    i_reader.Read(i_buffer, 0, i_buffer.Length);
    encrypt_stream.Write(i_buffer, 0, i_buffer.Length);
    }

    encrypt_stream.Close();
    input_f_stream.Close();
    i_writer.Close();
    i_reader.Close();
    output_f_stream.Close();
    }

    در پست بعد روش رمزگشایی را مرور خواهیم کرد...


  4. #4
    Moderator
    تاریخ عضویت
    2012 November
    ارسال ها
    128
    تشکر
    28
    تشکر شده 173 بار در 77 پست


    1 امتياز مثبت از 1 راي
    آيا اين پست براي شما سودمند بود؟ بله | خیر
    حالا نوبت ميرسه به رمزگشايي (Decryption) ، البته استفاده از لغت رمز شکني فکر کنم درست تر باشه!!!
    مراحلي که در رمز گشايي فايل داريم ، کاملا شبيه قبل است با اين تفاوت که کار CryptoStream تغيير مي کند و عکس عمل رمز کردن را انجام مي دهد...
    امضاي اين متد بايد به شکل زير باشد تا آدرس يک فايل رمز شده را همراه با يک آدرس براي فايل رمز گشايي شده و يک کليد رمز دريافت کند:
    public void decrypt_file(string input_file_address,string output_file_address,string key)

    حالا يک File Stream و يک Binary Reader براي خواندن از فايل ورودي به شکل زير ايجاد مي کنيم:
     FileStream input_f_stream = new FileStream(input_file_address, FileMode.Open, FileAccess.Read);
    BinaryReader i_reader = new BinaryReader(input_f_stream);

    و حالا بايد کلاس الگوريتم DES رو ايجاد کنيم که مانند متد رمز کننده از کد زير استفاده مي کنيم :
     DESCryptoServiceProvider i_des = new DESCryptoServiceProvider();
    i_des.Key = Encoding.ASCII.GetBytes(key);
    i_des.IV = Encoding.ASCII.GetBytes(key);

    حالا بايد با استفاده از رابط ICryptoTransform مشخص کنيم که قرار چه عملي را انجام بده!؟ رمز نگاريي يا رمز گشايي !؟ جواب مشخصه :
    ICryptoTransform i_cryptotransform = i_des.CreateDecryptor();

    خوب ، حالا بايد با استفاده از جريان رمز فايل رمز شده را بخوانيم و رمز گشايي کنيم ، براي اينکار از کلاس CryptoStream ، به شکل زير استفاده ميکنيم :
    CryptoStream deccrypt_stream = new CryptoStream(i_reader.BaseStream, i_cryptotransform, CryptoStreamMode.Read);

    در پارامتر اول ، جريان ورودي را مي فرستيم ، در پارامتر دوم ICryptoTransform ميفرستيم تا مشخص کند وظيفه CryptoStream چيست و در پارامتر سوم مشخص کرديم که بايد چه عملي را انجام دهد...
    و حالا بايد فايل رمز شده اي که خوانديم و رمز گشايي کرديم را در يک فايل جديد بنويسيم:
     byte[] i_buffer = new byte[input_f_stream.Length];
    StreamWriter i_stream_writer = new StreamWriter(output_file_address);
    BinaryWriter i_writer = new BinaryWriter(i_stream_writer.BaseStream);
    deccrypt_stream.Read(i_buffer, 0, i_buffer.Length);
    i_writer.Write(i_buffer);

    اما مشکلي که ما در اين قسمت باهاش روبرو هستييم اينکه کلاس CryptoStream قابلیت Seek نداره و ما نمی توانیم فایل های بزرگ را باهاش رمز گشایی کنیم ، متاسفانه هنوز برای بر طرف کردن این مشکل راهی پیدا نکردم!!!
    و اما مرحله ی آخر ، بستن تمام جریان ها:
     deccrypt_stream.Close();
    input_f_stream.Close();
    i_stream_writer.Flush();
    i_stream_writer.Close();
    i_reader.Close();
    i_writer.Close();

    کد کامل این متد در پست بعدی قرار خواهد گرفت....


  5. #5
    Moderator
    تاریخ عضویت
    2012 November
    ارسال ها
    128
    تشکر
    28
    تشکر شده 173 بار در 77 پست


    1 امتياز مثبت از 1 راي
    آيا اين پست براي شما سودمند بود؟ بله | خیر
            public void decrypt_file(string input_file_address,string output_file_address,string key)
    {
    //File Streams:
    FileStream input_f_stream = new FileStream(input_file_address, FileMode.Open, FileAccess.Read);
    BinaryReader i_reader = new BinaryReader(input_f_stream);
    //Create Algorithms Provider:
    DESCryptoServiceProvider i_des = new DESCryptoServiceProvider();
    i_des.Key = Encoding.ASCII.GetBytes(key);
    i_des.IV = Encoding.ASCII.GetBytes(key);
    ICryptoTransform i_cryptotransform = i_des.CreateDecryptor();

    CryptoStream deccrypt_stream = new CryptoStream(i_reader.BaseStream, i_cryptotransform, CryptoStreamMode.Read);

    //Read Encrypted File And Write To Decrypted File:

    byte[] i_buffer = new byte[input_f_stream.Length];
    StreamWriter i_stream_writer = new StreamWriter(output_file_address);
    BinaryWriter i_writer = new BinaryWriter(i_stream_writer.BaseStream);
    deccrypt_stream.Read(i_buffer, 0, i_buffer.Length);
    i_writer.Write(i_buffer);

    deccrypt_stream.Close();
    input_f_stream.Close();
    i_stream_writer.Flush();
    i_stream_writer.Close();
    i_reader.Close();
    i_writer.Close();
    }//End function



  6. #6
    کاربر فعـال
    تاریخ عضویت
    2013 March
    ارسال ها
    101
    تشکر
    154
    تشکر شده 124 بار در 75 پست


    آيا اين پست براي شما سودمند بود؟ بله | خیر
    در گرافها و رنگ پذیری تو ریاضیات با این مقوله آشنا شدم .در واقع در سطوح پیشرفته این مسئله بچه های ریاضی هست . مثل محاسبات پیچیده برای کنترل فهباد امریکایی که در واقع کار بچه های ریاضی بود . با بمباران الکترونیکی و بدست اوردن زمان مناسب اول رمز شکنی ریاضی این مسئله انجام میشه و بعد کار های دیگه ... . ولی نمود این مقوله توسط بچه های نرم قابل لمس تر هست . مثل متنی مهمی که کد میشه و در قالب عکس دیده میشه . مقوله رمز در ایران در چند دانشگاه بصورت خاص تدریس میشه و باعث میشه کمتر بررسی بشه . من چقدر براتون خوشحالم که تو این بیمیلی این کار رو انجام دادین .

    ویرایش توسط jellyfish : 8th May 2013 در ساعت 06:11 AM

 

 

کاربران برچسب خورده در این موضوع

علاقه مندی ها (Bookmarks)

علاقه مندی ها (Bookmarks)

مجوز های ارسال و ویرایش

  • شما نمیتوانید موضوع جدیدی ارسال کنید
  • شما امکان ارسال پاسخ را ندارید
  • شما نمیتوانید فایل پیوست کنید.
  • شما نمیتوانید پست های خود را ویرایش کنید
  •  


Powered by vBulletin
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Content Relevant URLs by vBSEO 3.6.0
Persian Language By Ustmb.ir
این انجمن کاملا مستقل بوده و هیچ ارتباطی با دانشگاه علوم و فنون مازندران و مسئولان آن ندارد..این انجمن و تمامی محتوای تولید شده در آن توسط دانشجویان فعلی و فارغ التحصیل ادوار گذشته این دانشگاه برای استفاده دانشجویان جدید این دانشگاه و جامعه دانشگاهی کشور فراهم شده است.لطفا برای اطلاعات بیشتر در رابطه با ماهیت انجمن با مدیریت انجمن ارتباط برقرار کنید
ساعت 02:11 PM بر حسب GMT +4 می باشد.