API و Rest چیست؟ و آموزش Rest API در PHP به همراه ویدئوی آموزشی

مقدمه

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

عکسی از PHP و نسخه آن

API چیست؟

API برگرفته از 3 کلمه‌ي Application Programming Interface است، به معنای (رابط برنامه ‌نویسی اپلیکیشن) که مانند موتور زیر کاپوت عمل می‌کند و تمامی کارهایی را که ما انتطار داشته باشیم در پشت صحنه انجام می‌دهد.

ولی سوالی که خیلی‌ها می‌پرسند این است که API دقیقا چیست؟ و احتمالا شما هم این عبارت را در گوگل جستجو کرده‌اید.

API مثل یک پیام‌رسان است که درخواستش را به سیستم می‌دهد و به سیستم می‌گوید که چه کاری می‌خواهد انجام بدهد و سیستم به آن پاسخ می‌دهد.

API در زندگی روزمره

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

در این مثال پدر شما همان درخواست‌کننده است و فروشنده همان سیستم است که به درخواست پدرتان پاسخ می‌دهد، اما API چه کسی است؟

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

API در دنیای برنامه نویسی

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

عکسی برای بخش API - Rest API - Restful API

Rest چیست؟

Rest برگرفته از 3 کلمه‌ی Representational State Transfer که به معنای (انتقال بازنمودی حالت) است، به طور دقیق‌تر Rest چگونگی ظاهر APIها را تعیین می‌کند.

4 کار از عهده Rest بر‌می‌آید که یکیش را در بالا گفتیم و به ترتیب مابقی را توضیح می‌دهیم.

  • Rest تشکیل شده از متدهای HTTP می‌باشد
  • وضعیت کدها را به ما نمایش می‌دهد.
  • نوع پاسخ‌ها را نیز به نمایش می‌گذارد.

Rest تشکیل شده از متدهای HTTP می‌باشد

شاید با مفهوم CRUD آشنا باشید، CRUD مختصر شده 4 کلمه‌ی Create – Read – Update – Delete است که این عملیات در پایگاه داده انجام می‌شود که Create وظیفه‌ی ایجاد را دارد، Read وظیفه‌ی خواندن، Update وظیفه‌ی بروزرسانی و در نهایت Delete وظیفه‌ی حذف کردن را دارد، این موارد را در متدهای HTTP هم داریم که عملیاتی مشابه را انجام می‌دهند. (اگر به خواندن درباره پروتکل HTTP علاقه دارید مقاله پروتکل HTTP چیست؟ را از دست ندهید)

  • POST: یک درخواست به سمت سرور ارسال می‌کند.
  • GET: تمامی اطلاعاتی که از سمت سرور می‌آید را دریافت می‌کند.
  • PUT: اطلاعاتی که از قبل ارسال شده‌اند را بروزرسانی یا جای‌گذاری می‌کند.
  • DELETE: همین‌طور که از نامش پیداست وظیفه حذف تمامی اطلاعات نمایشی منبع هدف را دارد.
  • PATCH: متد کمتر شناخته شده از HTTP است اما کار دو متد POST و PUT را انجام می‌دهد و می‌توانید با این متد تغییرات جزئی را ایجاد کنید.
  • HEAD: این متد تقریبا شبیه به GET می‌ماند ولی یک سری تفاوت‌ها بین این دو است، برای مثال اگر شما از متد GET لیست کاربران را می‌خواهید این متد لیست را به شما نمایش می‌دهد اما متد HEAD این لیست را به شما نمایش نمی‌دهد ولی شاید برایتان سوال پیش بیاید پس برای چه استفاده می‌شود؟ این متد زمانی به کار می‌آید که بخواهید بدانید اطلاعاتی که قرار است بیاید به چه بزرگی و چه چیزی است.
  • OPTION: این متد درخواست‌هایی که از سمت سرور می‌آید را بررسی می‌کند، برای مثال اینکه این سرور چه متد‌هایی و چه عملکرد‌هایی را پشتیبانی می‌کند. متد OPTION گزینه‌ی خوبی برای آزمایش کردن Fatal Errorهای API نیز است.
  • TRACE: برای ارسال درخواست (Request) دریافتی است که مانند یک حلقه ارسال پیام می‌ماند و مکانیزم مناسبی برای اشکال‌زدایی است.

