Search
Generic filters

اینستاگرام رامان صفر و یک
طراحی و پیاده سازی انواع وب سایت و سیستم های تحت وب

آخرین مقالات

محصولات

برچسب ها

برچسب‌ها

ASP.NET backend frontend php PHP و ASP.NET PHP یا ASP.NET استراتژی طراحی وب سایت استفاده از کتابخانه PdfView اسلایدر افقی در اندروید اسلایدر افقی در برنامه نویسی اندروید الگوی معماری MVC برنامه نویس حرفه ای وب برنامه نویسی برنامه نویسی وب تجربه کاربر (UX) توسعه دهنده وب توسعه دهندگان وب توسعه وب حل مشکل اتصال به دیتابیس آنلاین در اندروید 8 به بالا داشتن نرم افزار های موفق درآمد برنامه نویسی دریافت نکردن اطلاعات از سمت سرور در اندروید رسم نمودار در برنامه نویسی اندروید رسم نمودار در برنامه نویسی اندروید با کتابخانه MPAndroidChart روش ایجاد اسلایدر افقی در برنامه نویسی اندرود سمت سرور سمت کلاینت شروع برنامه نویسی موبایل طراح UI طراح UX طراحی UX و UI طراحی UX یا UI طراحی استراتژیک وب طراحی رابط کاربر (UI) طراحی وب طراحی وب سایت عدم اتصال به دامنه های http در اندروید فروش موفق نرم افزار مدل کلاینت-سرور موفقیت در دنیای نرم افزار نشان دادن فایل های pdf در برنامه نویسی اندروید نمایش pdf در موبایل چکونه برنامه نویسی موبایل را شروع کنیم ؟ کتابخانه PdfView گرفتن اطلاعات گوشی اندرویدی در برنامه نویسی

سلام و عرض ادب خدمت همه شما رامان صفر و یکی های عزیز :
در این نوشتار قصد داریم بررسی کنیم ” api چیست ؟ ”
برای افرادی که با توسعه نرم‌افزار آشنایی ندارند، API مفهومی گنگ محسوب می‌شود.
اما وقتی وارد این حوزه شدید، API به یکی از ابزارهای کاملاً روزمره شما تبدیل می‌شود.
در هر حال بسیاری از کسانی که در حوزه‌های مرتبط با فناوری یا غیره مشغول به کار هستند، ایده مبهم یا نادرستی از معنی این اصطلاح پرکاربرد دارند.

منظور از api چیست ؟

منظور از api چیست ؟

وقت آن رسیده که خیلی دقیق بررسی کنیم که api چیست ؟
API ازنظر فنی اختصاری برای عبارت «رابط برنامه‌نویسی اپلیکیشن» (Application Programming Interface) محسوب می‌شود.
در برخی موارد شرکت‌های بسیار بزرگ API هایی برای مشتریان خود و یا کاربردهای داخلی‌شان ساخته‌اند.
اما اگر بخواهیم API را به زبان کاملاً ساده توضیح دهیم، معنی بسیار گسترده‌تری از آن چه در حوزه‌های نرم‌افزار یا کسب‌وکار استفاده می‌شود، خواهد داشت.
اگر برنامه نویس نیستید و قصد داشتید بدانید api چیست ؟ مطالعه این آموزش را تا این قسمت برای شما مفید می‌دانم. در صورتی که برنامه نویس هستید، شما را به خواندن ادامه این مطالب دعوت میکنم.
ابتدا کمی به عقب‌تر باز می‌گردیم و به بررسی عملکرد خود وب می‌پردازیم.

WWW و سرورهای ریموت

زمانی که در مورد وب فکر می‌کنیم، معمولاً یک شبکه بزرگ از سرورهای به هم متصل را در نظر می‌آوریم.
هر صفحه روی اینترنت در جایی روی یک سرور ریموت ذخیره شده است.
البته این سرور ریموت چیز چندان عجیب و جادویی نیست؛ بلکه بخشی از یک رایانه واقع شده در مکانی دوردست است که برای پردازش درخواست‌هایی که دریافت می‌کند بهینه‌سازی شده است.

برای این که چشم‌اندازی از این بحث داشته باشید، باید بدانید که شما می‌توانید یک سرور را روی لپ‌تاپ خود راه‌اندازی کنید که حتی قادر است کل یک وب‌سایت را روی اینترنت میزبانی کند.
در واقع اغلب مهندسان نرم‌افزار پیش از انتشار کدهای خود روی سرور ریموت و در دسترس عموم، آن‌ها را روی یک سرور محلی توسعه داده و تست می‌کنند.
زمانی که آدرس www.raman01.ir را در مرورگر خود وارد می‌کنید، یک درخواست به سرور ریموت رامان صفر و یک ارسال می‌شود.
زمانی که مرورگر پاسخ را دریافت می‌کند، کد مربوطه را تفسیر کرده و صفحه متناظر را نمایش می‌دهد.

