دات نت و جايگاه ASP.NET
نگاهی اجمالی به گذشته
در رابطه با رويکرد فوق برخی مسائل اساسی وجود دارد که در ادامه به آنها اشاره می گردد:
• رويکرد فوق کاملا" وابسته به پلات فورم است . اين بدان معنی است که زمانيکه يک برنامه را مثلا" با ويژوال بيسيک می نويسيد ،برنامه فوق صرفا" بر روی کامپيوترهائی که از ويندوز استفاده می نمايند، قابل اجراء خواهد بود.
• هيچگونه تضمينی وجود ندارد که دو برنامه اجرائی نوشته شده با زبانهای برنامه نويسی متفاوت دارای کدهای مشابه سطح پايين باشند. بنابراين اشتراک مجموعه ای از توابع برای زبانهای برنامه نويسی غيرممکن بنظر می رسد. ( مايکروسافت با ارائه تکنولوژی Com سعی در ارائه راهکاری جهت حل مشکل فوق را داشت ولی عملا در مراحل عملياتی با مشکل مواجه گرديد. مثلا" اگر قصد بکارگيری عناصر COM نوشته شده به زبان ويژوال بيسيک را بهمراه عناصر COM نوشته شده به زبان ويژوال C+ + را داشته باشيد در زمان پاس دادن پارامتر بين آنها به مشکلات خاصی برخورد خواهيد کرد.
• کتابخانه Win32 API چيزی بيش از مجموعه وسيعی از توابع نيست . توابع فوق هريک دارای تعاريف اختصاصی خود بهمراه پارامترهای مربوطه می باشند. در برنامه های ويژوال بيسيک و يا C++ به دفعات ممکن است اين نياز احساس گردد که مستقيما" يکی از توابع موجود در Win32 API فراخوانی گردد ، يافتن تابع مورد نظر جهت فراخوانی کار ساده ای بنظر نمی آيد!
بموازات رشد و توسعه نرم افزارها مسئله دوم يکی از اساسی ترين چالش های جدی در زمينه برنامه نويسی گرديد.در حالت ايده آل ما اين انتظار را داريم که هر مجموعه تابع و يا عناصری را که بکمک يک زبان برنامه نويسی نوشته شده اند را بتوان به اشتراک گذاشت و زمينه استفاده از آنان برای ساير زبانهای برنامه نويسی نيز فراهم گردد. مسئله فوق از اين زاويه نگران کننده تر بنظر خواهد آمد که توجه داشته باشيم هر زبان برنامه نويسی ممکن است نوع های داده ئی اوليه مربوط به خود را دارا باشد. مثلا" در ويژوال بيسيک می توان برداری را داشت که که ايندکس باند پايين آن از هر محدوده ای شروع گردد در صورتيکه در C++ اين تاکيد وجود دارد که حتما" می بايست باند پايين با ايندکس صفر آغاز گردد.
دات نت
(Common Language Runtime(CLR
در ابتدای مقاله به نحوه عملکرد کمپايلرهای کلاسيک در رابطه با ترجمه کدهای نوشته شده توسط يکی از زبانهای سطح بالا به دستورات قابل فهم برای کامپيوتر اشاره گرديد . در دات نت فرآيند ترجمه يک برنامه سطح بالا به زبان ماشين بصورت کاملا" محسوس تغيير يافته است . کمپايلرهای سازگار با دات نت کدهای نوشته شده توسط يکی از زبانهای برنامه نويسی را به Win32 API Call ترجمه نخواهند کرد.کمپايلرهای فوق کدهای نوشته شده را به يک زبان ميانه خاص با نام MSIL(Microsoft Intermediate Language) تبديل خواهند کرد. در ادامه CLR کدهای زبان ميانه ای (IL) را اخذ و on the fly آنان را به دستورالعمل های اختصاصی ماشين تبديل خواهند کرد.
توجه داشته باشيد که مرحله CLR به Runing Program صرفا" زمانی اتفاق خواهد افتاد که يک برنامه اجراء گردد. کمپايلر فايلی با محتويات کدهای MSIL را ايجاد خواهد کرد.زمانيکه فايل فوق اجراء می گردد ،کدهای MSIL به سمت CLR روانه شده و در ادامه با استفاده از مترجم JIT(Just-In-Time) کدهای IL به دستورات قابل فهم برای کامپيوتر تبديل خواهند شد. ( يک برنامه در حال اجراء بکمک CLR )
.NET FramWork Classes
برخلاف Win32 API ،کلاس های دات نت در يک سيستم سلسله مراتبی NameSpace سازماندهی شده اند.هر NameSpace می تواند دارای تعداد نامحدودی از کلاس ها باشد. مثلا" NameSpace پايه ای System شامل کلاس هائی است که از آنها برای نوع داده های اوليه نظير : System.Int32, System.Array , System.string و غيره استفاده می شود. NameSpace ،System.Data شامل کلاس ها و ساير Namespace های مربوطه برای دستيابی به داده ها است . NameSpace ،System.IO شامل کلاس های مربوطه برای انجام عمليات متفاوت در رابطه با فايل ها و ورودی و خروجی است . دات نت دارای صدها کلاس بوده که تمامی آنها با استفاده از Namespace ها بدرستی سازماندهی شده اند. طراحان و برنامه نويسان می توانند در صورت نياز اقدام به طراحی کلاس های اختصاصی و NameSpace مربوط به خود نموده و آنها را در برنامه های دات نت خود استفاده نمايند.
دقت داشته باشيد که کلاس های فريمورک دات نت شامل يک کلاس برای هر يک از نوع داده ها در NameSpace ، System می باشد. زبانهای برنامه نويسی دات نت نظير VB.NET,C#,Jscript.NET,� می بايست از اين نوع ها استفاده نمايند . اين بدان معنی است که هر نوع داده بمنزله يک کلاس در نظر گرفته خواهد شد. بنابراين زمانی که عملياتی مطابق زير را انجام می دهيم :
IN VB.NET: Dim i as Integer
IN C# : int i;
IN Jscript.NET : Var i;
در حقيقت يک نمونه از يک کلاس System.Int32 را ايجاد کرده ايم . با توجه به اين امر که هر يک از زبانهای برنامه نويسی از نوع داده های يکسان استفاده و از مجموعه يکسانی از کلاس ها استفاده می نمايند ،ارتباط متقابل بين زبانها ی برنامه نويسی که زمانی بيش از يک آرزو نبود ،ميسر خواهد شد . بدون دليل نيست که CLR را Common Language Runtime ناميده اند. برنامه های نوشته شده توسط هر يک از زبانهای برنامه نويسی در نهايت و پس از ترجمه توسط کمپايلرهائی که دات نت را حمايت می نمايند ، به کدهای MSIL تبديل خواهند شد ،بدين ترتيب اين اطمينان و تضمين بوجود خواهد آمد که تا اين مرحله ( مرحله ترجمه کدهای نوشته شده با يک زبان برنامه نويسی و ترجمه آنها به MSIL ) تمامی زبانهای برنامه نويسی از نوع داده ها و کلاس های موجود در فريمورک دات نت استفاده کرده اند.
حل مشکلات سه گانه
مشکل اول در مرحله تئوری نمی تواند باعث بروز مسائلی گردد . در تئوری مايکروسافت می تواند CLR و کلاس های فريمورک دات نت را برای هر نوع پلات فورم و سيستم عامل ارائه نمايد.اين بدان معنی است که کدهای MSIL توليده شده توسط VB.NET را می توان بر روی لينوکس نيز اجراء نمود. در دنيای واقعي مايکروسافت تاکنون در زميته تامين خواسته هائی اينچنين فعاليت های خاصی را انجام نداده است .
در رابطه با مشکل دوم ( ارتباط متقابل بين زبانها ) با ارائه نوع های داده ئی و توابع مورد نظر که در سطح سيستم عامل فعاليت می نمايند ،با مسئله فوق بدرستی برخورد و راهکار مناسبی ارائه شده است . بر اساس راهکار فوق ،تمامی زبانهای برنامه نويسی مورد حمايت در دات نت می بايست از کلاس های فريمورک دات نت استفاده نموده و پس از ترجمه اوليه کدهای MSIL را توليد نمايند.
در رابطه با مشکل سوم ( ساختار آشفته Win32 API ) فريمورک دات نت ،تمامی کلاس ها را در يک ساختار سلسله مراتبی سازماندهی نموده و از اين طريق دستيابی ،استفاده و شناخت عملکرد هر يک از آنان بمراتب راحت تر از win32 API انجام خواهد شد.
جايگاه ASP.NET در دات نت
زمانيکه يک صفحه ASP.NET بکمک يک مرورگر مشاهده می گردد ، در ابتدا ASP.NET engine بررسی خواهد کرد که آيا آخرين نسخه بهنگام سازی شده از کدهای IL برای صفحه ASP.NET وجود دارد؟ در صورتيکه اين نسخه وجود داشته باشد ،کدهای IL روانه CLR شده و خروجی HTML توليده شده توسط صفحه ASP.NET برای مرورگر سرويس گيرنده ارسال خواهد شد. در صورتيکه کدهای IL موجود نبوده و يا صفحه اوليه ASP.NET از زمانيکه کدهای IL آن توليد شده اند ،تغيير کرده باشد ،صفحه ASP.NET می بايست مجددا" ترجمه گردد. در چنين حالتی با توجه به زبانی که برای نوشتن کدهای صفحه ASP.NET استفاده شده است ،کمپايلر مربوطه فعال و کدهای IL توليد خواهند شد. کدهای IL فوق بر روی ديسک ذخيره تا مورد استفاده در آينده قرار گيرند.
در صورتيکه تاکنون صفحات ASP.NET را ايجاد کرده باشيد ،به نقش بسيار مهم کنترل های وب واقف شده ايد. از کنترل های فوق می توان بهمراه صفحات ASP.NET برای ايجاد عناصر HTML نظير : Text Box,Labels,ListBoxes,� استفاده نمود. مثلا" برای ايجاد يک TextBox بکمک يک کنترل وب می توان از عبارتی مطابق زير استفاده نمود :
<asp:textbox id="name" runat="server" />
در حقيقت صفحه ASP.NET می تواند شامل ترکيبی از کدهای Server-Side ( محصور شده در بلاک Script ) و in-line HTML باشد.
يک نمونه صفحه ASP.NET |
<script language="VB" runat="Server"> |
چگونه کدهای Server-Side و HTML موجود در يک صفحه ASP.NET ترجمه شده تا کمپايلر VB.NET قادر به شناخت آنان باشد؟. يکی از مهمترين عملياتی که توسط ASP.NET engine می بايست انجام گيرد ،ترجمه کدهای HTML/Server-Side به کلاسی است که کمپايلر VB.NET ( و يا ساير کمپايلرهای Jscript.NET,C#) قار به تشخيص آنان باشند.پردازش فوق پيچيده بوده و از حوصله اين مقاله خارج است . کافی است به اين نکته اشاره گردد که صفحات به کلاسی تبديل خواهند شد که خصوصيات خود را از کلاس page ( يکی از کلاس های فريمورک دات نت ) به ارث خواهند برد.در حقيقت تمامی کنترل های وب که در صفحات ASP.NET استفاده می گردند ،بصورت کلاس هائی در فريمورک دات نت در نظر گرفته خواهند شد. در اين راستا تمامی کدهای Html که بصورت موردی در صفحات ASP.NET استفاده می گردنند ،بعنوان نمونه هائی از کلاس LiteralText در نظر گرفته خواهند شد.
اولين نسخه ASP.NET در ماه جولای سال 2001 عرضه گرديده است . (Beta Version) با استفاده از ASP.NET می توان کارهای بزرگ و شگفت انگيزی را انجام داد که اگر قصد انجام آنها را به کمک ASP کلاسيک داشتيم ، می بايست صدها خط برنامه شامل کدهای آشفته ( غيرساختيافته ) را نوشت .