متدهای پروتکل HTTP - HTTP Methods

وضعیت کدها (Code Status) را به ما نمایش می‌دهد.

به طور کلی Code statusهایی که به سمت ما برمی‌گردد به 5 دسته تقسیم می‌شوند.

  • نوع اول:  از 100 تا 199
  • نوع دوم: از 200 تا 299
  • نوع سوم: از 300 تا 399
  • نوع چهارم: از 400 تا 499
  • نوع پنجم: از 500 تا 599

نوع پاسخ‌ها را نیز به نمایش می‌گذارد.

  • 1XX: پیام‌های اطلاعاتی (مثل پیام اطلاعاتی 100)
  • 2XX: پیام‌های موفقیت‌آمیز (مثل پیام موفقیت آمیز 200)
  • 3XX: تغییر مسیرها (مثل پیام 304)
  • 4XX: خطاهایی از سمت کاربر (مثل خطاهای 403)
  • 5XX: خطاهایی از سمت سرور (مثل خطای 500)

پس به خاطر داشته باشید که API یک پیام‌رسان می‌باشد و Rest این امکان را به ما می‌دهد تا از HTTP  استفاده کنیم و به این پیام‌ها استایل بدهیم.

منظور از استایل‌دهی همان تبادل اطلاعات در قالب JSON می‌باشد. JSON به اختصار رسیده 3 کلمه JavaScript Object Notation است که ساختاری شبیه به این را دارد.

Rest API یا Restful API چیست؟

تعریف در Restful API این‌گونه بیان می‌شود که به APIهایی که از قوانین Rest پیروی می‌کنند Restful API یا Rest API گفته می‌شود، یا خیلی ساده‌تر به تمامی فرایند ارسال و دریافت API از Server و Client که انجام می‌شود Rest API گفته می‌شود که هیچ محدودیتی در اجرای آن نیست به این معنا که در تمامی زبان‌های برنامه‌نویسی قابل استفاده است.

Rest API در گیت‌هاب

با هم یک مثال از آن را در سایت گیت‌هاب مشاهده می‌کنیم، برای این کار شما می‌توانید آدرس https://api.github.com/users  را در مرورگر خود وارد کنید و شاهد ساختار JSON که گیت‌هاب به ما برگردانده است خواهید بود. برای اینکه مشخصات خود را در ساختار JSON ببینید باید در انتهای آدرس یک / قرار دهید و نام کاربری گیت‌هاب خود را وارد کنید، بعد از این کار شما جزئیات پروفایل خود را در گیت هاب مشاهده می‌کنید.

مفهوم کلی Rest api - HTTP Methods در قالب یک عکس

Rest API یا Restful API در PHP

حالا وقت آن رسیده که یک نمونه Restful API با همدیگر در PHP بنویسیم، برای شروع یک سری پیش‌نیازها داریم که باید آن‌ها را تهیه کنید.

  1. XAMPP
  2. IDE
  3. JSON viewer (افزونه‌ی Google Chrome برای نمایش شکیل‌تر JSON)

بعد تهیه ابزارهای مورد نیاز باید کد‌نویسی را شروع کنیم.

  • قدم اول: پایگاه داده
    • Phpmyadmin خودتان را باز کنید.
    • یک پایگاه داده با نام api_db بسازید.
    • یک Table درون پایگاه داده به نام users بسازید.
    • در پایگاه داده خود 3 فیلد با نام‌های id – name- age بسازید.
    • درون فیلدها به طور دلخواه داده وارد کنید.
  • قدم دوم: آماده‌سازی فایل‌ها
    • ساخت فایل config.php برای قرار دادن کدهای اتصال به پایگاه داده
    • ساخت فایل index.php برای نوشتن کدهای Restful API

کدهایی که پایین قرار داده‌ایم باید در فایل config.php قرار بگیرد تا بتوانیم به پایگاه داده متصل شویم، در ادامه خط به خط کدها را توضیح خواهیم داد.

<?php
class Connect extends PDO
{
    public function __construct()
    {
        parent::__construct("mysql:host=localhost;dbname=api_db","root","");
        array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8");
        $this->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    }
}
?>