سرور رامان صفر و یک از نظر مرورگر که به نام کلاینت نیز شناخته می‌شود، یک API است.
این بدان معنی است که هر بار که شما از صفحه‌ای روی وب بازدید می‌کنید، به نوعی با API سرور ریموت سر و کار دارید.
یک API همان سرور ریموت است؛ به جز این که بخشی از سروری محسوب می‌شود که درخواست‌ها را دریافت کرده و پاسخ‌ها را ارسال می‌کند.

API ها روشی برای عرضه خدمات به مشتریان هستند.

شاید شنیده باشید که برخی شرکت‌ها API هایشان را به صورت محصول بسته‌بندی می‌کنند.
برای نمونه Weather Underground دسترسی به API داده‌های آب‌وهوا را به فروش می‌رساند.

سناریوی نمونه

فرض کنید وب‌سایت کسب‌وکار کوچک شما یک فرم دارد که از آن برای ثبت‌نام از مشتری‌ها برای تعیین قرار ملاقات استفاده می‌کند.
شما می‌خواهید به مشتریان خود این توانایی را بدهید که به طور خودکار یک رویداد در تقویم گوگل ایجاد کرده و جزییاتی برای آن قرار ملاقات تعیین نمایند.

کاربرد API

برای فهم بهتر و پاسخ دقیق تر به این سوال که ” api چیست ؟ ” بیایید کاربرد api ها را بررسی کنیم.
ایده کاربرد API این است که کاری کنید سرور وب‌سایت شما به طور مستقیم و از طریق یک درخواست برای ثبت رویداد با جزییات مفروض با سرور گوگل ارتباط برقرار کند.
سرور شما سپس پاسخ گوگل را دریافت کرده و اطلاعات مرتبط مانند پیام تأیید به کاربر را به مرورگر وی بازمی‌گرداند.

به طور جایگزین مرورگر شما می‌تواند یک درخواست API را به صورت مستقیم به سرور گوگل ارسال کند و بدین ترتیب سرور شما را دور بزند.

API تقویم گوگل چه تفاوتی با API هر سرور ریموت دیگری دارد؟

از لحاظ فنی تنها تفاوت در قالب درخواست و پاسخ است.
مرورگر شما برای رندر کردن یک صفحه انتظار دارد پاسخی که دریافت می‌کند به زبان HTML باشد که شامل کدهای زیادی است.
در حالی که فراخوانی API تقویم گوگل تنها داده بازمی‌گرداند که احتمالاً در قالب JSON است.

  • اگر سرور وب‌سایت شما درخواست API را صورت داده باشد، در این صورت سرور وب‌سایت شما کلاینت است.
  • از منظر کاربر وب‌سایت، API ها امکان تکمیل کارها بدون نیاز به ترک وب‌سایت را می‌دهند.
  • اغلب وب‌سایت‌های مدرن دست‌کم مصرف‌کننده برخی API ها شخص ثالث هستند.
راه حل های مبتنی بر api

برای بسیاری از مشکلات راه‌حل‌های مبتنی بر API آماده‌ای وجود دارد که به شکل یک کتابخانه یا سرویس هستند.
بدین ترتیب در اغلب موارد استفاده از چنین API های آماده‌ای بسیار پایدارتر است.

در اغلب موارد تیم‌های توسعه، اپلیکیشن خود را به چندین سرور تقسیم می‌کنند که از طریق API با هم ارتباط دارند.
سرورهایی که تابع‌های کمکی را برای اپلیکیشن اصلی اجرا می‌کنند، غالباً به نام میکروسرویس نامیده می‌شوند.

برای این که این بحث را جمع‌بندی بکنیم، باید اشاره کنیم که وقتی یک شرکت API خود را به مشتریان ارائه می‌کند، بدان معنی است که آن‌ها مجموعه‌ای از URL های اختصاصی ساخته‌اند که پاسخ‌های داده‌ای خاصی را بازگشت می‌دهند، یعنی پاسخ‌هایی که شامل هیچ نوع «سربار ارائه‌ای» (Presentational Overhead) نیستند و مانند یک وب‌سایت منتظر یک رابط گرافیکی نیستیم.

در اکثر موارد می‌توان این درخواست‌ها را با مرورگر ارائه کرد.
چون انتقال واقعی HTTP به صورت متنی انجام می‌گیرد و مرورگر در این موارد برای نمایش پاسخ بسیار مناسب است.

