امروزه اینترنت فراگیرترین رسانه اجتماعی است که انواع و اقسام سرورها، مرورگرها، سیستم ها و نرم افزار ها به وسیله آن با هم در ارتباط بوده و اطلاعات خود را رد و بدل می کنند .
یک وب سایت یا نرم افزار تحت وب، بر روی هر سیستمی که دارای یک مرورگر باشد، فارغ از نوع سیستم عامل یا سخت افزار آن قابل اجراست.
برای مثال وقتی به وب سایت بانک خود سر می زنید، مهم نیست از یک مرورگر روی ویندوز استفاده می کنید یا مرورگر safari روی دستگاه آیپدتان. هر دو مرورگر، وب سایت بانک را یکسان باز کرده و می توانید عملیات مشابه انجام دهید. دلیل آن هم، نوشته شدن برنامه براساس استاندارد مرورگرهاست.
اما زمانی که دو سیستم عامل متفاوت بخواهند با هم اطلاعات رد و بدل نمایند ، چه باید کرد؟
فرض کنید شما نرم افزاری را بر روی ویندوز سرور اجرا کرده و می خواهید نتیجه آن را به همان نرم افزار، ولی بر روی یک سرور لینوکس ارسال کنید. در اینجا با مشکل تداخل و عدم هماهنگی بین سیستم ها مواجه خواهیم شد .
راه حل چیست ؟
راه حل استفاده از Web Service ها است. Web Service ها، اطلاعات را برای ارسال، به زبان XML کد کرده و سپس در مقصد نیز اطلاعات را بر حسب همان زبان رمزگشایی و ترجمه می کنند.
به عبارت دیگر، از XML به عنوان یک زبان محاوره ای مشترک بین انواع سیستم ها استفاده می شود. حال برای ارسال و دریافت اطلاعات بین انواع سرور ها مشکلی وجود ندارد .
خاصیت مهم Web Service ها، این است که شما می توانید نرم افزار و یا اطلاعات مورد نظر خود را به وسیله آنها، بدون دغدغه خاصی برای اجرای صحیح در مقصد، بر روی وب منتشر سازید .
به طور کلی Web Service ها ، دو استفاده کلی دارند:
اجزایی از نرم افزارها که مرتب مورد استفاده قرار می گیرند :
برخی اطلاعات هستند که نرم افزارها به صورت مرتب به آنها نیاز دارند. با استفاده از Web Service ها، به جای تولید هرباره آنها، فقط یکبار تولید شده و در اختیار همگان قرار می گیرد. برای مثال ، اطلاعات آب و هوا یا قیمت های ارز و غیره.
اتصال نرم افزارهای موجود و انتقال اطلاعات بین آنها :
Web Service مشکل عدم تناسب و ناهمگونی بین سیستم ها را با به کار بردن زبانی مشترک حل کرده است.
به وسیله XML ، می توانید اطلاعات و نرم افزارهای خود را بین هر نوع سیستم عامل و سخت افزار انتقال دهید .
SOAP چیست؟
SOAP پروتکل دسترسی آسان به اشیاء و مخفف عبارت Simple Object Access Protocol می باشد.
این پروتکل برای رد و بدل کردن اطلاعات بین برنامه ها استفاده می شود. اطلاعات در SOAP به صورت پیام (Message) و از طریق پروتکل های موجود در اینترنت مانند HTTP منتقل میشود. به زبان ساده تر، SOAP یک پروتکل برای دستیابی به یک سرویس ارایه شده در وب (Web Service) می باشد. پروتکل SOAP یکی از عمومی ترین استاندارد هایی است که در وب سرویس ها استفاده می شود.
وقتی یک برنامه شروع به ارتباط با وب سرویس می کند، پیغام های SOAP وسیله ای برای ارتباط و انتقال دیتا بین آن دو هستند. یک پیغام SOAP به وب سرویس فرستاده می شود و یک تابع را در آن به اجرا در می آورد، وب سرویس نیز از محتوای پیغام SOAP استفاده کرده و عملیات خود را آغاز می کند و در انتها نیز نتایج را با یک پیغام SOAP دیگر به برنامه اصلی می فرستد.
یکی از مسایلی که در دهه اخیر از اهمیت خاصی برخوردار بوده، چگونگی ارتباط برنامه های تحت اینترنت با یکدیگر می باشد.
برنامه های عادی از RPC) Remote Procedure Call) برای فراخوانی اشیاء DCOM یا CORBA، استفاده میکنند. اما مشکلی که در این نوع فراخوانی ها در بستر اینترنت وجود دارد، مسدود شدن این نوع ترافیکها در Proxy Server ها و دیوارهای آتش (Firewall ها) می باشد.
در صورت استفاده از SOAP با این مشکل روبرو نخواهید بود. SOAP به راحتی شما را قادر خواهد کرد تا بین برنامه هایی که در بسترهای متفاوت طراحی شده اند و در بسترهای متفاوتی در حال سرویس دهی هستند، ارتباط برقرار کنید.
ویژگی های SOAP
- یک پروتکل ارتباطی است.
- برای ارسال پیام استفاده میشود.
- برای محیط اینترنت و شبکه طراحی شده است.
- وابسته به محیط پیاده سازی و اجرا نیست. ( Platform Independent)
- مبتنی بر XML است.
- از دیوارهای آتش (Firewall) گذر میکند ودیوارهای آتش مانع آنها نمی شوند (Block نمیشوند).
ساختار SOAP
پیام ها در SOAP یک فایل XML هستند که از ساختار زیر پیروی میکنند:
- یک بخش ضروری که به آن Envelope (پاکت نامه) گفته میشود که مشخص میکند که این XML یک پیام SOAP است.
- قسمت Header که اختیاری است. این بخش شامل اطلاعاتی در مورد خود برنامه است. در صورتی که از Header استفاده شود، باید اولین عنصر در ساختار Envelope باشد.
- قسمت Body که ضروری است. این بخش شامل Call یا Response است. در واقع مشخص کننده درخواست برنامه سرویس گیرنده یا پاسخ برنامه سرویس دهنده است.
- قسمت Fault یا خطا که اختیاری است. این بخش اطلاعاتی درباره خطاهای بوجود آمده در هنگام پردازش پیام در خود دارد.
معایب SOAP
همانطور که میدانید اولین حرف از حروف تشکیل دهنده SOAP حرف S و اول کلمه Simple است. همین مورد، باعث شده است تا در این سیستم سادگی مقدم بر هرچیز باشد. برای همین در SOAP بسیاری از کاستی ها دیده میشود، که یکی از مهمترین آنها امنیت و قابلیت اعتماد پایین است.
همین کاستی باعث شده است که تولیدکنندگان نرم افزار به این فکر بیفتند تا SOAP را توسعه دهند و استانداردهای جدیدتری با امکانات بیشتری تولید کنند.
استاندارد تولید شده توسط مایکروسافت با نام GXA) Global XML Web Services Architecture) ارائه شد. که یک پیاده سازی از آن WSE) Web Services Enhancements) است. WSE یک ابزار قدرتمند است که شما با استفاده از DotNet Framework و WSE می توانید وب سرویس های امن و قدرتمند بنویسید. به بیان ساده تر WSE ابزار شما برای طراحی و ساخت وب سرویس ها با .NET می باشد. WSE را می توانید از سایت Microsoft بارگیری کرده و نصب کنید.
REST چیست؟
REST يك مدل معماري براي طراحي برنامههاي كاربردي شبكه است كه ترکیبی از چند مدل معماری مبتنی بر شبکه ميباشد و محدودیتهايی جهت تعریف يك واسط اتصال یکنواخت براي آن درنظر گرفته شده است.
REST مخفف شدهی عبارت Representational State Transfer و به معنای “انتقال بازنمودی حالت” است.
ايده اصلي معماري REST اين است كه به جاي استفاده از مكانيزم هاي پيچيده اي مانند CORBA، RPC يا SOAP براي اتصال ماشين ها ، ازHTTP ساده براي برقراري ارتباط بين ماشينها استفاده شود.
مدل REST شش قيد براي معماری برنامههاي شبكه تعريف ميكند: كلاينت سرور (client-server) باشد. بدون حالت (stateless) باشد. قابليت cache داشته باشد. (cacheable) سيستم لايهبندي شده (layered system) داشته باشد. واسط يكنواخت (uniform interface) داشته باشد. داراي قابليت كد در صورت نياز (code on demand) باشد. (كه اين محدوديت اختياري ميباشد) به سيستمي كه اين قيود را رعايت نمايد، RESTful ميگويند.
از لحاظ رويكرد برنامه نويسي REST جايگزيني ساده براي سرويسهاي وب است. توسعهپذيري در تعاملات ميان اجزا، عموميت واسط ها، توسعه مستقل اجزا و استفاده از واسطه ها از كليدي ترين اهداف معماري REST ميباشد و همچنين استفاده از معماري REST در برنامهنويسي كارايي، سادگي، انعطافپذيري، امكان مشاهده و نظارت، قابليت حمل و قابليت اطمينان را افزايش مي دهد.
امروزه برنامه های سنتی وب در حال حرکت به سمت سرویسی شدن هستند، بدین صورت که کلاینت ها تنها از طریق وب سرویس هایی با سرور در تماس هستند.
به بیانی دیگر ارتباط کلاینت ها با لایه داده برنامه (Data Model) از طریق وب سرویس ها صورت می پذیرد. در چنین برنامه هایی منطق برنامه (logic) کاملا در سمت کلاینت پیاده سازی می شود و سرور دیگر هیچ نقشی جز فراهم کردن داده برای کلاینت هایش را برعهده ندارد. یکی از الگو های طراحی وب سرویس که در سال های اخیر بسیار مورد توجه قرار گرفته است سرویس های REST می باشند.
در سرویس های REST فراهم کردن منابع برای کلاینت ها بسیار مهم است. در واقع تمام هدف REST اینست که این منابع را بگونه ای در اختیار کلاینت ها قرار دهد تا از آنها استفاده کنند، تغییراتی در آنها دهند و یا آنها را حذف کنند.
یکی از نکات مثبت سروریس های REST این است که دسترسی کلاینت ها به این منابع از طریق درخواست های HTTP انجام می گیرد. این درخواست ها با متد های مختلفی می توانند ارسال شوند که هر یک معنا و مفهومی خاصی دارد. این متد ها عبارتند از GET، POST ، PUT، DELETE و … که کاربرد هریک با دیگری متفاوت است.