و در فایل index.php این خط کدها را قرار دهید.

require_once "config.php";
class API
{
    function Select(){
        $db = new Connect();
        $users = array();
        $data = $db->prepare("SELECT * FROM users ORDER BY id;");
        $data->execute();
        while($outPutData = $data->fetch(PDO::FETCH_ASSOC)){
            $users[$outPutData['id']] = array(
                'id'   => $outPutData['id'],
                'name' => $outPutData['name'],
                'age'  => $outPutData['age'],
            );
        }
        return json_encode($users);
    }
}
$users = new API();
header("Content-Type: application/json");
echo $users->Select();

حال اگر شما این کدها را اجرا کنید باید شاهد این خروجی باشید.

// 20200229194615
// http://localhost/php/API/
{
  "1": {
    "id": 1,
    "name": "Amir",
    "age": "18"
  },
  "2": {
    "id": 2,
    "name": "Mohammad",
    "age": "13"
  },
  "3": {
    "id": 3,
    "name": "Zahra",
    "age": "28"
  },
  "4": {
    "id": 4,
    "name": "Sahar",
    "age": "22"
  }
}

تمامی توضیحات درباره کدهای بالا در ویدئو پایین قرار دارد، توصیه می‌کنیم این ویدئو را مشاهده نمائید.

توضیحاتی درباره‌ی کدهای نوشته شده در فایل config.php

class Connect extends PDO
{
}

با کلمه کلیدی class ما می‌توانیم در PHP یک کلاس تعریف کنیم و با آوردن یک نام دلخواه جلوی class می‌توان آن‌ کلاس را با آن نام بشناسیم، کلمه‌ی کلیدی  extends PDO که بعد از نام class آمده به این معناست که خصوصیات PDO که یک روش شی‌گرایی برای اتصال به پایگاه داده است را برای ما ارث‌بری می‌کند.

public function __construct() 
{
}

وقتی ما در تعریف یک تابع درون یک شیء از تابع construct__ استفاده می‌کنیم زمانی اجرا می‌شود که ما آن کلاس را فراخوانی کنیم، پس اولین تابعی که در این کلاس به طور پیش‌فرض اجرا می‌شود construct__ است.

parent::__construct("mysql:host=localhost;dbname=api_db","root","");

کلمه‌ی کلیدی parent ویژگی پدر خودش که PDO بود که آن را به ارث بردیم برای ما می‌آورد، در تابع construct__ مشخصات پایگاه داده خود را وارد می‌کنیم.

در مقابل =mysql:host  نام host خود را می‌آوریم که در اینجا localhost می‌باشد و با ; (سمیکالن) جدا می‌کنیم و در مقابل =dbname نام پایگاه داده خود را وارد می‌کنیم.

در قسمت بعدی خارج از ” (دابل کوتیشن)، یک رشته‌ي دیگر باز می‌کنیم و نام کاربری پایگاه داده خود را وارد می‌کنیم که به طور پیش‌فرض root است و در رشته‌ي بعدی رمز پایگاه داده خود را وارد می‌کنیم که به طور پیش فرض خالی است.

array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8");

در کد بالا کاراکتر utf8 برای mysql ست کرده‌ایم.

$this->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

 

با کلمه this$ ما در اصل داریم به آن تابع اشاره می‌کنیم و با تابع setAttribute ما می‌توانیم یک سری صفت برای آن‌ها ست کنیم که در اینجا ما PDO::ATTR_ERRMODE که کار گزارش‌دهی خطا و ERRMODE_EXCEPTION هندل کردن خطا را بر عهده دارند.

توضیحاتی درباره کدهای نوشته شده در فایل index.php
Require_once "config.php";

با require_once می‌توانیم یک فایل را لود کنیم تا از محتویات آن در کدهایمان استفاده کنیم.

class API
{
    function Select(){
    }
}

 

همان‌طور که مشاهده می‌کنید ما یک کلاس با نام API ساخته‌ایم که کدهای API خود را درون آن می‌ریزیم و درون آن یک تابع به نام Select ایجاد کرده‌ایم تا بتوانیم کدی که نوشته‌ایم را بارها و بارها استفاده کنیم.

