
مقدمه
حتما شما از تلگرام استفاده کردهاید و به احتمال زیاد هم نرمافزار موبایلش را در تلفنهای همراه خود دارید و شاید بعضی اوقات بنا بر نیازتان از نسخه دسکتاپ یا وب آن استفاده کردهاید، شاید برایتان سوال باشد که چطور میشود که من هر چیزی که در تلگرام موبایلم دارم در وب و دسکتاپ نیز دارم و حتی میتوانم همزمان از آنها استفاده کنم، سوال بسیار جالبی است و قرار است که با هم در این مقاله جزئیات آن را بررسی کنیم.
فهرست محتوای این مقاله
API چیست؟
API برگرفته از 3 کلمهي Application Programming Interface است، به معنای (رابط برنامه نویسی اپلیکیشن) که مانند موتور زیر کاپوت عمل میکند و تمامی کارهایی را که ما انتطار داشته باشیم در پشت صحنه انجام میدهد.
ولی سوالی که خیلیها میپرسند این است که API دقیقا چیست؟ و احتمالا شما هم این عبارت را در گوگل جستجو کردهاید.
API مثل یک پیامرسان است که درخواستش را به سیستم میدهد و به سیستم میگوید که چه کاری میخواهد انجام بدهد و سیستم به آن پاسخ میدهد.
API در زندگی روزمره
فرض کنید که پدرتان به شما یه لیست خرید داده است و شما میخواهید از فروشگاه مربوطه خرید کنید، میروید و لیستی که پدرتان به شما داده است را به فروشنده میدهید و میخواهید که این لیست را برای شما بیاورد و فروشنده بعد از چند دقیقه اجناس را برای شما آماده میکند و شما هم برمیگردید و آنها را تحویل پدرتان میدهید.
در این مثال پدر شما همان درخواستکننده است و فروشنده همان سیستم است که به درخواست پدرتان پاسخ میدهد، اما API چه کسی است؟
درست حدس زدید API دقیقا خود شما هستید که درخواست را از پدرتان دریافت کردهاید و به فروشنده تحویل دادهاید و از همان فروشنده پاسخ را دریافت کردید و به پدرتان تحویل دادهاید.
API در دنیای برنامه نویسی
حال فکر کنید که میخواهید یک بلیط هواپیما بخرید، اگر به سایتهایی مثل ماهان ایر، ایرانایر و ... بروید شما محدود هستید به اینکه فقط از پروازهای آنها بلیط تهیه کنید اما وقتی شما به سایتهایی مانند علی بابا مراجعه میکنید، این سایتها تمامی پروازها را از مبدا هر جایی به مقصد هر جایی در اختیار دارند پس متوجه میشویم که این سایتها در حال صحبت کردن با سایر سایتها میباشند، در اینجا 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) دریافتی است که مانند یک حلقه ارسال پیام میماند و مکانیزم مناسبی برای اشکالزدایی است.
وضعیت کدها (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 یا Restful API در PHP
حالا وقت آن رسیده که یک نمونه Restful API با همدیگر در PHP بنویسیم، برای شروع یک سری پیشنیازها داریم که باید آنها را تهیه کنید.
- XAMPP
- IDE
- 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 را آوردهایم از اهمیت بالایی بر خوردار است چون مشخص میکند محتوای ما از چه نوعی است.
و در نهایت نیز خروجی را چاپ میکنیم و نتیجه زیر را میبینیم.
جمع بندی
شاید تا الان نمیدانستیم ولی متوجه شدیم که تلفنهای همراهمان، وب سایتها، نرمافزارهای دسکتاپ و ... به یکدیگر متصل هستند و با یکدیگر صحبت میکنند پس امکانات بسیار زیادی را به ما میدهند، ساختار آنها درست مثل نمونهی سادهای که نوشتهایم است، پس اگر با هر زبان برنامهنویسی و یا فریمورکی کار میکنید فرا گرفتن این بخش میتواند بسیار شما را در کارتان حرفهای کند لازم به ذکر است که شما اگر به دنیای تکنولوژی علاقهمند هستید باید همیشه خودتان را بروز نگه دارید.
خوبه. اما از یه مجموعه ای مثل سون لرن انتظار میره آموزش های کامل تری رو ارائه بده. این آموزش نقص های زیادی داشت و نیاز هس کامل تر باشه. هم از نظر مفهوم و هم از نظر مثال ها و نمونه ها
خوب بود ممنون
اگه ممکن هست یک راه ارتباطی مثلا تلگرام و یا اینستاگرام بدید از اونجا با شما در ارتباط باشم در ضن قالب 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 در اختیار دارید و میتونید استفاده کنید.
خب الان api رو نوشتیم تو فرانت اند چجوری ازش استفاده کنیم ؟
سلام و احترام
باید یک Request ارسال کنید به Endpoint تا بتونید نتابج json رو دریافت کنید
با سلام و وقت بخیر
آیا میتوان دستورات و کدهای مربوط به API را با زبان جاوااسکریپت و در نرم افزار visual studio زد؟
سلام و احترام
بله قطعا میتونید با جاوااسکریپت های api نویسی کرد. در بارهی نرم افزار visual studio باید بهتون بگم که این نرم افزار فقط یک IDE هستش و دخالتی توی نوشتن api نداره، صرفا بهمون کمک میکنه توی محیط مناسب کد نویسی کنیم.
سلام ، من میخواستم اطلاعات یک سایت رو بگیرم و در سایت خودم نشان بدم، از API استفاده کنم بهتر هست یا استفاده از web service ؟ ، با فریم ورک لاراول کار میکنم.
سلام
اگه وب سایت مقصد شما به شما خدمات api را می دهد می توانید از api استفاده کنید
ممنون عالی بود واقعا ،خدا خیرت بده امیر جان
سلام حسین جان، خیلی خوشحالم که به کارت اومده