برای نمونه می‌توانید به طور مستقیم و بدون نیاز به هیچ توکن دسترسی به API گیت‌هاب دسترسی داشته باشید.
کد زیر پاسخ JSON است که هنگام بازدید از مسیر API کاربر گیت‌هاب (+) در مرورگر دریافت می‌کنید:
حتما آن را مورد بررسی قرار دهید.


{
  "login": "petrgazarov",
  "id": ۵۵۸۱۱۹۵,
  "avatar_url": "https://avatars.githubusercontent.com/u/5581195?v=3",
  "gravatar_id": "",
  "url": "https://api.github.com/users/petrgazarov",
  "html_url": "https://github.com/petrgazarov",
  "followers_url": "https://api.github.com/users/petrgazarov/followers",
  "following_url": "https://api.github.com/users/petrgazarov/following{/other_user}",
  "gists_url": "https://api.github.com/users/petrgazarov/gists{/gist_id}",
  "starred_url": "https://api.github.com/users/petrgazarov/starred{/owner}{/repo}",
  "subscriptions_url": "https://api.github.com/users/petrgazarov/subscriptions",
  "organizations_url": "https://api.github.com/users/petrgazarov/orgs",
  "repos_url": "https://api.github.com/users/petrgazarov/repos",
  "events_url": "https://api.github.com/users/petrgazarov/events{/privacy}",
  "received_events_url": "https://api.github.com/users/petrgazarov/received_events",
  "type": "User",
  "site_admin": false,
  "name": "Petr Gazarov",
  "company": "PolicyGenius",
  "blog": "http://petrgazarov.com/",
  "location": "NYC",
  "email": "petrgazarov@gmail.com",
  "hireable": null,
  "bio": null,
  "public_repos": ۲۳,
  "public_gists": ۰,
  "followers": ۷,
  "following": ۱۴,
  "created_at": "۲۰۱۳-۱۰-۰۱T00:33:23Z",
  "updated_at": "۲۰۱۶-۰۸-۰۲T05:44:01Z"
}

مرورگرها در نمایش پاسخ JSON به خوبی عمل می‌کنند.
یک پاسخ JSON این چنین، آماده مصرف در کد است.
استخراج داده‌ها از این متن آسان است و سپس می‌توان با آن داده‌ها هر کاری که مورد نظر است را انجام داد.
به همین راحتی !

A اختصاری برای Application است

در انتها برخی نمونه‌های مختلف از API ها را بررسی می‌کنیم.
گفتنی است که Application می‌تواند به معانی مختلف باشد.
برخی از این مفاهیم در چارچوب API در ادامه معرفی شده‌اند:

  1. یک قطعه از نرم‌افزار با کارکرد متمایز
  2. کل سرور، کل اپلیکیشن، یا تنها بخش کوچکی از یک اپلیکیشن

اساساً هر بخش از نرم‌افزار که بتوان از محیطش جدا کرد را می‌توان یک «A» برای API تصور کرد و در اغلب موارد نیز نوعی API دارند.

برای درک بهتر مفهوم در ادامه با ما همراه باشید.
فرض کنید از یک کتابخانه شخص ثالث در کد خود استفاده می‌کنید.

زمانی که این کتابخانه را در کد خود به کار گرفتید، این کتابخانه به بخشی از اپلیکیشن کلی شما تبدیل می‌شود.
یعنی ما کتابخانه را به عنوان قسمتی از اپلیکیشن در نظر می‌گیریم.
در واقع متمایز بودن این کتابخانه از نرم‌افزار شما موجب می‌شود که:
API یی داشته باشد که امکان تعامل با بخش‌های دیگر کد را میسر می‌سازد.

در ادامه مثال دیگری را ارائه می‌کنیم.
در طراحی شیءگرا، کد به صورت اشیایی سازمان‌دهی می‌شود.
یک اپلیکیشن می‌تواند صدها شیء تعریف شده داشته باشد که می‌توانند با همدیگر تعامل داشته باشند.
هر شیء یک API دارد که مجموعه‌ای از متدهای عمومی و مشخصات هستند و از آن برای تعامل با اشیای دیگر در اپلیکیشن استفاده می‌کند.
هر شیء می‌تواند یک منطق درونی نیز داشته باشد که خصوصیات آن از منظر بیرونی (و نه API) پنهان است.

دیدگاهتان را بنویسید

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *

این فیلد را پر کنید
این فیلد را پر کنید
لطفاً یک نشانی ایمیل معتبر بنویسید.
برای ادامه، شما باید با قوانین موافقت کنید

آخرین مقالات منتشر شده

آخرین آموزش های کوتاه