$db = new Connect();
$users = array();
$data = $db->prepare("SELECT * FROM users ORDER BY id;");
$data->execute();

به بررسی 4 خط کد اول داخل تابع می‌پردازیم.

  • در خط اول: یک نمونه از کلاسی که درون فایل config.php ساخته شده بود ایجاد کرده‌ایم و درون متغیر db$ ریخته‌ایم.
  • در خط دوم: یک آرایه خالی از usersها ساخته که در جلوتر کاربرهای خود را درون آن متغیر قرار می‌دهیم.
  • در خط سوم: یک دستور SQL ساده نوشته‌ایم که تمامی کاربرها را از پایگاه داده می‌خواند و آن‌ها را بر اساس شناسه id مرتب می‌کند.
  • در خط چهارم: دستور SQL را اجرا کرده‌ایم.
while($outPutData = $data->fetch(PDO::FETCH_ASSOC)){
     $users[$outPutData['id']] = array(
          'id'   => $outPutData['id'],
          'name' => $outPutData['name'],
          'age'  => $outPutData['age'],
     );
}

ما در قسمت شرط این حلقه با PDO::FETCH_ASSOC هر بار یک آرایه associative، از هر سطر در tableمان داخل پایگاه داده دریافت می‌کنیم (آرایه associative یک آرایه‌ای است که کلیدها را ما خودمان در آن با نام دلخواه تعریف میکنیم) و در متغیر outPutData$ قرار می‌گیرد و ما هر بار مقدار بازگشتی را در یک عضو از آرایه users ذخیره می‌کنیم و در آخر وقتی که مقدار بازگشتی وجود نداشته باشد شرط false می‌شود و از حلقه خارج می‌شود.

return json_encode($users);

و در آخر مقداری که درون آرایه users ذخیره شده است را به یک ساختار JSON تبدیل می‌کنیم و آن را به عنوان خروجی کار برمی‌گردانیم.

$users = new API();
header("Content-Type: application/json");
echo $users->Select();

در ادامه کار و در خارج از ساختار کلاس ما یک نمونه از کلاس API در users می‌سازیم، در خط دوم که header را آورده‌ایم  از اهمیت بالایی بر خوردار است چون مشخص می‌کند محتوای ما از چه نوعی است.
و در نهایت نیز خروجی را چاپ می‌کنیم و نتیجه زیر را می‌بینیم.
خروجی کدهای نوشته شده JSON - API - Restful API - Rest API
جمع بندی

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

 
ارسال دیدگاه
ما همه سوالات و دیدگاه ها رو می خونیم و پاسخ میدیم
۴۲ دیدگاه
Ayoob Kargar ۱۰ خرداد ۱۴۰۰، ۱۸:۵۶
خیلی خوب بود دمت گرم
Ayoob Kargar ۱۰ خرداد ۱۴۰۰، ۱۸:۵۱
سلام
یک سوال داشتم
اگر بخواهیم خروجی از نوع آرایه ای از جیسون باشه چکار باید کرد
نازنین کریمی مقدم ۱۱ خرداد ۱۴۰۰، ۱۷:۵۰
درود. سوال خیلی خوبی پرسیدید.
کافیه خروجی رو یک آرایه در نظر بگیرید و داده رو با فرمت جیسون توش برگردونید. برای مثال:

$output = array();
foreach ($query->result() as $row) {
$output[] = $row->id . ' ' . $row->name;
}
echo json_encode($output);


