490 likes | 719 Views
بسمه تعالی. نام درس :وب سرویس. وب سرویس چیست؟. یک وب سرویس به معنای ساده نوعی کامپوننت تحت وب است. این کامپوننت به برنامه هایی که از آن استفاده می کنند این امکان را می دهد که بتوانند از متدهای این وب سرویس استفاده کنند.
E N D
بسمه تعالی نام درس :وب سرویس
وب سرویس چیست؟ • یک وب سرویس به معنای ساده نوعی کامپوننت تحت وب است. این کامپوننت به برنامه هایی که از آن استفاده می کنند این امکان را می دهد که بتوانند از متدهای این وب سرویس استفاده کنند. • وب سرویس یک تکنولوژی است که امکان می دهد نرم افزارهای کاربردی، مستقل از نوع سیستم عامل و زبان برنامه نویسی با یکدیگر ارتباط برقرار کنند. • یک وب سرویس، واسطه ای نرم افزاری است که مجموعه ای از عملیات را تعریف می نماید، که می توانند بر روی یک شبکه و از طریق پیام رسانی استاندارد شده XMLمورد دسترسی قرار گیرند. • وب سرویس با استفاده از استانداردی (که بر پایه ی XML است) شرح داده شده است که توصیف سرویس (Service Description) نامیده می شود. این توصیف، شامل تمام جزییات لازم برای تعامل با سرویس، از جمله فرمت های پیام، پروتکل های انتقال و موقعیت آن می باشد.
وب سرویس - مثال • فرض کنید شما می خواهید در web application خود وضعیت آب و هوای مناطق جغرافیایی مختلف را داشته باشید. برای پیاده سازی چنین کاری شما دو راه دارید: 1- خودتان وضعیت اب و هوا را از سایت های مختلف جمع آوری کنید و آنها را در web application خود استفاده کنید. 2- از یک وب سرویس که آب و هوای مناطق جغرافیایی مختلف را می دهد استفاده کنید. • در واقع این وب سرویس آب و هوا به تنهایی کاری نمی کند. بلکه توابعی دارد که توسط web application های مختلف صدا زده می شوند. که بعنوان مثال در اینجا وب سرویس وضعیت آب و هوا را برمی گرداند. • البته وب سرویس ها استفاده های بسیار پرکاربردتر و مهمتری دارند مثل کار با دیتابیس و ... که در اینجا فقط یک مثال برای روشن شدن موضوع ذکر شد.
اما مزیت اصلی استفاده از وب سرویسها • عدم نیاز به کدنویسی مجدد. این کار با کلاس هم امکانپذیر است. اما: 1- در برنامه نویسی با کلاس شما باید کلاستان را در هر پروژه addکنید ولی در وب سرویس فقط کافیست از متدها استفاده کنید. 2- در کار با کلاسها شما ممکن است در applicationهای مختلف به روشهای مختلف با کلاسهای متفاوت کار کنید. یعنی به عبارتی کار شما هر بار متفاوت است و این خوانایی را پایین می آورد و همچنین توسعه را مشکل می سازد. اما در استفاده از وب سرویس شما هربار فقط با یک وب سرویس خاص کار می کنید و طبق همان متدهای خاص وب سرویس کار می کنید حالا در هر کجا و هر applicationکه باشید. 3- وقتی با سرویس کار می کنید یک سری استانداردهایی در استفاده وجود دارد که تمام applicationها باید از آن تبعیت کنند و بنابراین reusability بالا می رود.
نقش :SOAP • Simple Object Access Protocol (SOAP) پروتکل مورد استفاده توسط استفاده کنندگان برای فرستادن درخواست به و دریافت پاسخ از سرویس های وب مبتنی بر XML است. • SAOP یک پروتکل سبک است که روی HTTP ایجاد شده است.البته می توان پیغام های SAOP را از طریق پروتکل های دیگر نیز تبادل کرد، ولی در حال حاضر فقط مرتبط سازی های HTTP برای SOAP تعریف شده اند.این پروتکل مجموعه قواعد مبتنی بر XML برای مشخص کردن اسم متدها، نوع پارامترها و مقادیر برگشتی که استفاده کننده می خواهد روی یک سرویس وب مبتنی بر XML، آنها را فراخوانی کند ، یک Client یک سرویس وب مبتنی بر XML را فراخوانی می کند، باید پارامترها و متد ها را با استفاده از این قواعد مشخص کند.
HTTPچیست • پروتکل HTTP یا Hyper Text Transfer Protocol اصطلاحا به پروتکلی گفته می شود که برای ایجاد ارتباط، دریافت، و ارسال داده ها بین سرور و کلاینت استفاده می شود. • این پروتکل از پروتکل TCP/IP برای بستن پلی میان سرور و کلاینت استفاده می کند. • طریقه کار ارتباط کلاینت با سرور، با استفاده از پروتکل HTTP به این ترتیب است که داده ها، از طریق بسته های اطلاعاتی، بین سرور و کلاینت رد و بدل می شود. به این ترتیب که برای برای ارسال داده ای به سمت مقصد، در ابتدا، داده، به بخش های کوچکتری شکسته می شود و سپس از هر کدام به سمت مقصد و با ترتیب مشخص ارسال می شوند.
نحوه استفاده از وب سرویس • در ابتدا برنامه متقاضی وب سرویس جهت یافتن وب سرویس مورد نیاز خود در UDDI Registery جستجو می کند.و بعد از یافتن سرویس مورد نظرش، چگونگی ارتباط با وب سرویس را از طریق WSDL مربوط به آن وب سرویس بدست می آورد. • در مرحله بعد درخواست SOAP خود را بر اساس مشخصات وب سرویس، که از WSDL بدست آورده، ایجاد کرده و به وب سرویس می فرستد، در نهایت وب سرویس پاسخ خود را بصورت پیغام SOAP برمی گرداند. • همانطور که در شکل نشان داده شده است برای تعریف، جستجو و دسترسی به وب سرویس ها تکنولوژی های استاندارد UDDI ,WSDL ,SOAP وجود دارد که در ادامه در مورد آن ها بحث می کنیم. • - Universal Description, Discovery and Integration • - Simple Object Access Protocol • - Web Service Definition Language
UDDIچیست • UDDI استانداردی است که توسط شرکت های Microsoft وAriba و IBM جهت پیدا کردن وب سرویس ها بر اساس محتوایی که ارائه می کنند در سال 2000 ایجاد شد. • UDDI مانند یک دفترچه تلفن برای وب سرویس ها عمل می کند. شرکت های مختلف می توانند اطلاعات عمومی خود رادر مورد وب سرویس ها در آن ثبت کنند و کاربران می توانند با جستجو در ان سرویس مورد نظر خود را بیابند. • اطلاعات ارائه شده در UDDI شامل سه جزء اصلی است که در شکل زیر نشان داده شده است.
White Pages در آنها اطلاعات تماس شرکت ها و توضيحات متنی آنهاست. برای مثال، محل خدمت بر اساس نام ارائه دهنده. • This category contains: • Basic information about the Company and its business. • Basic contact information including business name, address, contact phone number etc. • A unique identifiers for the company tax IDs. • This information allows others to discover your web service based upon your business identification.
Yellow Pages حاوی اطلاعات طبقه بندی شده شرکتها و اطلاعات درباره توانايی های الکترونيکی آنها می باشد. This category contains: This has more details about the company, and includes descriptions of the kind of electronic capabilities the company can offer to anyone who wants to do business with it. It uses commonly accepted industrial categorization schemes, industry codes, product codes, business identification codes and the like to make it easier for companies to search through the listings and find exactly what they want.
Green Pages( شرح چگونگی دسترسی به وب سرویس) حاوی اطلاعات تکنيکی درباره سرويس های آنها و نحوه پردازش اطلاعات شرکت آنها می باشد.اطلاعات تجاری و سرويس های شرکت ها کاملا ً طبقه بندی شده است و اجازه می دهد که به راحتی در آنها جستجو کرد. سپس متخصصانITمی توانند از اين اطلاعات استفاده کرده و شرکت ها را برای خدمات بهتر به هم متصل کنند. با اين شرطUDDIامکان پياده سازی مدل B2Bرا ايجاد می کند و شرکتها می توانند از سرويس های يکديگر استفاده کنند. • This category contains technical information about a web service. This is what allows someone to bind to a Web service after it's been found. This includes: • The various interfaces • The URL locations • Discovery information and similar data required to find and run the Web service. NOTE: UDDI is not restricted to describing web services based on SOAP. Rather, UDDI can be used to describe any service, from a single web page or email address all the way up to SOAP, CORBA, and Java RMI services.
RMI چیست؟ RMIمخفف عبارت Remote Method invocation به معنی «فراخوانی متد از راه دور »است. RMIمکانیسمی در اختیار برنامه نویسان جاوا قرار می دهد که می توانند از طریق آن متد، اشیای گوناگون را بر روی یک ماشین مجازی (JVM )راه دور اجرا کنند. مکانیسم های فراخوانی راه دور متفاوتی در دنیای نرم افزار ایجاد شده اند،اما RMIبرخلاف بسیاری از آنها محدود به انواع داده ای اولیه یا ساختار هایی متشکل از داده های ساده نیست و به کمک آن می توان اشیای نرم افزاری را به تمامی همانند یک پارامتر عبور داد یا باز گرداند. این ویژگی از RMI یک مکانیسم منحصر به فرد می سازد. چنین خاصیتی به این معنی است که یک برنامه نویس جاوا می تواند به کمک RMI ، کدهای جدیدی را در شبکه انتقال دهد و در ماشین های مجازی راه دور به صورت دینامیک آن ها را اجرا نماید. بدین ترتیب برنامه نویسان جاوا در زمان برنامه نویسی سیستم های توزیع شده،آزادی عمل زیادی به دست خواهند آورد.در یک محیط توزیع شده، کلاینت های RMIمی توانند به نسخه های جدید سرویس های جاوا دسترسی داشته باشند و نیازی به توزیع کردن برنامه به کلاینت ها نخواهد بود. این ویژگی همانطور که در محیط های شبکه محلی اجرا می شود،در محیط وب نیز قابل اجرا است. In order to support code running in a non-JVM context, a CORBA version was later developed.
CORBA((Common object Request Broker Architecture وابسته به يك سكوي نرم افزاری و زبان برنامه نويسي مشخص معين نيست، و به كمك آن مي توان سيستم هاي نرم افزاري گوناگون را در محيط هاي گسترده به يكديگر ارتباط داد. سرويس ها از طريق يك رابط که به زبانIDL (interface Definition Language )نوشته شده است،توصيف مي شوند. CORBA به اشياي نرم افزاري اين امكان را مي دهد كه درخواست هايي به مقصد اشياي نرم افزاري راه دور ارسال كنند و بدين ترتيب متدهاي شي نرم افزاري راه دور را فراخواني نمايند.
روش stub/skeleton A typical implementation model of Java-RMI using stub and skeleton objects. بعضی از پروتکلهایی که از روش stub/skeleton استفاده میکنند: RPC- Remote Procedure Call; CORBA- Common Object Request Broker Architecture; DCE- Distributed Computing Environment; RMI- Remote Method Invocation; و......
WSDLچیست؟ • -2-4زبان تعریف سرویس های وب چیست؟ • بدنه پیغام SOAP ،به فرمت XML است.سرور وب انتظار دارد که Client از یک مجموعه خاص از تگ ها برای رمزنگاری پارامترهای متد استفاده کند. • از طرفی سرویس وب مبتنی بر XML باید بتواند خودش را توصیف کند.برای این کار Client باید با استفاده WSDL که یک query stringاست،یک درخواست به سرویس وب مبتنی بر XML بفرستد: • HTTP://localhost/Northwind Services/ProductService.asmx?WSDL • همانطور که شرح داده شد SOAP زبان ارتباط با وب سرویس ها می باشد. WSDL جزئیات ارتباط و پیام هایی که رد و بدل می شود را توضیح می دهد.
WSDLچیست؟-ادامه • WSDL نیز خود ساختار XML دارد و برنامه ها برای ایجاد پیغام SOAP می بایست در ابتدا به آن رجوع کنند. شکل زیر چگونگی ارتباط با وب سرویس ها را با استفاده از WSDL نشان می دهد.
ساختار وب سرویس معماری وب سرویس برپایه تعامل بین سه نقش قرار دارد: • مهیاکننده سرویس • ثبت کننده سرویس (Service Registry) • درخواست کننده سرویس عملیات شامل انتشار، یافتن و اتصال می باشد. مهیاکننده سرویس، یک توصیفی از سرویس برای وب سرویس ارائه می کند و آن را برای درخواست کننده سرویس یا ثبت کننده سرویس انتشار میدهد. درخواست کننده سرویس، توصیف سرویس را به صورت محلی یا از طریق ثبت کننده سرویس استخراج می کند و از آن توصیف برای تعامل با وب سرویس استفاده می کند.
ارائه دهنده سرویس وب (service Provider) • گره ای در شبکه که مسئولیت میزبان نمودن یک سرویس وب را برعهده خواهد داشت • زیرساخت ایجاد شده توسط ارائه دهنده سرویس ، امکانات لازم حمایتی و میزبان نمودن سرویس های وب رافراهم می نماید. قابلیت پردازش پروتکل HTTPو سرویس اعتبار سنجی ، نمونه هائی از زیر ساخت ارائه شده توسط ارائه دهنده سرویس می باشند. درصورتیکه ارائه دهنده سرویس قادر به ارائه چنین زیرساختی نباشد ، سرویس وب می بایست خود این زیر ساخت را حمایت نماید .وضعیت فوق، طراحی و پیاده سازی سرویس های وب را با مشکل بیشتر مواجه خواهد کرد.
مصرف کننده سرويس(service Requestor) • گره ای در شبکه است که به سرويس ارائه شده توسط يک ارائه دهنده سرويس مرتبط و از امکانات و پتانسيل های سرويس ارائه شده در جهت پياده سازی سيستم خود استفاده می نمايد. مصرف کننده سرويس را می توان بمنزله يک برنامه سرويس گيرنده بر روی يک گره در نظر گرفت .
ثبتکننده سرویس (Service Registry) • ثبت کننده سرویس یک ثبات قابل جستجو برای توصیفات سرویس است و مکانی است که مهیاکنندگان سرویس، توصیفات خود را در آن منتشر میکنند.
تمامی گره های فوق ، قادر به ارتباط با یکدیگر از طریق شبکه های مبتنی بر پروتکل TCP/IP می باشند .
عملیات در معماری وب سرویس عملیات در معماری وب سرویس عبارتند از: انتشار (Publish): برای اینکه سرویسی در دسترس باشد، توصیف آن باید طوری انتشار یابد که درخواست کننده سرویس بتواند آن را پیدا کند. یافتن (Find): در این عملیات، درخواست کننده سرویس، توصیف سرویس مورد نظر را به طور مستقیم و یا از طریق درخواست از ثبت کننده سرویس، استخراج می کند. • اتصال (Bind): در نهایت، از یک سرویس باید استفاده کرد. در این عملیات، درخواست کننده سرویس از طریق جزییات لازم الاجرا در توصیف سرویس، شروع به ارتباط با سرویس می کند .
معماري سرويسگرا و سرويس هاي وب • معمولا واژه هاي معماري سرويس گرا و سرويس هاي وب اشتباها به جاي هم و به صورت معادل استفاده مي شوند لذا لازم است اين دو مفهوم به صورت دقيق تر بررسي شوند. • سرويس هاي وب: • نرم افزارهاي كاربردي كه تحت وب منتشر شده، شناسائي و مورد فراخواني قرار مي گيرند. • مستقل از سكو و زبان هستند. • نوعي از پياده سازي معماري سرويس گرا مي باشند. • با منطق حرفه در تماس هستند ولي هيچ شخصي مستقيما با آنها ارتباط ندارد. • خود شمول هستند. • خود توصيف هستند. • يك رهيافت كليدي براي عينيت بخشيدن به معماري سرويس گرا هستند.
تفاوت وب سرویس با برنامه های تحت وب • سرويس وب بايد داراي شرايط زير باشد: • در سطح وب در دسترس باشد • از استاندارد XML جهت تبادل اطلاعات استفاده كند • به هيچ سكو يا سيستم عاملي وابسته نباشد. • با سرويس هاي تحت وب تعامل دارد و نه كاربران. • خود توصيف باشد • قابل شناسائي باشد(جهت استفاده سرويس گيرندگان ابتدا بايد شناسائي و كشف شود) • در حاليكه نرم افزار تحت وب اين ويژگيها را دارد: • از استاندارد HTML براي تبادل اطلاعات استفاده مي كند. • وابسته به فناوری و سكو ست(ASP،PHP،CGI ، ..) • توسط اشخاص با مرورگر وب مورد استفاده قرار مي گيرد.
برنامه های تحت وب، بسته های نرم افزاری هستند که از طریق مرورگر قابل دسترسی می باشند. نرم افزار و پایگاه داده ی آن به جای نصب در سیستم کاربر، در یک سرور مرکزی قرار دارد و از طریق شبکه می توان به آن دست یافت. تفاوت وب سرویس با برنامه های تحت وب تفاوت بین وب سرویس و نرمافزارهای تحت وب، در جدول زیر آمده است:
مزایا و معایب وب سرویس ها • وب سرویس ها همانند تکنولوژی های دیگر، دارای مزایا و معایبی هستند. از مزایای وب سرویس می توان به موارد زیر اشاره کرد: • قابلیت همکاری: قابلیت همکاری بین برنامه های کاربردی متفاوت که روی سیستم های عامل غیریکسان در حال اجرا می باشند. • یکپارچگی خارجی: تجمع آسان برنامه ها و سرویس ها از شرکت هایی با موقعیت جغرافیایی متفاوت برای ارائه یک سرویس یکپارچه. • استفاده مجدد از کد: شکستن منطق و ایجاد توابع ایستا که می تواند توسط برنامه های کاربردی زیادی فراخوانی شود. • استقلال: کدها می تواند توسط برنامه های کاربردی متفاوتی مورد استفاده قرار گیرد، برای مثال یک وب سرویس که با ASP.NET نوشته شده است، می تواند توسط یک صفحه JSPاستفاده شود
از معایب وب سرویس نیز می توان موارد زیر را نام برد: • در دسترس نبودن: هر کسکهبا اینترنتسروکار دارد می داندکههیچسایتی 100 درصد در دسترس نیست. وب سرویس ها نیز زیرساختی مشابه وب سایت دارند، بنابراین وب سرویس ها هم این مشکل را خواهند داشت. حتی اگر سرور نیز در حال اجرا باشد، ممکن است ISPدر دسترس نباشد. به علت وجود این مشکلات، لازم است مکانیزمی وجود داشته باشد که در صورت وقوع این اتفاق، درخواست را برای بار دوم ارسال نماید. برخی از پروتکل های جدیدی که توسط وب سرویس پشتیبانی می شوند، به صورت خودکار این عمل را انجام می دهند (مانند JMS) ولی اکثریت آن هایی که بر مبنای HTTPمی باشند، از این مکانیزم پشتیبانی نمی کنند.
از معایب وب سرویس نیز می توان موارد زیر را نام برد: (ادامه) • تطبیق نیازمندی ها: زمانی که شما یک سرویس ایجاد می کنید و آن را در دسترس عموم قرار می دهید، می تواند مورد استفاده انواع مشتریان قرار گیرد، ولی این سرویس الزامات خاصی را فراهم می کند. ممکن است بعضی از مشتریان سرویسی را بخواهند که کمی با سرویس شما متفاوت است و فقط مورد نیاز اندکی از مشتریان باشد. وب سرویس یک تکنولوژی از نوع "اندازه ای متناسب برای استفاده حداکثر مشتریان" است. اگر این سرویس جوابگوی نیاز شما نیست، باید راهحل دیگری بیابید.
از معایب وب سرویس نیز می توان موارد زیر را نام برد: (ادامه) • غیرقابل تغییر بودن: اگر شما برای ایجاد یک وب سرویس سرمایه گذاری کنید، باید از هرگونه تغییر در پارامترها و متدهای آن اجتناب کنید. شما می توانید تغییرات را در قالب متدهای جدید به سرویس اضافه کنید، اما اگر تغییری در متدهای سرویس خود بدهید، برنامه های مشتریان را از بین خواهید برد. اگر متوجه شوید که سرویس شما پاسخ اشتباه به کاربران می دهد، شما بازهم چاره ای جز ایجاد یک سرویس جدید ندارید. اشتباهاتی از این قبیل در همه سیستم ها اتفاق می افتد که وب سرویس نیز مانند بقیه سیستم ها از این قاعده مستثنی نخواهد بود. ولی در سایر سیستم ها، یک راه ارتباطی بین ارائه دهنده خدمات و مصرف کنندگان آن وجود دارد که در صورت تغییر، به اطلاع کاربر می رسد.
از معایب وب سرویس نیز می توان موارد زیر را نام برد: (ادامه) • ضمانت اجرا: کل ایده وب سرویس این است که یک برنامه کامپیوتری به جای وارد کردن دستی کدها، به نیازمان پاسخ دهد که این برنامه بدون مراقبت اجرا می شود. HTTPیک پروتکل unreliableاست و هیچ تضمینی از تحویل صحیح داده ها ندارد. اگر شما به این ضمانت نیاز دارید، یا خودتان باید این مکانیزم را به صورت دستی بنویسید که تلاش مجدد را انجام دهد، و یا اینکه از طریق یک واسط (که دارای این ویژگی است) درخواست خود را ارسال نمایید.
اتصالات سست یا loosely coupled يك ويژگي براي سيستم هاي اطلاعاتي است كه در آن واسط هاي بين اجزاء(ماژولها) به گونه اي طراحي مي شوند كه وابستگي بين اين اجزاء حداقل شود و در نتيجه ريسك اثر تغيير يك جزء بر ساير اجزاء كاهش يابد . درمعماري سرويس گرا منظور از اتصال سست قابليت تعامل بين سرويس ها به صورت مستقل از كدنويسي و مكان سرويس ها است، بگونه اي كه سرويس ها در زمان اجرا مي توانند تغيير مكان داده، روالهاي داخلي خود را تغيير دهند يا حتي از يك فناوری جديد تر استفاده كنند، بدون اينكه تاثيري منفي بر سرويس گيرندگان گذاشته شود. چند نكته در تعريف اتصال سست وجود دارد: به وسيله واسط سيستم انجام مي شود ارتباط از طريق ارسال پيام است تمام طرف ها در محيط ارتباطي بايست از يك مدل داده استفاده كنند ارتباط بايستي مستقل از سكو و فناوری پياده سازي هر جزء باشد
مقايسه اي ميان سيستم هاي اتصال سست با اتصال سفت:
discovery layer The discovery layer provides the mechanism for consumers to fetch the descriptions of providers. One of the more widely recognized discovery mechanisms available is project. the Universal Description, Discovery, and Integration (UDDI).
Description layer When a web service is implemented, it must make decisions on every level as to which network, transport, and packaging protocols it will support. A description of that service represents those decisions in such a way that the Service Consumer can contact and use the service. The Web Service Description Language (WSDL) is the de facto standard for providing those descriptions. Other, less popular, approaches include the use of the W3C's Resource Description Framework (RDF) and the DARPA Agent Markup Language (DAML), both of which provide a much richer (but far more complex) capability of describing web services than WSDL.
Packaging layer For application data to be moved around the network by the transport layer, it must be"packaged" in a format that all parties can understand (other terms for this process are"serialization" and "marshalling"). This encompasses the choice of data types understood, the encoding of values, and so on. HTML is a kind of packaging format, but it can be inconvenient to work with because HTML is strongly tied to the presentation of the information rather than its meaning. XML is the basis for most of the present web services packaging formats because it can be used to represent the meaning of the data being transferred, and because XML parsers are now ubiquitous. SOAP is a very common packaging format, built on XML.
transport layer The transport layer includes the various technologies that enable direct application-to-application communication on top of the network layer. Such technologies include protocols like TCP, HTTP, SMTP, and Jabber. The transport layer's primary role is to move data between two or more locations on the network. Web services may be built on top of almost any transport protocol. The choice of transport protocol is based largely on the communication needs of the web service being implemented. HTTP, for example, provides the most ubiquitous firewall support but does not provide support for asynchronous communication. Jabber, on the other hand, while not a standard, does provide good a asynchronous communication channel.
Network layer The network layer in the web services technology stack is exactly the same as the network layer in the TCP/IP Network Model. It provides the critical basic communication, addressing and routing capabilities.
SOAP SOAP's place in the web services technology stack is as a standardized packaging protocol for the messages shared by applications. The specification defines nothing more than a simple XML-based envelopefor the information being transferred, and a set of rules for translating application and platform specific data types into XML representations. SOAP's design makes it suitable for a wide variety of application messaging and integration patterns.
SOAP Messages A SOAP message consists of an envelope containing an optional header and a required body. The header contains blocks of information relevant to how the message is to be processed. This includes routing and delivery settings, authentication or authorization assertions, and transaction contexts. The body contains the actual message to be delivered and processed. Anything that can be expressed in XML syntax can go in the body of a message.
Example. A purchase order in document-style SOAP <s:Envelope xmlns:s="http://www.w3.org/2001/06/soap-envelope"> <s:Header> <m:transaction xmlns:m="soap-transaction" s:mustUnderstand="true"> <transactionID>1234</transactionID> </m:transaction> </s:Header> <s:Body> <n:purchaseOrder xmlns:n="urn:OrderService"> <from><person>Christopher Robin</person> <dept>Accounting</dept></from> <to><person>Pooh Bear</person> <dept>Honey</dept></to> <order><quantity>1</quantity> <item>Pooh Stick</item></order> </n:purchaseOrder> </s:Body> </s:Envelope>
RPC and EDI XML messaging, and therefore SOAP, has two related applications: RPC and EDI. Remote Procedure Call (RPC) is the basis of distributed computing, the way for one program to make a procedure (or function, or method, call it what you will) call on another, passing arguments and receiving return values. Electronic Document Interchange (EDI) is basis of automated business transactions, defining a standardformat and interpretation of financial and commercial documents and messages. If you use SOAP for EDI (known as "document-style" SOAP), then the XML will be a purchase order, tax refund, or similar document. If you use SOAP for RPC (known as "RPC-style" SOAP) then the XML will be a representation of parameter or return values.