آخرین اخبار و مقالات و مطالب پیرامون فریم ورک در ایران آی سی تی نیوز ، پایگاه فناوری اطلاعات و ارتباطات ایران
بر روی این دامنه اینترنتی سیستم مدیریت محتوا
پارس سی ام اس
نصب شده است که نرم افزاری قوی جهت طراحی سایت
می باشد. طراحی وب
با استفاده از پرتال
( پورتال
) پارس منجر به طراحی وب سایت
شما می شود. طراحی وب سایت
کپی رایت پورتال
پارس
با وجود کارایی زیاد و انعطاف پذیری بالای زبان برنامه نویسی جاوا، این ابزار قدرتمند و رو به توسعه هنوز نتوانسته جایگاه مناسبی برای پیاده سازی پروژه های تجاری در مقایسه با سایر framework های موجود بیابد. از جمله دلایل اصلی عدم استفاده از جاوا در بیشتر پروژه های بزرگ تجاری، می توان به مشکل بازگشت پذیری یا decompile شدن کدهای نوشته شده، با این زبان برنامه نویسی اشاره کرد که این خود به تنهایی یک معضل بزرگ امنیتی در مسیر توسعه نرم افزارهای تجاری با استفاده از این ابزار به شمار می آید.
برنامه های نوشته شده در جاوا به دلیل استفاده از واسط زمان اجرای java runtime environment یا به طور اختصار jre برای مهیا کردن بستری مناسب برای جلوگیری از کامپایل مجدد کد منبع و همچنین حفظ قابلیت جابه جایی و استفاده در پلتفرم های مختلف، پس از کامپایل به جای تبدیل شدن به زبان ماشین یا همان «صفر» و «یک» به قالب خاصی از داده ها به نام byte code تبدیل می شود که این خروجی همان قالب قابل فهم و اجرا برای jre است.
همین موضوع باعث می شود کد برنامه های نوشته شده به زبان جاوا را با استفاده از متدهای مهندسی معکوس تا حدود زیادی بازیابی کرد. این مشکل به حدی جدی است که شرکت توسعه دهنده زبان جاوا یعنی سان میکروسیستمز، اقدام به ارائه ابزاری به نام obfuscator برای مبهم سازی کد منبع نوشته شده از طریق تزریق کدهای اضافی به زبان جاوا کرده تا پس از انجام عملیات دیکامپایل، کاربران نتوانند به راحتی قطعات مختلف کد حاصل را درک و تفسیر کنند.
اجرای این برنامه به گونه ای است که در بدنه توابع و کلاس ها در نتیجه نهایی و خروجی اصلی برنامه تغییری را در پی نخواهد داشت. البته استفاده از این متد که به صورت توکار (یا درون ساخت built-in) هم در کتابخانه های جاوا و هم توسط ide پیش فرض شرکت سان، یعنی netbeans نیز پشتیبانی می شود، نمی تواند تمام آنچه که برنامه نویسان برای ایجاد امنیت بیشتر به آن نیاز دارند را تامین کند. گذشته از این، استفاده از روش مذکور سبب افزایش حجم فایل اجرایی پس از کامپایل، کندی در بارگذاری و اجرای برنامه، سخت تر شدن انجام عملیات اشکال زدایی (دیباگ)، بالا بردن میزان استفاده از حافظه اصلی و تحمیل بار مضاعف بر دوش پردازنده به دلیل استفاده مکرر از حلقه های تکرار و تصمیم گیری می شود.
در این میان روشی کاملا ابتکاری توسط برخی برنامه نویسان برای هر چه بالاتر بردن ضریب امنیت در کدهای جاوا یا حتی دیگر زبان های برنامه نویسی که از یک قالب همسان با فریم ورک جاوا بهره می برند، ارائه شده است. این روش که به متد رمزگذاری (encryption) معروف است، هم اکنون به عنوان یکی از بهترین و موثرترین راه حل های مطرح شده برای حفاظت از کدهای جاوا شناخته می شود. تفاوت عمده این روش با دیگر متدها در این است که روش رمزگذاری از آغاز تا پایان باید توسط برنامه نویس و گروه توسعه دهنده پروژه پیاده سازی شود؛ برخلاف روش obfuscator که برای مبهم کردن کد منبع از الگوهای محدود و تکراری استفاده می کند.
شاید این موضوع در نگاه اول کمی دشوار به نظر برسد اما کارایی واقعی روش رمزگذاری به این موضوع وابسته است که منطق رمزنگاری در برنامه شما می تواند کاملا متفاوت با تصور دیگران یا به عبارت دیگر کاملا ابتکاری و شخصی باشد.
رفتار متد رمزگذاری
در این روش فرض بر این است که تمام یا تعدادی از کلاس های نوشته شده، به جز کلاس اصلی پروژه و کلاسی که قرار است عملیات کدبرداری دیگر کلاس ها را انجام دهد، با استفاده از یک برنامه واسط و یک کلید اصلی به مجموعه ای از کاراکترهای غیرقابل فهم و نامفهوم تبدیل شده است. سپس کلاس های کدشده در مسیر مناسب به پروژه افزوده می شوند.
کلاس اصلی پروژه باید بتواند با استفاده از توابعی که برای رمز گشایی کلاس های کدشده توسط برنامه نویس طراحی شده اند، کلاس های مذکور را در حافظه دیکد و بازسازی کند تا در محل و زمان مناسب فراخوانی و استفاده شوند. به این ترتیب حتی بعد از دیکامپایل شدن برنامه نیز کاربران با انبوهی از کلاس های رمزگذاری شده و کاراکترهای غیرقابل فهم روبه رو خواهند شد.
نحوه پیاده سازی
پیش از هر چیز باید گفت که بهترین حالت ممکن برای پیاده سازی روش رمزگذاری، زمانی است که تمام برنامه نویسی های مربوط به کلاس ها و متدهایشان به صورت کامل انجام شده و پروژه آماده کامپایل شدن نهایی باشد. همان طور که پیشتر نیز گفته شد، برای پیاده سازی این متد ما نیاز به یک برنامه واسط برای رمزنگاری کلاس های مورد نظرمان با استفاده از یک کلید اصلی و بر اساس الگویی که برنامه نویس مشخص کرده است داریم. برای نمونه، برنامه ساده ای بنویسید که تمام کاراکترهای یک فایل از نوع کلاس جاوا را به عنوان ورودی دریافت کرده و با یک مقدار به عنوان کلید اصلی xor کند. سپس باید کلاس یا تابع مستقلی برای کدبرداری کلاس های رمزگذاری شده با استفاده از همان کلید اصلی نوشته شود تا در هنگام اجرای برنامه بتوانیم با فراخوانی آن، کلاس های کد شده را در حافظه رمزگشایی و دوباره سازی کنیم و سرانجام برنامه بدون هیچ مشکلی بتواند اجرا شود. توجه داشته باشید که کلید اصلی به عنوان یک عنصر حیاتی برای حفظ امنیت و حتی ضامن اجرای صحیح برنامه، می تواند برای هر کلاس به صورت متفاوت تولید شود یا از مجموعه چند عملیات پیچیده ریاضی روی مقادیر گوناگون به دست آمده باشد، یا حتی روی یک قفل سخت افزاری ذخیره شود تا برنامه بدون وجود آن اصلا اجرا هم نشود.
برای پنهان ماندن الگوریتم کدبرداری کلاس ها نیز می توانید از فایل های کتابخانه ای پویا و استاندارد (برای ویندوز پسوند dll و برای گنولینوکس پسوند so) نوشته شده با زبان c استفاده کنید. البته در این حالت پیاده سازی الگوریتم رمزگشایی باید در همین کتابخانه ها انجام شود و همین طور برای حفظ قابلیت اجرا و انتقال روی سایر پلتفرم ها نیز باید کتابخانه های مورد نیاز و قابل استفاده روی سایر پلتفرم ها را هم ایجاد کرده و همراه با دیگر منابع به پروژه بیفزایید تا بتوانید با توجه به نوع سیستم عامل، فایل کتابخانه مورد نظر را بارگذاری کرده و توابع مورد نیاز برای رمزگشایی را از داخل این فایل ها فراخوانی کنید.
نتیجه گیری
روش یا متد رمزگذاری راه حل مناسبی برای حفظ امنیت کد برنامه های نوشته شده به زبان جاواست که بر خلاف دیگر روش های معمول در روند عادی اجرای برنامه خللی وارد نمی کند و در صورتی که به درستی پیاده سازی شود حتی می توان با اتکا به آن از فریم ورک جاوا، بدون ترس از دیکامپایل شدن برنامه در پروژه های تجاری بزرگ و مستقل از سکو نیز استفاده کرد و با خیال راحت از مواهب بسیار زیاد جاوا برخوردار شد.
منابع
http://java.sun.com
http://www.javaworld.com
http://www.devarticles.com
محمد جواد احمدی
... وردپرس همچنین با حذف فریم ورک qt، از هر دو سیستم عامل s60 و maemo نیز پشتیبانی می کند؛ در حالی که نوکیا پشتیبانی از s60 را متوقف اما پشتیبانی برای maemo را تضمین کرده است ...
... وردپرس همچنین با حذف فریم ورک qt، از هر دو سیستم عامل s60 و maemo نیز پشتیبانی می کند در حالی که نوکیا پشتیبانی از s60 را متوقف اما پشتیبانی برای maemo را تضمین کرده است ...
... - طراحی مستقل از طراحی فیزیکی و ملاحظات فنی (abstract design): طراحی معماری اطلاعات و تعاملات، اهداف استراتژیک را به یک فریم ورک مفهومی در جهت استفاده کاربر ترجمه می نماید ...
... از این رو آن ها به فریم ورک (frame work) روی آوردند ... فریم ورک ها ، محیط های هستند که به برنامه نویسان اجازه می دهد با کمترین معلومات، بیش ترین استفاده و بهره را از یک زبان خاص ببرند! این محیط ها بیشتر برای زبان هایی طراحی شده اند که نوشتن آن ها سخت تر است و برنامه نویسان برای یک کار جزئی، باید کدهای زیادی را بنویسند ... یکی از فریم ورک های ارائه شده برای جاوا اسکریپت، فریم ورک prototype است ... این فریم ورک آزاد قابلیت های متنوعی از جمله: ارسال و دریافت، مخفی و نشان دادن قسمتی خاص و به روز رسانی لحظه ای را داراست ... نکته دیگری که طراحان وب، در مورد همه فریم ورک ها دقت می کنند، پشتیبانی مرورگرها از آن است ... 5 , کروم 1 , سافاری2 ، اینترنت اکسپلولر 6 و نسخه های بالاترشان همگی از این فریم ورک قوی پشتیبانی می کنند ... در این مبحث ما شاهد این امر هستیم که این فریم ورک با پیوندی ساده، می تواند محتوایات یک فرم html را به مقصد بانک اطلاعاتی برساند بدون این که کاربر خود وارد صفحه ی پویایی شود ... همانطور که اشاره شد، ارسال و دریافت داده ها بدون اتصال مستقیم به صفحات پویا دیگر، از مزایای آژاکس و مخصوصا فریم ورک های آن است که در این میان پروتوتایپ یکی از بهترین فریم ورک ها نسبت به jquery می باشد ... دلیل این قیاس هم آن است که اولا حجم نسبی این فریم ورک کم است و هم استفاده مبتدیان از آن راحت تر است ...
... فریم ورک های جاوااسکریپت، دیگر امروز پدیده نو و جدیدی نیستند و رقابت بر سر کیفیت، سرعت و امکانات این فریم ورک ها تنگاتنگ شده است ... حضور یک فریم ورک جدید که مطرح باشد، به اندازه کافی دشوار می نمایاند، حتی تولیدکنندگان فریم ورک swell نیز همین اعتقاد را دارند ... این فریم ورک جدید که در اصل یک مدیر drag & drop است، برخلاف کتابخانه های جاوااسکریپت فعلی چون jquery ، yui ، mootools ، scriptaculous از شیوه جدیدتری برای مدیریت drag & drop استفاده می کند ... از ویژگی ها و برتری های این فریم ورک می توان به موارد زیر اشاره کرد: دقت و بازدهی، حقه های مرتبط با حرکت ماوس و تشخیص یک عنصر زیر نشانگر آن و شناسایی المان مقصد متعلق به گذشته است، این فریم ورک واقعا سریع است ... اما این فریم ورک ایرادات خاص خود را دارد که از میان آنها می توان به عدم تطابق با مرورگرهای مختلف اشاره کرد ... البته وضعیت کشیدن و انداختن در این مرورگر هنوز در مراحل اولیه قرار دارد و رسما عرضه نشده است اما هدف از ارائه این فریم ورک، ایجاد بستری است که بشود یک راه واحد برای پشتیبانی از کشیدن و انداختن در مرورگرهای تحت وب ایجاد کرد و در مرورگرهایی که از نظر فناوری عقب افتاده تر هستند هم اجرا شود ...
... py و همین بود! از این به بعد می توانید هر فریم ورک را به طور جداگانه بررسی کنید ...
... این تولید به کمک استفاده از جنریک ها7، فریم ها8، کلاس ها، الگوها9 و دیدگاه ها10 انجام می شود و باعث بالارفتن میزان بهره وری می گردد ... mygeneration تولیدکننده کد برمبنای الگوهاست که برای دات نت فریم ورک مایکروسافت نوشته اند ...
... میگوئل د ایسازا3، معاون ارشد ناول و خالق فریم ورک مونو اعلام کرده است که در نسخه جدید مونو تمرکز اصلی بر روی بهبود بازدهی بوده است ...
... همه چیز از آنجا شروع شد که زبان برنامه نویسی ruby دارای فریم ورکی شد به نام rails و بهره گیری از یکی مهم ترین معماری های پیاده سازی نرم افزار یعنی معماری mvc ، این دو را به ترکیبی سریع، قابل اطمینان و محکم برای توسعه نرم افزارهای وب تبدیل کرد ... php انعطاف زیادی برای استفاده در برنامه نویسی سطح وب می دهد، اما نبود یک فریم ورک مطمئن و قابل انعطاف که بتوان به جای تمرکز در مسایل پیش پا افتاده، روی برنامه تمرکز کرد در این زبان به چشم می خورد ... چندین فریم ورک در همان زمان ها تقریبا شروع به کار کردند، که cakephp به همراه symfony از دو فریم ورک مشهور php به شمار می روند ...
|
صفحه 1
|
2 | 3 | 4 |
|