البته یک نمونه کد حاوی جیسون هم در انتهای مقاله آوردیم که میتونید اون رو هم بررسی کنید.
کیاوش ۲۳ اردیبهشت ۱۴۰۰، ۱۰:۳۴
سلام وقتتون بخیر،یک سوالی داشتم،من دیدم یک جاهایی نوشتن آموزش api و یکسری هم نوشتن rest api ،میخواستم بدونم تفاوتی هست در این دو؟
نازنین کریمی مقدم ۲۵ اردیبهشت ۱۴۰۰، ۰۳:۰۰
درود
یجورایی جواب سوالتون در مقاله هست. به طور کلی api به مجموعه روشهایی گفته میشه که با استفاده از اونها برنامه ها میتونند با هم ارتباط برقرار کنند. حالا در حوزه وب، یکی از پرکاربردترینشون روش rest api هست. پس در واقع rest api یک روش هست که زیرمجموعه ای از مجموعه گسترده api میشه.
مهدی جعفری ۱۲ دی ۱۳۹۹، ۲۰:۲۴
خوبه. اما از یه مجموعه ای مثل سون لرن انتظار میره آموزش های کامل تری رو ارائه بده. این آموزش نقص های زیادی داشت و نیاز هس کامل تر باشه. هم از نظر مفهوم و هم از نظر مثال ها و نمونه ها
zahra ۲۶ آذر ۱۳۹۹، ۱۱:۰۲
خوب بود ممنون
امیر ۱۸ آذر ۱۳۹۹، ۲۳:۵۴
اگه ممکن هست یک راه ارتباطی مثلا تلگرام و یا اینستاگرام بدید از اونجا با شما در ارتباط باشم در ضن قالب html رو باید در ریشه سایت اپلود کنم یعنی کلا وردپرس رو از اونجا حذف کنم و فقط قالب html رو بزارم و با ریداکت همون صفحه نمایش داده بشه.
نازنین کریمی مقدم ۱۹ آذر ۱۳۹۹، ۲۰:۰۲
برای تغییر قالب وردپرس نیاز نیست از ریشه همه چیز رو پاک کنید. روش دومی که گفتید اوکی هست. شما از همون سایتی که بهتون پیشنهاد دادم آموزش ها رو ببینید متوجه میشید.
برنامه نویسی دردسرهای خودش رو داره و شما حتما باید خودتون یکبار آموزشها رو ببینید و مراحل رو انجام بدید، اینجوری مشکلتون سریعتر رفع میشه.
متاسفانه به دلایل سیاستهای تیمی امکان ارتباط خارج از سایت رو با هم نداریم، اما در صورت گرفتن خطا در مراحل، میتونید در زیر پستهای مرتبط با وردپرس مون کامنت بگذارید تا با کمک هم مشکلتون رو برطرف کنیم.
موفق باشید :)
امیر ۱۷ آذر ۱۳۹۹، ۱۸:۱۱
به نظر شما قالب " https://themeforest.net/item/buka-one-page-portfolio/22281415 " خوب هست چون موضوع سایت من مقاله های اموزش و ویدئو های اموزش میخوام درست کنم بخواتر همین میخواستم ببینم این قالب برای صفحه اول خوب هست یا نه و شما گفتید از یه قالب تک صفحه ای استفاده کنید من دقیقن نمیدونم چطور باید قالب تک صفحه ای رو به نمایش بزارم اگه میشه یه سایتی بگید که از طرق آموزش قالب تک صفحه ای رو تنظیم کنم و افزونه المنتور رو نصب کردم و دارم ازش استفاده میکنم الان من توی این افزونه مطالب وبلاگ رو میتونم نمایش بزارم یا باید چطور باید این کار بکنم. اگه ممکنه خودتون چند تا قالب تک صفحه ای و قالب شخصی هم معفی کنید که با افزونه المنتور سازگار هست.
نازنین کریمی مقدم ۱۸ آذر ۱۳۹۹، ۲۳:۴۲
1. بله قالب بوکا قالب خوبیه و یه بخش وبلاگ در نظر گرفته، بعضی از قالبای تک صفحه ای حتی وبلاگ رو صرفا فقط تو هدر صفحه اصلی میارن و وقتی روش میزنید میره رو تو بخش وبلاگ. حالا اینکه کدوم رو میپسندید سلیقه خودتون هست. قالبی که انتخاب میکنید باید جوری باشه که ضمن اینکه انتظارات صفحه اول موردنظرتون رو برآورده کنه، سایر انتظارات رو هم برآورده کنه.
2. قالب تکصفحه ای هیچ فرقی با بقیه قالبها نداره، فقط یکم کاربر پسندتر هست (چون رو گزینه های منو که کلیک میکنید صفحه جابجا میشه و چیزی دوباره لود نمیشه)
3. پیشنهاد میکنم از سایت همیار وردپرس برای استفاده از قالبهای مختلف کمک بگیرید. این سایت قالبهای وردپرسی رو براساس موضوع و نوع دسته بندی کرده و پیش نمایش هر قالب و طریقه استفاده شو کامل توضیح داده.
4. بله با المنتور هم میتونید روی قالب فعلی تون هم کار کنید. به راحتی یه بخش رو به صفحه اصلی تون اضافه کنید و یه منوی سه قسمتی در اون بخش بندازید. تو هر قسمت هم یه مقاله بندازید. یه دکمه هم بذارید که اگه کاربر روش زد، بره به برگه مقالات. پیشنهاد میکنم چندتا آموزش ویدیویی از اینترنت ببینید، چون توضیحش یکم سخته اما تصویری در کمتر از یه ربع کامل متوجه میشید.
5. من خودم با قالب Divi کار میکنم که البته رایگان نیست. کارهای شخصی سازی قالب مثل همین اضافه کردن بخش و... رو هم با المنتور انجام میدم. اما در کل سعی کنید با قالب و وردپرس دوست باشید و از کار کردن و تست حالتهای مختلف خسته نشید تا وردپرس مهربون تر رفتار کنه :)
امیر ۱۶ آذر ۱۳۹۹، ۱۶:۳۸
سلام دوباره منظور من این هست من در دامنه سایتم یعنی amirhm.ir یه سابدامین درست میکنم به نام بخش وبلاگ blog.amirhm.ir حالا میخوام مقاله ها و هر مطالبی که هست در این بخش وبلاگ و در دامنه اصلی این ها نشون داده بشه حالا من با چه راهی میتونم این کار رو انجام بدم با افزونه rss انجام دادم به درستی نمایش نداد حالا میخوام بدونم با نوشتن api میشه این کار رو انجام داد یا با بدون اون. برای مثال این سایت pouyeshserver.com رو ببینید در قسمت پایین بخش آخرین اخبار وطالب بخش وبلاگ رو در صفحه اطلی قرار دادن. الان منم میخوام این کار رو بکنم.
نازنین کریمی مقدم ۱۷ آذر ۱۳۹۹، ۰۴:۰۸
خیلی ممنون که واضح تر توضیح دادید :)
هم با API میشه انجام داد و هم بدون اون،
در حالت اول اگر با API بخواید انجام بدید باید تمامی مراحل رو صفر تا صد خودتون پیاده سازی کنید: اول از همه سورس صفحه اصلی رو تغییر بدید تا بخش وبلاگ به شکل یه فضای خالی دیده بشه، بعد با API اطلاعات آخرین مقاله تون رو درون این فضای خالی نشون بدید و یه دکمه هم بذارید که اگر کاربر زد، بره به برگه وبلاگ. در این روش کارتون خیلی سخت میشه، علاوه بر اون اگر از قالب خوبی استفاده نکرده باشید و تغییرات رو ریسپانسیو اعمال نکنید ممکنه روی سایر دستگاه ها و یسری مرورگرها به مشکل بخوره.
من توصیه میکنم که بدون API انجام بدید. اول از همه توصیه میکنم از همین ابتدای کار قالب تون رو تغییر بدید. قالب شما Astra است و صفحه اولش دارای بخشهای مشخصی هست. تغییر قالب دردسرش خیلی کمتره و ثابت شده که بهترین راهکار هست. میتونید از قالبهای تک صفحه ای کمک بگیرید. (این قالبها لزوما تک صفحه ای نیستند اما در صفحه اول امکان حذف و اضافه بخش جدید رو به کاربر میدهند) دقیقا همون چیزی رو به شما میدهند که به دنبالش هستید.
اگر به هر دلیلی نمیتونید قالب رو تغییر بدید، از افزونه المنتور استفاده کنید. انگار نصبش هم کردید، اما نمیدونم چه مشکلی داشته که نتونسته بهتون کمک کنه؟ امیدوارم قالب تون با المنتور سازگار باشه.
امیر ۱۳ آذر ۱۳۹۹، ۱۸:۲۹
سلام خسته نباشید من میخوام بخش وبلاگ رو در سایت راه اندازی کنم برای مثال : پوشه blog رو درست میکنم و وردپرس رو توش راه میندازم و نوشته های توی اون میزارم و الان میخوام این نوشته ها بخش وبلاگ به ادرس example.ir/blog رو در بخش اصلی سایت یعنی example.ir نمایش بدم باید چی کار کنم که مطالب بخش وبلاگ رو در صفحه اول به نمایش در بیاد منظورم این هست که وقتی یک کاربر در بخش example.ir روی یک پست زد به بخش وبلاگ بره نمونه example.ir/blog/test این امکان وجود داره یا نه.
نازنین کریمی مقدم ۱۵ آذر ۱۳۹۹، ۰۴:۵۰
درود.
امکانش که هست اما سوالتون خیلی کلی هست و معلوم نیست روی کدوم بخش به مشکل خوردید. منظورتون همین بحث استفاده از API هست؟
این مقاله رو بخونید و اگر سوالتون موارد بیشتری رو شامل میشه همون پایین دقیقتر توضیح بدید که بتونیم کمک تون کنیم.
حیدر ۲۴ آبان ۱۳۹۹، ۲۳:۴۴
سلام، خدا خیرتان دهد
یک سؤال داشتم
آنچه من دیدم یک کوئری از دیتابیس بود
header("Content-Type: application/json");
و اطلاعات به صورت json استخراج شدند
آیا API این است؟
اگر بخواهیم یک API با همین PHP بنویسیم که بتوانیم از reactjs در فرانت اند استفاده کنیم، راه حل چیست؟
امیر صالحی ۲۸ آبان ۱۳۹۹، ۲۳:۰۱
سلام و احترام
بله به این شکل هستش و بهتون پیشنهاد میدم بیشتر مطالعه داشته باشید. شما وب سرویس خودتو مینویسید و با استفاده از جاوااسکریپت میتونید یک درخواست به سمت آدرس API یا همون End-point ارسال میکنید. وقتی که این درخواست رو ارسال کردید داده هارو در قالب json در اختیار دارید و میتونید استفاده کنید.
mehran ۲۷ مهر ۱۳۹۹، ۰۰:۰۸
خب الان api رو نوشتیم تو فرانت اند چجوری ازش استفاده کنیم ؟
امیر صالحی ۲۸ مهر ۱۳۹۹، ۲۱:۳۰
سلام و احترام
باید یک Request ارسال کنید به Endpoint تا بتونید نتابج json رو دریافت کنید
رضا ۲۶ شهریور ۱۳۹۹، ۱۷:۰۲
با سلام و وقت بخیر
آیا میتوان دستورات و کدهای مربوط به API را با زبان جاوااسکریپت و در نرم افزار visual studio زد؟
امیر صالحی ۲۶ شهریور ۱۳۹۹، ۱۷:۲۲
سلام و احترام
بله قطعا میتونید با جاوااسکریپت های api نویسی کرد. در باره‌ی نرم افزار visual studio باید بهتون بگم که این نرم افزار فقط یک IDE هستش و دخالتی توی نوشتن api نداره، صرفا بهمون کمک میکنه توی محیط مناسب کد نویسی کنیم.
Amin Allahrabi ۳۱ مرداد ۱۳۹۹، ۱۲:۲۳
سلام ، من میخواستم اطلاعات یک سایت رو بگیرم و در سایت خودم نشان بدم، از API استفاده کنم بهتر هست یا استفاده از web service ؟ ، با فریم ورک لاراول کار میکنم.
امیر صالحی ۰۲ شهریور ۱۳۹۹، ۰۹:۴۴
سلام
اگه وب سایت مقصد شما به شما خدمات api را می دهد می توانید از api استفاده کنید
حسین سلطانیان ۲۸ خرداد ۱۳۹۹، ۲۳:۱۶
ممنون عالی بود واقعا ،خدا خیرت بده امیر جان
امیر صالحی ۰۳ تیر ۱۳۹۹، ۱۹:۵۲
سلام حسین جان، خیلی خوشحالم که به کارت اومده
ماندانا مهرپور ۰۳ خرداد ۱۳۹۹، ۱۳:۳۷
سلام
عالیییی بود...واقعا ممنون
امیر صالحی ۰۵ خرداد ۱۳۹۹، ۱۱:۳۷
سلام
سپاس از شما
omid ۰۱ اردیبهشت ۱۳۹۹، ۲۱:۱۲
سلام - از Collation زیر استفاده کردم
utf8mb4_general_ci
امیر صالحی ۰۲ اردیبهشت ۱۳۹۹، ۱۹:۵۳
لطفا پروژه کنونی رو توی گیت هاب آپلود کنید تا من بررسی کنم
omid ۳۱ فروردین ۱۳۹۹، ۱۵:۵۳
سلام ممنون از آموزشتون
من در هنگام دریافت اطلاعات رو بصورت زیر دریافت میکنم
{
"id": "36",
"name": "\u0627\u0646\u0648\u0627\u0639 \u062f\u0645\u0646\u0648\u0634"
},

