تبلیغات :
خرید لپ تاپ استوک
ماهان سرور
آکوستیک ، فوم شانه تخم مرغی ، پنل صداگیر ، یونولیت
دستگاه جوجه کشی حرفه ای
فروش آنلاین لباس کودک
خرید فالوور ایرانی
خرید فالوور اینستاگرام
خرید ممبر تلگرام

[ + افزودن آگهی متنی جدید ]




صفحه 28 از 231 اولاول ... 182425262728293031323878128 ... آخرآخر
نمايش نتايج 271 به 280 از 2307

نام تاپيک: بحث و گفتگو در مورد قفل سی دی ها (شکستن و گذاشتن انواع قفل)

  1. #271
    حـــــرفـه ای mehdi_7070's Avatar
    تاريخ عضويت
    Aug 2005
    پست ها
    3,232

    پيش فرض

    اين يه مقاله توپ در مورد يك نوع قفل جديد :twisted:

    .:: قفل هاي اکتيو ايکس ::.
    تعريف قفل هاي اكتيو ايكس :
    در واقع يك اكتيو ايكس كه مانع اجراي برنامه در شرايط خاصي شود را قفل اكتيو ايكس مينامند. اين نوع قفل مانند ساير كامپوننتهاي برنامه نويسي است . برنامه نويس به سادگي آن را بر روي فرم برنامه خود قرار ميدهد و با تنظيم پارامترها و خصوصيات آن ،‌ سبب فعاليت آن ميشود. اين اكتيو ايكس قبل از قرارگرفتن فرم اصلي در حافظه ، شروع به كار ميكند و اگر براي اولين بار اجرا ميشود بر حسب اندازه حافظه ، شماره هاي سريال و سرعت پردازنده كد ويژه اي توليد ميكند اين كد توليد شده وابسته به خصوصيات كامپيوتر است بنابراين كد برگشتي اين اكتيو ايكس بر روي هر سيستمي متفاوت خواهد بود. پس از ارائه كد ، كد معادل آن را از كاربر در خواست ميكند. كاربر با ارائه كد توليد شده به شركت توليد كننده نرم افزار كد معادل آن را دريافت ميكند.اين كد را كاربر يا از طريق تلفن يا از طريق پست الكترونيكي و يا اينترنت دريافت ميكند در صورتيكه كد معادل دريافت شده پس از كد شدن معادل كد ارائه شده باشد يا به عبارتي ديگر كد ارائه شده از طرف كامپيوتر مكمل كد دريافت شده از شركت باشد اكتيو ايكس اجازه ميدهد كه برنامه بدون اشكال شروع به كار كند. كاربر نيز ميتواند بارها از اين كد بر روي كامپيوتر خود(كامپيوتري كه كد دريافت كرده) استفاده كند. پس از ورود كد، اين كد در مكاني از سيستم مثلا ريجستري يا يك فايل بصورت كد شده قرار ميگيرد و هر بار كامپيوتر برنامه را اجرا كند به جاي درخواست كد از كاربر ، كد را از رجيستري يا فايل پس از كديابي مورد استفاده قرار ميدهد. نقاط ضعف: 1.قفلهاي اكتيو ايكس نياز به دريافت كد از شركت دارند يعني اينكه بايد كاربر حتما به نحوي با شركت توليد كننده تماس بگيرد و نميتواند برنامه را پس از خريد بلافاصله استفاده كند . خصوصا دسترسي به تلفن و اينترنت ضروري است. 2. قفلهاي اكتيو ايكس تنها بر روي يك سيتسم اجرا ميشوند و بايد براي دريافت كد براي هر كامپيوتر اقدام شود.(دشواري در نصب هاي تعداد بالا) 3.قفلهاي اكتيو ايكس ممكن است با فرمت كردن ، پارتيشن بندي تعغير يابد كه نميتواند شركت دقيقا حدس بزند كه اين قفل براي اين سيستم بوده يا واقعا تعغير كرده . در اكثر قفلهاي ساخته شده تعغيرات اين كد بسيار مشاهده شده است. 4. با صدمه ديدن قطعه اي در كامپيوتر و يا تعويض يك قطعه برنامه تصور ميكند كه سيتسم تعغير يافته است مثلا با تعغير حافظه سيستم. نقاط قوت: 1- امنيت بالا براي برنامه نويس از نظر كپي برداري با تعداد بالا. 2- داراي بيشترين امنيت نسبت به ساير قفلهاي نرم افزاي يا سي دي 3- سازگاري بسيار بالا نسبت به ساير قفلهاي نرم افزاري. 4- قابليت آمار گيري فروش برنامه توسط شركت ارائه كننده كد معادل نحــوه ايجاد قفل براي برنامه نويسان ويژوال بيسيك: اول اينكه اين برنامه بايد بصورت اكتيو ايكس توليد شود كه بتوان از آن به سادگي استفاده نمود. قدم اول براي توليد آن اين است كه برنامه قبل از فرم اصلي بار شود. قدم دوم ارائه يك كد توليد شده براي سيستم است اين بخش تقريبا هسته برنامه را تشكيل ميدهد بنابراين در مورد اين قسمت توضيحات بيشتري ارائه ميكنم كدي كه اكتيو ايكس براي يك كامپيوتر خاص توليد ميكند بايد منحصر بفرد باشد يعني نبايد در سيستمهاي ديگر مشابه آن پيدا شود همچنين مهمترين نكته اي كه بايد براي توليد اين كد در نظر گرفته شود اين است كه با تعغيرات كوچك درون سيستم تغيير نكند بدين منظور ميتوان آن را به قسمتهاي مختلف كامپيوتر بنا بر نوع انتظار قفل تغيير دهيم مثلا به شماره سريال هارد يا مثلا به مقدار حافظه سيستم يا به نوع كارت گرافيكي و... و يا به مجموع آنها وابسته كنيم. بسياري سوال كردند در ويژوال بيسيك چگونه ميتوان شماره سريال هارد را بدست آورد؟ براي اين منظور ميتوان از API ها استفاده نمود. يك API خوب براي اين منظور GetVolumeInformation است قدم سوم ايجاد كد مكمل است . بصورتهاي گوناگون ميتوان براي كد توليد شده كد مكمل ايجاد كرد اولين روش استفاده كه ساده ترين است استفاده از يك فرمول است مثلا يك مثال ساده اين است كه اگر كد توليد شده 15663 بود برنامه با جمع كردن اعداد زوج و فرد اين عدد و تقسم نمودن و ضرب در 5586 يك كد توليد كند ايراد اينگونه روشها در قابل كشف بودن كد ميباشد مگر اينكه واقعا يك رياضيدان باشيد. روش ديگر توليد كد هاي تصادفي مثلا در ويژوال بيسيك بوسيله Randomize Timer و تشكيل يك بانك اطلاعاتي است كه كد معادل و كد ارايه شده براي همه آنها را در آوريم اين روش بسيار اطمينان بخش تر است. ديگر تمام است بسادگي يك قفل حرفه اي ساخته ايم . آنهم با ساده ترين زبان دنيا ويژوال بيسيك اگر آن را با برنامه هاي ديگر توليد كنيد كه ديگر محشر است ! با كمي رنگ و لعاب دادن به اكتيو ايكس خودمان و توليد همان پايگاه داده و تعيين پارامترهاي گوناگون مثلا محدود كردن در تعداد ، نوع وابستگي و ... براي برنامه خود ، حتي ميتوانيم آن را بفروش برسانيم !

  2. #272
    حـــــرفـه ای mehdi_7070's Avatar
    تاريخ عضويت
    Aug 2005
    پست ها
    3,232

    پيش فرض

    .:: اطلاعيه ::.
    دوستان علاقمند به قفل شكستن !
    هر كسي دوست داشت قفل برنامه اي را بشكند براي من پيغام خصوصي بفرستد

  3. #273
    داره خودمونی میشه
    تاريخ عضويت
    Feb 2005
    پست ها
    193

    پيش فرض

    آقا اگه چیزی بلدی بهتره بگی تا همه استفاده کنن
    اینجا که جای تبلیغ نیست

  4. #274
    پروفشنال double_n's Avatar
    تاريخ عضويت
    Apr 2005
    محل سكونت
    the Shire
    پست ها
    900

    پيش فرض

    mehdi_7070 جان بلدی برای این آموزشی که دادی آموزش برنامه نویسی هم بذاری :?:

    موفق باشید

  5. #275
    حـــــرفـه ای mehdi_7070's Avatar
    تاريخ عضويت
    Aug 2005
    پست ها
    3,232

    پيش فرض

    پس چي شد آقايان ادعا .
    چرا ديگه چيزي نمي فرستيد يا نمي گيد دارم آموزش مي نويسم .
    ديديد نمي شه قفلي نوشت كه باز نشه .
    +++
    من هنوز منتظر مقاله هاي دست اول دوستان حرفه اي تز از خودم هستم . لااقل نظر بديد . بي معرفت ها :shock:
    +++
    دنبال يه مقاله درباره قفل هاي سخت افزاري و نرم افزاري هستم كه تا چند ساعت ديگه مي گذارم . بريد و حال كنيد .

    ادقام شد

  6. #276
    حـــــرفـه ای mehdi_7070's Avatar
    تاريخ عضويت
    Aug 2005
    پست ها
    3,232

    پيش فرض

    قفل هاي نرم افزاري چگونه طراحي مي شوند؟

    با توجه به فزوني نرم افزار در سيستم هاي كامپيوتري از يك طرف و توانايي كنترل كپي هاي غيرمجاز ( از ديدگاه اقتصادي آن ) از طرفي ديگر دليلي محكم جهت بررسي اين شاخه از مهندسي نرم افزار مي باشد.
    از آنجا كه متاسفانه قانون Copyright در تمام جهان بجز ايران و چند كشور ديگر اجرا مي گردد, بحث كنترل كپي هاي غيرمجاز حساس تر مي شود. در اين مقاله سعي بر اين است تا علاوه بر آشنايي با انواع قفل هاي نرم افزاري و اختلاف آن ها با قفل هاي سخت افزاري, بتوانيم به عنوان طراح يك قفل نرم افزاري از محصولات نرم افزاري خودمان حمايت كنيم. ضمنا علاوه بر آشنايي با مفاهيم فوق, نوشتن روتين هاي ضد ديباگ و همچنين نحوه كد كردن اطلاعات نيز لحاظ شده است.
    لازم به ذكر است كه اين مقاله حاصل تجربيات چند ساله و زحمات زيادي است كه تقديم مي گردد.




    كلمات كليدي
    Key Lock, Hard Lock, Software Lock, قفل نرم افزاري، Tag Lock, Anti Debug, قفل سخت افزاري


    مقدمه
    از آنجا كه زمان زيادي تا سال 2000 باقي نمانده, اما هنوز در كشور ما ايران, نرم افزار جاي خود را به عنوان يك محصول صادراتي پيدا نكرده چرا كه يكي از دلايل اصلي آن عدم توجه جدي به حمايت از توليد كنندگان نرم افزار مي باشد. به هر حال قصد اينجانب از ارائه مقاله, بررسي كم و كاستي هاي نرم افزار در ايران نيست بلكه طريقه حل مشكل موجود در اين بازار نابسامان مي باشد. با توجه به كپي هاي غيرمجازي كه روزانه بصورت كاملا عادي و بدون اطلاع سازنده آن صورت مي گيرد, جلوگيري از اين عمل و كنترل جدي آن امري ضروري و واجب بنظر مي رسد. در ادامه مطلب به توضيح درباره قفل هاي نرم افزاري و سخت افزاري مي پردازيم.

    آشنايي با قفل هاي نرم افزاري و سخت افزاري

    تعريف قفل هاي نرم افزاري: به هر برنامه اي كه كنترل كپي آن فقط از طريق نرم افزار و بدون نياز به سخت افزار اضافي قابل انجام باشد, گويند.
    تعريف قفل هاي سخت افزاري: به هر برنامه اي كه كنترل كپي آن از طريق سخت افزار اضافي قابل انجام باشد, گويند.
    با توجه به تعاريف فوق مي توان به تفاوت قفل هاي سخت افزاري و نرم افزاري پي برد. قفل هاي سخت افزاري با توجه به اضافه كردن يك سخت افزار جديد به كامپيوتر ( اغلب از طريق ارتباط با پورت چاپگر ) برنامه خود را كنترل مي كنند. برنامه قبل از اجرا ابتدا با توجه به مراجعه به آدرس سخت افزار نصب شده ( اضافه شده با استفاده از دستور Port ) به سخت افزار مورد نظر خود مراجعه كرده و در صورت يافتن آن, تست هاي مختلف اعم از تست رمز, خواندن اطلاعات و ... مي تواند تصميم گيري نمايد. اما در قفل هاي نرم افزاري برنامه بدون نياز به سخت افزار اضافي و با كنترل رسانه ذخيره سازي مي تواند تصميم گيري كند. ضمنا لازم به توضيح است كه هدف از طراحي قفل هاي نرم افزاري/ سخت افزاري اين نيست كه هيچكس توانايي شكستن ( باز كردن ) آنرا ندارد بلكه مقصود بالا بردن سطح كنترل كپي هاي غير مجاز تا حد ممكن مي باشد. ( چرا كه مي دانيم اطلاعات همه در يك سطح نيست. )

    طريقه استفاده از قفل نرم افزاري در برنامه مورد نظر
    با توجه به نوع كاربرد برنامه ( كوچك وقابل كپي بر روي يك ديسكت, تحت شبكه و ... ) مي توانيم از انواع روش هايي كه جهت حفاظت از نرم افزار در نظر داريم ( و متعاقبا توضيح داده خواهد شد ) استفاده كنيم. اما مساله قابل بحث اين است كه چگونه از يك قفل منتخب استفاده نمائيم؟
    جواب اين سوال متغيير و وابسته به شرايط زير مي باشد:
    الف: اعتقاد طراح نرم افزار به اينكه كاربر حتما بايد آنرا خريداري نمايد تا از امكانات آن مطلع گردد.
    در اين حالت قفل نرم افزاري در ابتداي شروع به كار برنامه كنترل مي گردد حتي طراح مي تواند در مواقع حساس نيز قفل را مجددا كنترل كند و يا در حالتي كه طراح واقعا سخت گير باشد, مي تواند در زمان هاي مشخصي از وجود قفل اطمينان حاصل نمايد ( مثلا هر 4 ثانيه ). البته در اين حالت طراح بايد روشي را كه جهت كنترل قفل استفاده مي كند, نيز در نظر بگيرد.
    ب: اعتقاد طراح نرم افزار به اين كه كاربر مي تواند از نرم افزار به عنوان نسخه نمايشي نيز استفاده كند.
    طراح در اين حالت مي بايست در مكان هاي خاصي از برنامه, قفل را كنترل كند. مثلا در يك برنامه حسابداري مي توان تمام بخش هاي سيستم را آزاد گذاشته ( يعني برنامه نيازي به قفل نداشته باشد ) اما در صورتي كه كاربر مايل به استفاده از امكانات گزارشگيري سيستم باشد, قفل نرم افزاري در خواست گردد. مزيت اين روش بر روش قبلي اين است كه ديگر نياز به طراحي نسخه نمايشي جهت مشاهده كاربران وجود ندارد.

    آشنايي با نحوه قفل گذاري بر روي يك برنامه
    الف: طراح به سورس برنامه دسترسي دارد.
    در اين حالت طراح پس از انتخاب روش قفل گذاري, كافيست آنرا به زبان مورد نظر خود پياده سازي نموده و در برنامه خود بگنجاند. ( كه مكان هاي قرار دادن قفل در عنوان قبلي توضيح داده شد. )
    ب: طراح ( مجري پروژه ) به سورس برنامه دسترسي ندارد.
    گاهي اوقات به يكسري برنامه هاي ارزشمندي برخورد مي كنيم كه فاقد قفل هستند, بنابراين نياز به قفل گذاري وجود دارد. ( البته اين حالت بيشتر در كشور ما و چند كشور ديگر كه در آن ها قانون Copyright معني ندارد, كاربرد دارد. ) جهت تزريق قفل به اين گونه برنامه ها, نياز به آشنايي كامل به ساختار فايل هاي اجرايي (EXE, COM, SYS, …) وجود دارد چرا كه بايد برنامه اي طراحي كنيم تا همانند يك ويروس كامپيوتري به فايل اجرايي مشخصي بچسبد. البته جهت اينكار بهترين زبان برنامه نويسي, اسمبلي مي باشد. ( بدليل توانايي دخالت در روند اجراي برنامه )
    البته در رابطه با نحوه نوشتن اين گونه برنامه ها, روش هاي زيادي وجود دارد كه خود بحثي مجزا را مي طلبد و از حوصله اين مقاله خارج است.
    ضمنا براي بالا بردن سطح امنيت برنامه لازم است تا يكسري كد هاي ضد ديباگ در برنامه گنجانده شوند. كدهاي ضد ديباگ, دستوراتي به زبان اسمبلي هستند كه در حالت اجراي عادي برنامه, هيچ تغييري در روند اجراي نمي گذارند بلكه در صورتي كه برنامه توسط ديباگرها اجرا گردد ( مورد ارزيابي قرار گيرد ) بتواند از اجراي آن جلوگيري نمايد. با اضافه كردن كد هاي ضد ديباگ به ابتداي برنامه ( يا قبل از كنترل قفل ) مي توان احتمال دستكاري در برنامه را پائين آورد. ( نحوه نوشتن كد هاي ضد ديباگ در پيوست A آورده شده است.)

    آشنايي با روش هاي قفل گذاري و نحوه طراحي آن ها

    1- قفل گذاري با استفاده از شماره سريال اصلي ديسكت
    همانطور كه مي دانيد, سيستم عامل جهت هر ديسكت يك شماره سريال واحد (UNIQUE) اختصاص مي دهد, بطوريكه شماره سريال هر دو ديسكت با هم يكي نيستند. بنابراين همين خود يك راه تشخيص ديسكت كليد ( قفل ) مي باشد.
    جهت استفاده از اين قفل مي بايست شماره سريال ديسكت را خوانده و سپس در داخل برنامه آنرا كنترل نمائيم. يك راه ساده جهت خواندن شماره سريال, اجراي دستور VOL بصورت شكل مقابل است:
    VOL >>COSLCK.TMP
    بعد با باز كردن فايل LCK.TMP, مي توانيم به محتويات آن دسترسي پيدا كنيم. راه ديگر مراجعه به Boot Sector جهت كنترل قفل مي باشد.
    ضريب اطمينان اين قفل در مورد ديسكت ها, 5%-2% بوده و در رابطه با هارد ديسك 60%-50% مي باشد. دليل اين اختلاف اين است كه در حالت قفل ديسكتي با كپي Boot Sector, قفل بر روي ديسكت ديگر قرار خواهد گرفت اما در رابطه با هارد ديسك اينكار به سادگي انجام پذير نيست.

    2- قفل گذاري با استفاده از مشخصات سيستم
    در اين نوع قفل نرم افزاري, برنامه قبل از اجرا ابتدا مشخصات سيستم را خوانده ( كه اينكار از طريق مراجعه به بخش هاي خاصي از حافظه و يا مراجعه به اطلاعات BIOS انجام مي شود. ) سپس آنرا با فايلي كه قبلا توسط نويسنده نرم افزار بر روي كامپيوتر كپي گرديده, مقايسه مي كند و در صورت عدم برابري, اجراي برنامه پايان مي پذيرد.
    اين نوع قفل هنوز هم در بسياري از برنامه ها استفاده مي گردد, اما نكته قابل ذكر اين است كه جهت اطمينان بيشتر به قفل لازم است فايل حاوي مشخصات بصورت كد شده نوشته شده باشد تا امكان دستكاري آن توسط قفل شكنان به حد اقل ممكن برسد.
    درصد اطمينان اين نوع قفل 75%-65% مي باشد.

    3- قفل با استفاده از موقعيت فايل روي هارد ديسك
    اين نوع قفل فقط بر روي هارد ديسك قابل استفاده بوده و به اين صورت است كه فايل اجرايي به موقعيت خود بر روي هارد حساس مي باشد چرا كه قبل از اجرا ابتدا موقعيت خود را از روي سكتورهاي ROOT خوانده و سپس شماره كلاستر اشاره گر به خودش را بدست مي آورد, سپس آنرا با شماره كلاستري كه قبلا توسط برنامه نويس بر روي يكي از فايل هاي برنامه ( ممكن است بصورت كد شده باشد ) قرار داده شده, مقايسه كرده و در صورت برابر بودن اجرا مي شود. اين نوع قفل نسبت به قفل قبلي ( شماره 2 ) استفاده كمتري داشته چرا كه در صورتيكه برنامه از روي بخشي از هارد به ناحيه ديگري انتقال يابد, اجرا نخواهد شد و اين از نظر كاربر بسيار ناپسند مي باشد. ( ضمنا امكان Defra, Scandisk, و ... نيز وجود ندارد چرا كه شماره كلاستر اشاره گر به فايل تغيير خواهد كرد. )
    ضريب اطمينان اين نوع قفل نيز 80%-70% مي باشد.

    4- قفل با استفاده از فرمت غير استاندارد
    اين شيوه يكي از رايج ترين قفل هاي نرم افزاري است كه هنوز هم بصورت جدي مورد استفاده قرار مي گيرد. برخي از دلايل اهميت آن عبارتند از:
    - امكان استفاده از روش هاي متفاوت در اين روش
    - راحتي و سرعت زياد به هنگام استفاده آن
    - وجود ضريب اطمينان بالا و انعطاف پذيري زياد آن
    - عدم وجود نرم افزار خاصي جهت باز كردن اين نوع از قفل ها
    همان طور كه مي دانيم سيستم عامل جهت دسترسي به اطلاعات يك ديسكت از فرمت خاصي ( 18 سكتور در هر تراك ) استفاده مي كند اما اگر يه تراك به صورت غير استاندارد فرمت شود, ( مثلا 19 سكتور در تراك ) سيستم عامل ديگر توانايي استفاده از سكتورهاي غيرمجاز را نخواهد داشت و بنابراين تمام نرم افزارهاي تحت سيستم عامل مزبور نيز از سكتورهاي مخفي استفاده نكرده, در نتيجه امكان كپي برداري از آنها بسيار ضعيف است. مانيز از همين روش جهت طراحي قفل مورد نظر مان استفاده مي كنيم. بصورتيكه تراك آخر ديسك را بصورت يك سكتوري و با شماره 20 فرمت مي كنيم. سپس جهت كنترل ديسكت به سكتور فوق مراجعه كرده و در صورت وجود, كنترل برنامه را پي مي گيريم. البته غير از تغيير شماره سكتور مي توان از اندازه غير مجاز نيز استفاده كرد يعني بجاي اينكه سكتورها را بصورت 512 بايتي فرمت كنيم, از اندازه 1024, 2048 و ... استفاده مي كنيم. ( قفل نرم افزاري Copy Control كه معروفترين در نوع خود مي باشد, از همين روش استفاده مي كند. )
    اين قفل فقط جهت فلاپي ديسك قابل استفاده مي باشد و در صد اطمينان در اين روش حدود 95%-85% مي باشد.

    5- قفل با استفاده از شماره سريال ساختگي
    اين روش قفل گذاري كه قويترين قفل مي باشد, بصورت مخلوطي از روش هاي 1 و 4 مي باشد يعني ابتدا تراك خاصي را بصورت غير استاندرد فرمت كرده و سپس اطلاعات خاصي را درون آن قرار مي دهند ( شماره سريال فرضي ). اين قفل فقط جهت فلاپي ديسك قابل استفاده بوده و ضريب اطمينان آن حدود 98%-90% مي باشد.

    پيوست A- روتين هاي ضد ديباگ Anti Debug Procedures

    همان طور كه توضيح داده شد, روتين هاي ضد ديباگ جت جلوگيري از اجراي برنامه هاي ديباگر و يا جلوگيري از ( حد اقل مشكل كردن كار ) دستكاري توسط قفل شكنان, استفاده مي شوند. در زير توضيحات چند روش موثر و مفيد, آورده شده است:

    الف: غير فعال كردن وقفه ها
    جهت جلوگيري از اجراي مرحله به مرحله ( Trace كردن ) برنامه, مي توان وقفه هاي كنترلر 8359 را غير فعال ساخت. آدرس اين كنترلر 21h بوده و IRQ هاي 7-0 را كنترل مي كند IRQ1 همان وقفه مربوط به صفحه كليد مي باشد. پس با غير فعال كردن اين وقفه مي توان صفحه كليد را غير فعال نمود.

    طريقه استفاده:


    CS:0100 E421 IN AL,21
    CS:0102 0C02 OR AL,02
    CS:0104 E621 OUT 21,AL



    ب: تغيير بردار وقفه ها
    يكي از روش هاي ساده و راحت جهت ضد ديباگ كردن برنامه ها, تغيير برداري است, كه ديباگر از آن استفاده مي كند. (03 ) حتما بخاطر بسپاريد كه در پايان برنامه دوباره آدرس بردار وقفه تغيير داده شده را بازيابي كنيد.

    طريقه استفاده:


    CS:0100 EB04 JMP 0106
    CS:0102 0000 ADD [BX+SI],AL
    CS:0104 0000 ADD [BX+SI],AL
    CS:0106 31C0 XOR AX,AX
    CS:0108 8EC0 MOV ES,AX
    CS:010A 268B1E0C00 MOV BX,ES:[000C]
    CS:010F 891E0201 MOV [0102],BX
    CS:0113 268B1E0E00 MOV BX,ES:[000E]
    CS:0118 891E0401 MOV [0104],BX
    CS:011C 26C7064C000000 MOV Word Ptr ES:[000C],0000
    CS:0123 26C7064E000000 MOV Word Ptr ES:[000E],0000



    ج:گيج كردن ديباگر
    اين راه يكي از قويترين تكنيك هاي ضد ديباگ بوده كه در آن به وسط يك دستور, پرش مي شود و اينكار باعث قفل كردن ( Hang ) ديباگر خواهد شد.

    طريقه استفاده:


    CS:0100 E421 IN AL,21
    CS:0102 B0FF MOV AL,FF
    CS:0104 EB02 JMP 0108
    CS:0106 C606E62100 MOV Byte Ptr [21E6],00
    CS:010B CD20 INT 20



    د: كنترل پرچم هاي CPU
    اين روش در برابر ديباگرها بسيار مفيد مي باشد و به اين صورت است كه ابتدا پرچم Trace از CPU را خاموش كرده و در بين برنامه آنرا كنترل كنيم. در صورتيكه اين پرچم روشن شده باشد, مشخص است كه ديباگر در پشت صحنه در حال اجراست.

    طريقه استفاده:


    CS:0100 9C PUSHF
    CS:0101 58 POP AX
    CS:0102 25FFFE AND AX,FEFF
    CS:0105 50 PUSH AX
    CS:0106 9D POPF



    و در بين برنامه از دستورات ذيل استفاده كنيد:


    CS:1523 9C PUSHF
    CS:1524 58 POP AX
    CS:1525 250001 AND AX,0100
    CS:1528 7402 JZ 152C
    CS:152A CD20 INT 20



    ه: متوقف ساختن ديباگر
    اين روش باعث متوقف شدن ديباگر مي شود كه با اجراي دستور ساده INT 03 مي توان اين كار را انجام داد.

    طريقه استفاده:


    CS:0100 B96402 MOV CX,0264
    CS:0103 BE1001 MOV SI,0110
    CS:0106 AC LODSB
    CS:0107 CC INT 3
    CS:0108 98 CBW
    CS:0109 01C3 ADD BX,AX
    CS:010B E2F9 LOOP 0106



    پيوست B- روش هاي كد كردن اطلاعات Data Coding Procedures

    الف: افزودن يك عدد به كد هاي يك فايل
    در اين روش جهت كد كردن يك فايل, ابتدا آنرا خوانده و سپس يك مقدار خاص, مثلا 20 را به مقدار هر بايت فايل اضافه مي كنيم. اين يكي از ساده ترين روش ها بوده و نسبتا كارايي خوبي نيز دارد. جهت خارج كردن فايل از حالت كد شده ( Decode ) نيز, كافيست مقدار فوق را از تمام بايت هاي فايل كم كنيم.

    ب: XOR كردن كل فايل
    در اين روش نيز پس از خواندن كل فايل, تمام بايت هاي آنرا با رشته كاراكتري يا عدد ثابت خاصي XOR كرده و سپس مقدار جديد را در فايل حاصل ضبط مي نمائيم. جهت خارج كردن فايل از حالت كد شده, دقيقا عمل فوق را انجام مي دهيم.

    پيوست C- ليست برنامه قفل گذار Pascal Source To Learn

    در زير ليست دو برنامه نمونه, كه شماره (1) جهت درست كردن ديسكت قفل و شماره (2) جهت تست آن طراحي شده, آورده شده است:
    در اين برنامه ها از تراك 81 و سكتور 20 ( در حالت عادي هر ديسكت فقط 18 سكتور دارد ) جهت قفل برنامه استفاده شده و به اين صورت عمل مي كند كه يك رشته را از كاربر دريافت كرده و در مكان فوق قرار مي دهد و سپس جهت تست رشته دريافتي در برنامه دوم آنرا با اطلاعات موجود در ديسكت مقايسه مي كند و با دادن پيغام مناسبي آنرا چاپ مي نمايد.
    اين برنامه توسط Turbo Pascal 7.0 كامپايل و اجرا شده اند.



    {
    برنامه شماره(1)
    اين برنامه جهت ساختن ديسكت قفل استفاده مي شود
    }


    program PROGRAM-1;

    Uses Dos;

    TYPE
    DAT = String[40];
    VAR
    C : Registers;
    FP : String[15];
    PU : Array[1..512] of char;
    Data: Dat;
    I : Byte;
    Key : Dat;

    {******************************************}

    Procedure ZUW;
    Begin
    Fp:=#81+#0+#20+#2;
    c.d1 :=0;
    c.dh :=0;
    c.ch:=81;
    c.c1:=20;
    c.a1:=1;
    end;

    Procedure Write-Key(dataat);
    Begin
    c.ah:=5;
    ZUW;
    c.es:=Seg(fp[1]);
    c.bx:=Ofs(fp[1]);
    Intr(19,c);
    c.ah:=5;
    ZUW;
    c.es:=Seg(fp[1]);
    c.bx:=Ofs(fp[1]);
    Intr(19,c);
    For i:=1 to Length(data) do
    Pu:=data;
    Pu[i+1]:=#0;
    c.ah:=3;
    ZUW;
    c.es:=Seg(Pu);
    C.bx:=Ofs(Pu);
    Intr(19.c);
    end;

    {=======================================}

    begin
    Writeln;
    Writeln( Program Number1 );
    Writeln( This Program Used For Create The Key );
    Write( Please Type Key Word : );
    Readln(Key);
    Writeln;
    Write( Writing Key …);
    Write-Key(Key);
    Writeln( OK .);
    Writeln;
    end.


    {



    برنامه شماره (2)
    اين برنامه جهت كنترل ديسكت قفل استفاده مي شود
    }


    program PROGRAM-2;

    Uses Dos;

    Type
    DAT = String[40];

    Var
    C : Registers;
    FP : String[15];
    PU : Array[1 ..512] of char;
    Data: Dat;
    I : Byte;
    Key : Dat;

    {********************************************}

    Procedure ZUW;
    Begin
    Fp:=#81+#0+#20+#2;
    c.d1:=0;
    c.dh:=0;
    c.ch:=81;
    c.c1:=20;
    c.a1:=1;
    end;

    {********************************************}

    Function Read-Key(Keyat):Boolean;
    Begin
    c.ah:=2;
    ZUW;
    c.es:=Seg(pu);
    c.bx:=Ofs(pu);
    Intr(19.c);
    c.ah:=2;
    ZUW;
    c.es:=Seg(pu);
    c.bx:=Ofs(pu);
    Intr(19,c);
    I:=1;
    data:=;
    While pu#0 do
    begin
    Data :=data+pu[];
    Inc(I);
    end;
    If data=Key then
    Read-Key:=True
    Else
    Read-Key:=False;
    end;

    {***********************************************}


    begin
    Writeln;
    Writeln( Program Number2 );
    Writeln( This Program Used For Check The Key );
    Write( Please Type Key Word : );
    Readln(Key);
    Writeln;

    If Read-Key(Key)=False then
    Writeln( I am Sorry , Not Found .);
    Else
    Writeln( Very Good , That Found .);

    Writeln;
    end.




    نويسنده : مهدي معاضدي
    از سايت خبري فن آوري اطلاعات ايران

  7. #277
    حـــــرفـه ای mehdi_7070's Avatar
    تاريخ عضويت
    Aug 2005
    پست ها
    3,232

    پيش فرض

    .:: قفل هاي سخت افزاري و نرم افزاري ::.

    قفل در اصطلاح عاميانه كلامي آشناست و از آن براي حفاظت از اشيا مختلف استفاده مي شود.

    اما مفهوم قفل در دنياي كامپيوتر و عالم نرم افزار، چيست ؟
    امروزه براي جلوگيري از استفاده غيرمجازا ز برنامه ها ويا تكثيرغيرقانوني آنها، اصطلا حا به آنها قفل مي زنند.

    اما اين قفل گذاري چگونه صورت مي گيرد ؟

    قفل گذاري كلا به دو روش نرم افزاري و سخت افزاري انجام مي شود كه ذيلا به تشريح آن مي پردازيم.

    قفل سخت افزاري ( Hardware lock ) چنانچه ازسخت افزارخاصي براي قفل گذاري استفاده شود، به آن قفل سخت افزاري مي گوييم. اين قفلها بعضي به صورت يك رابط، بر روي پورت پارالل سيستم نصب مي شوند كه البته هر دو نوع آن عملكرد مشابه دارند. بخش اصلي قفل، از يك حافظه قابل پاك شدن تشكيل شده كه با توجه به نوع و حجم آن، داراي عملكردي متفاوت مي باشد و عمدتا به يكي از دو روش زير عمل مي كند: الف) روش اول قفل گذاري به اين صورت است كه توليد كننده نرم افزار يك يا چند بايت از اطلاعات را در قفل نوشته و برنامه در هنگام اجرا آن را چك مي كند. در صورتيكه قفل وجود داشته باشد، برنامه به كار خود ادامه مي دهد و اگر قفل وجود نداشته باشد و يا اطلاعات خوانده شده از روي قفل صحيح نباشد، برنامه متوقف شده و با اعلام خطا، از اجراي صحيح، سرباز مي زند. اين نوع قفل ها داراي ساختاري ساده، حافظه اي در حد چند بايت، و قيمتي ارزان هستند. استفاده از اين قفل ها بسيار ساده بوده و نياز به تخصص خاصي ندارد،تنها كافيست كه نرم افزار ويژه قفل را ( كه توسط شركت توليد كننده قفل ارائه شده ) اجرا نمود. در ابتدا كه قفل فاقد اطلاعات است، اول يك كلمه دلخواه، به عنوان كلمه عبور درخواست كرده و سپس با توجه به نوع قفل، يك يا چند كلمه اطلاعات را دريافت و در حافظه قفل ثبت كنيد. در دفعات بعد مي بايست كلمه عبوري كه اولين بار ثبت شده، وارد شود تا بتوان به اطلاعات دروني قفل دسترسي داشت. البته بعد از ورود به برنامه اين كلمه قابل تغيير است. در هر صورت، پس از ثبت اطلاعات در قفل، توليد كننده نرم افزار، اطلاعات ثبت شده در يك برنلمه چك مي كند كه نحوه چك كردن اطلاعات، با توجه به نوع قفل متفاوت است. در بعضي فقط اطلاعات درون قفل چك مي شود و در بعضي ديگر، در مرحله اول وجود قفل چك شده و در مرحله بعدي، اطلاعات درون آن چك مي شود. ب) روش ديگر قفل گذاري به اين صورت است كه توليد كننده نرم افزار، بخش كوچكي از برنامه را در حافظه قفل قرار مي دهد كه در اين حالت، چنانچه قفل وجود نداشته باشد برنامه به هيچ وجه، قادر به اجرا و ادامه كار نخواهد بود. اين نوع قفل ها، داراي ساختاري كمي پيچيده، حافظه اي بعضا تا چند كيلو بايت، و قيمتي نسبتَََا گران هستند. استفاده از اين قفل ها، به سادگي نوع قبلي نيست. البته نحوه كلي كار مشابه روش قبلي است. با اجراي نرم افزار ويژه قفل و وارد نمودن كلمه عبور، بايد نام فايلي را كه مي خواهيم بر روي آن قفل بزنيم، مشخص كنيم، تا بخشي از آن در قفل ثبت گردد. البته در بعضي ديگر از اين نوع قفل ها، كه حفاظت بيشتري را انجام مي دهند، مي بايست توسط توليد كننده نرم افزار دقيقا كنترل شود كه چه بخش هايي از فايل بايد در قفل ثبت گردد كه ابته انجام اين كار نياز به تخصص و تجربه كافي دارد، چرا كه بعضا ممكن است كه خطا در انجام كار، باعث بروز اشكال در برنامه توليدي بشود. چون با اين كار در واقع بخشي از برنامه در قفل ثبت مي گردد، واضح است كه هر قفل فقط براي يك نسخه از برنامه مي تواند مورد استفاده قرار بگيرد و به همين علت كاربرد اين قفل، كمتر است. ضمنا نوع ديگري از قفل ها هستند كه هر دو روش فوق استفاده مي كنند، اما طرفدار چنداني ندارند. قفل نرم افزاري (Software Lock) چنانچه از روش ها و ترفند هاي نرم افزاري، براي قفل گذاري استفاده شود، به آن قفل نرم افزاري مي گوييم. قفل هاي نرم افزاري داراي تنوع بيشتري بوده و بعضا از لحاظ طراحي و اجرا سليقه اي و ابتكاري مي با شند. اما مي توان نحوه عملكرد اكثر آنها را، توسط يكي از 3 روش ذيل، تشريح نمود: الف) محدوديت در تعداد كپي(Copy Limited) در اين حالت برنامه نصب كننده نرم افزار، فضاي مشخصي در ديسك را با روش خاصي مرمت كرده، و تعداد مجاز نسخه برداري را در آن درج مي كند. بدين طريق با هر بار كپي كردن برنامه، يك واحد از اين عدد كم مي شود و هنگامي كه تعداد مجاز آن به صفر رسيد، ديگر نمي توان برنامه را بر روي سيستم نصب نمود. حال ممكن است اين سوال مطرح شود كه مگر نمي توان پس از نصب برنامه، از آن پشتيباني(Back Up) گرفته و سپس از نسخه پشتيبان نيز، بر روي سيستم ديگري استفاده نمود؟ پاسخ منفي است. زيرا هنگام نصب، اطلاعاتي راجع به سخت افزار سيستم كه مي تواند مثلا شامل نوع قطعات و يا شماره سريال قطعات باشد، در جايي، در محدوده قفل ذخيره مي شود و از اين پس هر بار در هنگام اجراي برنامه، اين اطلاعات به دقت چك مي شود و در صورت هرگونه تغيير، برنامه اجرا نمي شود. ب) استفاده از ديسكت، در هنگام اجراي برنامه (Disk Required) در اين حالت، ديسكت مورد نظر، يا به روش خاصي فرمت مي شود و سپس در هنگام اجرا، اطلاعات روي آن بررسي مي شود، و يا اينكه قسمتي از ديسكت را بصورت فيزيكي و عمدي خراب مي كنند و در اينجا، در واقع همان صدمه اي كه به عمد، بر سطح ديسكت وارد شده است، به عنوان قفل و محافظ نرم افزار عمل مي كند. از اين پس براي انتقال برنامه از يك سيستم به سيستم ديگر، اين فلاپي مانند قفل سخت افزاري عمل مي كند و مي بايست مختصات آن توسط برنامه تاييد شود و چنانچه اين فلاپي در درايو نباشد، برنامه اجرا نخواهد شد. قفل سي دي (اجرا از روي سي دي) با متداول شدن سي دي ويا لوح فشرده، روش جديدي در قفل گذاري ابداع شد و آن اجراي برنامه از روي سي دي است. در اين حالت برنامه هنگام اجرا، به سي دي رجوع كرده و نقاط خاصي از آن را چك مي كند. اين نقاط بخش هايي هستند كه به صورت فيزيكي علامت گذاري شده اند ودر واقع به نوعي صدمه ديده اند و معمولا اين خرابي با تابش اشعه ليزر انجام مي شود. به اين ترتيب به اصطلاح نقاط معيني از سي دي ليزرسوز مي شود. اين نقطه يا نقاط، به عنوان قفل سي دي عمل مي كند و از عمل تكثير يا كپي برداري و همچنين استفاده غير مجاز از آن جلوگيري به عمل مي آورد. در خاتمه سوالي كه در مورد سه روش فوق الذكر مطرح است، اين است كه آيا مي توان قبل از نصب، از ديسكت ها و سيدي هاي قفل گذاري شده كپي تهيه كرد و سپس آنها را نصب كرد؟ پاسخ منفي است، زيرا همانگونه كه اشاره شد، يا بخشي از ديسكت و يا تمامي ان، به روش خاصي فرمت مي شود كه قابل كپي برداري نيست و يا اينكه محل ونقاطي كه بر روي ديسكت و يا سي دي، به صورت فيزيكي و عمدي صدمه ديده اند، اجازه كپي برداري را نمي دهند و مانع از انجام اين كار مي شوند.

    منبع خبر : سايت فن آوري اطلاعات ايران

  8. #278
    حـــــرفـه ای mehdi_7070's Avatar
    تاريخ عضويت
    Aug 2005
    پست ها
    3,232

    پيش فرض

    خوب اين هم دو تا مقاله توپ ديگه كه از جاي ديگه اي آوردم . منتظر بقيه مقاله ها باشيد .
    +++
    خوب درباره قفل هاي سخت افزاري هم توضيح داديم . ديگه چي مي خواهيد .
    +++
    به اين جا هم سري بزنيد . درباره قفل اكتيو ايكس اين شركت

    [ برای مشاهده لینک ، با نام کاربری خود وارد شوید یا ثبت نام کنید ]

    پست های پشت سر هم ادقام شد
    لطفا به قوانین توجه کنید
    میثم

  9. #279
    حـــــرفـه ای Soda's Avatar
    تاريخ عضويت
    Mar 2005
    محل سكونت
    EB FE
    پست ها
    2,062

    پيش فرض

    مهدي جان از پستات ممنون
    ولي ميتوني از ويرايش پست هم استفاده كني
    البته اگه سليقت بگيره
    ممنون از توجهت

  10. #280
    اگه نباشه جاش خالی می مونه
    تاريخ عضويت
    Aug 2005
    پست ها
    239

    پيش فرض

    سلام مهدي جان بهpmما هم جواب ندادي ها

Thread Information

Users Browsing this Thread

هم اکنون 1 کاربر در حال مشاهده این تاپیک میباشد. (0 کاربر عضو شده و 1 مهمان)

User Tag List

قوانين ايجاد تاپيک در انجمن

  • شما نمی توانید تاپیک ایحاد کنید
  • شما نمی توانید پاسخی ارسال کنید
  • شما نمی توانید فایل پیوست کنید
  • شما نمی توانید پاسخ خود را ویرایش کنید
  •