در سلسله مقالات قبلی ما فصل اول از بخش اول را به پایان بردیم و مبحث آشنایی با CLR و نحوهی اجرای برنامه را یاد گرفتیم. در این سلسله مقالات که مربوط به فصل دوم از بخش اول است، در مورد نحوهی ساخت و توزیع برنامه صحبت میکنیم.
در طی این سالها ویندوز به ناپایداری و پپیچیدگی متهم شده است. صرف نظر از این که ویندوز شایستگی این اتهامات را دارد یاخیر، این اتهامات نتیجهی چند عامل است:
اول از همه برنامهها از dll هایی استفاده میکنند که بسیاری از آنها نوشتهی برنامه نویسانشان نیست و توسط توسعه دهندگان دیگر ارائه شدهاند و توسعه دهندگان مربوطه نمیتوانند صد در صد مطمئن شوند که افراد دیگر، به چه نحوی از dll آنها استفاده میکنند و در عمل ممکن هست باعث دردسرهای زیادی شود که البته این نوع مشکلات عموما از قبل خودشان را نشان نمیدهند، چرا که توسط سازندهی برنامه تست و دیباگ شدهاند.
موقعی کاربرها بیشتر دچار دردسر میگردند که برنامههای خودشان را به روز میکنند و عموما شرکتها در آپدیتها، فایلهای جدید زیادی را روی سیستم کاربر منتقل میکنند که ممکن هست سازگاری با فایلهای قبلی موجود نداشته باشند و از آنجا که همیشه تست این مورد برای توسعه دهنده امکان ندارد، به مشکلاتی بر میخورند و نمیتوانند صد در صد مطمئن باشند که تغییرات جدید باعث تاثیر ناخوشایند نمیشود.
مطمئن هستم شما بسیاری از این مشکلات را دیدهاید که کاربری یک برنامه را نصب میکند و شما متوجه میشوید که یک برنامهی از قبل نصب شده به خاطر آن دچار مشکل میشود و این مورد به DLL hell مشهور هست. این مورد باعث ایجاد ترس و لرز برای کاربر شده تا با دقت بیشتری به نصب برنامهها بپردازد.
دومین مورد مربوط به نصب برنامهها است که متهم به پیچیدگی است. امروزه هر برنامهای که روی سیستم نصب میشود، بر همه جای سیستم تاثیر میگذارد. یک برنامه را نصب میکنید و به هر دایرکتوری تعدادی فایل کپی میشود. تنظیمات ریجستری را آپدیت میکند، یک آیکن روی دسکتاپ و یکی هم start menu یا مترو را اضافه میکند. به این معنی که یک نصب کننده به عنوان یک موجودیت واحد شناخته نمیشود. شما نمیتونید راحت از یک برنامه بکاپ بگیرید. باید فایلهای مختلفش را جمع آوری کنید و تنظیمات ریجیستری را ذخیره کنید. عدم امکان انتقال یک برنامه به یک سیستم دیگر هم وجود دارد که باید مجدد برنامه را نصب کنید و نکتهی نهایی، حذف برنامه که گاهی اوقات حذف کامل نیست و به شکل نامنظم و کثیفی اثراتش را به جا میگذارد.
سومین مورد امنیت هست. موقعی که کاربر برنامهای را نصب میکند انواع فایلها از شرکت و تولید کنندههای مختلف روی سیستم نصب میشوند. گاهی اوقات برنامهها بعضی از فایل هایشان را از روی اینترنت دریافت میکنند و کاربر اصلا متوجه موضوع نمیشود و این فایلها میتوانند هر کاری از حذف فایل از روی سیستم گرفته تا ارسال ایمیل را انجام بدهند که این موارد باعث وحشت کاربرها از نصب یک برنامهی جدید میشود که این مورد را با قرار دادن یک سیستم امنیت داخلی با اجازه و عدم اجازه کاربر میشود تا حدی رفع کرد.
دات نت فریمورک هم این معضل را به طور عادی در زمینهی DLL hellدارد که در فصل آتی حل آن بررسی خواهد شد. ولی بر خلاف COM، نوعهای موجود در دات نت نیازی به ذخیره تنظیمات در ریجستری ندارند؛ ولی متاسفانه لینکهای میانبر هنوز وجود دارند. در زمینه امنیت دات نت شامل یک مدل امنیتی به نام Code Access security میباشد؛ از آنجا که امنیت ویندوز بر اساس هویت کاربر تامین میشود. code access security به برنامههای میزبان مثل sql server اجازه میدهد که مجوز مربوطه را خودشان بدهند تا بدین صورت بر اعمال کامپوننتهای بار شده نظارت داشته باشند که البته این مجوزها در حد معمولی و اندک هست. ولی اگر برنامه خود میزبان که به طور محلی روی سیستم نصب میشوند، باشد دسترسی کاملب به مجوزها را دارد. پس بدین صورت کاربر این اجازه را دارد که بر آن چیزی که روی سیستم نصب یا اجرا میشود، نظارت داشته باشه تا کنترل سیستم به طور کامل در اختیار او باشد.
در قسمت بعدی با نحوه توزیع برنامه آشنا خواهیم شد.
در طی این سالها ویندوز به ناپایداری و پپیچیدگی متهم شده است. صرف نظر از این که ویندوز شایستگی این اتهامات را دارد یاخیر، این اتهامات نتیجهی چند عامل است:
اول از همه برنامهها از dll هایی استفاده میکنند که بسیاری از آنها نوشتهی برنامه نویسانشان نیست و توسط توسعه دهندگان دیگر ارائه شدهاند و توسعه دهندگان مربوطه نمیتوانند صد در صد مطمئن شوند که افراد دیگر، به چه نحوی از dll آنها استفاده میکنند و در عمل ممکن هست باعث دردسرهای زیادی شود که البته این نوع مشکلات عموما از قبل خودشان را نشان نمیدهند، چرا که توسط سازندهی برنامه تست و دیباگ شدهاند.
موقعی کاربرها بیشتر دچار دردسر میگردند که برنامههای خودشان را به روز میکنند و عموما شرکتها در آپدیتها، فایلهای جدید زیادی را روی سیستم کاربر منتقل میکنند که ممکن هست سازگاری با فایلهای قبلی موجود نداشته باشند و از آنجا که همیشه تست این مورد برای توسعه دهنده امکان ندارد، به مشکلاتی بر میخورند و نمیتوانند صد در صد مطمئن باشند که تغییرات جدید باعث تاثیر ناخوشایند نمیشود.
مطمئن هستم شما بسیاری از این مشکلات را دیدهاید که کاربری یک برنامه را نصب میکند و شما متوجه میشوید که یک برنامهی از قبل نصب شده به خاطر آن دچار مشکل میشود و این مورد به DLL hell مشهور هست. این مورد باعث ایجاد ترس و لرز برای کاربر شده تا با دقت بیشتری به نصب برنامهها بپردازد.
دومین مورد مربوط به نصب برنامهها است که متهم به پیچیدگی است. امروزه هر برنامهای که روی سیستم نصب میشود، بر همه جای سیستم تاثیر میگذارد. یک برنامه را نصب میکنید و به هر دایرکتوری تعدادی فایل کپی میشود. تنظیمات ریجستری را آپدیت میکند، یک آیکن روی دسکتاپ و یکی هم start menu یا مترو را اضافه میکند. به این معنی که یک نصب کننده به عنوان یک موجودیت واحد شناخته نمیشود. شما نمیتونید راحت از یک برنامه بکاپ بگیرید. باید فایلهای مختلفش را جمع آوری کنید و تنظیمات ریجیستری را ذخیره کنید. عدم امکان انتقال یک برنامه به یک سیستم دیگر هم وجود دارد که باید مجدد برنامه را نصب کنید و نکتهی نهایی، حذف برنامه که گاهی اوقات حذف کامل نیست و به شکل نامنظم و کثیفی اثراتش را به جا میگذارد.
سومین مورد امنیت هست. موقعی که کاربر برنامهای را نصب میکند انواع فایلها از شرکت و تولید کنندههای مختلف روی سیستم نصب میشوند. گاهی اوقات برنامهها بعضی از فایل هایشان را از روی اینترنت دریافت میکنند و کاربر اصلا متوجه موضوع نمیشود و این فایلها میتوانند هر کاری از حذف فایل از روی سیستم گرفته تا ارسال ایمیل را انجام بدهند که این موارد باعث وحشت کاربرها از نصب یک برنامهی جدید میشود که این مورد را با قرار دادن یک سیستم امنیت داخلی با اجازه و عدم اجازه کاربر میشود تا حدی رفع کرد.
دات نت فریمورک هم این معضل را به طور عادی در زمینهی DLL hellدارد که در فصل آتی حل آن بررسی خواهد شد. ولی بر خلاف COM، نوعهای موجود در دات نت نیازی به ذخیره تنظیمات در ریجستری ندارند؛ ولی متاسفانه لینکهای میانبر هنوز وجود دارند. در زمینه امنیت دات نت شامل یک مدل امنیتی به نام Code Access security میباشد؛ از آنجا که امنیت ویندوز بر اساس هویت کاربر تامین میشود. code access security به برنامههای میزبان مثل sql server اجازه میدهد که مجوز مربوطه را خودشان بدهند تا بدین صورت بر اعمال کامپوننتهای بار شده نظارت داشته باشند که البته این مجوزها در حد معمولی و اندک هست. ولی اگر برنامه خود میزبان که به طور محلی روی سیستم نصب میشوند، باشد دسترسی کاملب به مجوزها را دارد. پس بدین صورت کاربر این اجازه را دارد که بر آن چیزی که روی سیستم نصب یا اجرا میشود، نظارت داشته باشه تا کنترل سیستم به طور کامل در اختیار او باشد.
در قسمت بعدی با نحوه توزیع برنامه آشنا خواهیم شد.