بخش name متن فارسی هستش . چجوری میتونم این مشکل رو حل کنم؟
امیر صالحی ۰۱ اردیبهشت ۱۳۹۹، ۱۸:۵۳
سلام
ممنون از شما برای وقتی که گذاشتید
برای دیتابیستون collation مناسب تعریف کردید؟
اشکان ۱۵ اسفند ۱۳۹۸، ۰۲:۰۲
درود به شما.
تشکر بابت آموزشتون.
اما! یه چیزی رو متوجه نشدم! این همه توضیح راجب HTTP و REST و API تهش چیزی از استفاده از پروتکل‌های HTTP نبود!
نه از پروتکل‌ها خبری بود نه از status codeها! به هر حال ممنون.
راستی «کدهای وضعیت یا status codes» درسته نه «وضعیت کد (code status)». :)
امیر صالحی ۱۵ اسفند ۱۳۹۸، ۱۰:۰۰
سلام دوست عزیز
بله همون طور تو ویدیو هم گفتیم قرار شد که Rest API ساده بزنیم و اگر Code status را جستجو کنید به نتیجه ای که بالا اشاره شد خواهید رسید.
و در آخر ممنون از وقتی که برای مطالعه این مقاله گذاشتید .
Faraz Salehi ۱۴ اسفند ۱۳۹۸، ۱۰:۴۷
خیلی عالی بود ... فقط یه سوال : کاربرد header چی هست ؟ من شخصا بیشتر از تابع header برای رجوع به یه صفحه دیگه می کنم.
امیر صالحی ۱۴ اسفند ۱۳۹۸، ۱۳:۰۸
تشکر بابت وقتی که گذاشتید
بله درسته شما از header و پارامتر location استفاده میکنید تا به یک صفحه ی دیگه روجوع کنید ولی تابع header محدود به این کار نیست، همون طور که تو مقاله هم خوندید از header برای مشخص کردن نوع محتوای صفحه مورد نظرمون استفاده کردیم و گفتیم که قراره تو این صفحه JSON بشینه.
امیدوارم باعث رفع ابهام شده باشه.
Abbas ۱۳ اسفند ۱۳۹۸، ۱۷:۱۴
سلام خسته نباشید عاااالی بود خدا خیرتون بده
امیر صالحی ۱۳ اسفند ۱۳۹۸، ۲۰:۳۳
سلام
شما هم خسته نباشی دوست عزیز
مرسی از اینکه وقت با ارزشتونو برای این مقاله گذاشتید
امیررضا جانانفر ۱۳ اسفند ۱۳۹۸، ۱۶:۴۰
واقعا عالی و کابردی بود
کلی لذت بردم از خوندن این پست
امیررضا جانانفر ۱۳ اسفند ۱۳۹۸، ۱۶:۳۹
آقا بسیار عالی و کاربردی بود
لذت بردم واقعا
امیر صالحی ۱۳ اسفند ۱۳۹۸، ۲۰:۳۱
خیلی خوشحالم از اینکه این مقاله برای شما کاربردی بوده
Abolfazl Soltani ۱۲ اسفند ۱۳۹۸، ۱۹:۳۸
عالی بود👌🏼
امیر صالحی ۱۳ اسفند ۱۳۹۸، ۱۴:۱۰
ممنون از اینکه برای مطالعه این مقاله وقت گذاشتید