⚜️ دوره لاراول - قسمت نوزدهم
📚 الکوئنت ، فکتوریها | Eloquent Factories
خلاصه :
توی این قسمت با فکتوریها اشنا شدیم کمی باهاشون کار کردیم ، برای پستها فکتوری ساختیم و استفاده کردیم.
توی قسمت های بعدی این مجموعه رو ادامه میدیم.
🎞 لینک ویدیو:
https://youtu.be/Gh-fbsUupLE
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
📚 الکوئنت ، فکتوریها | Eloquent Factories
خلاصه :
توی این قسمت با فکتوریها اشنا شدیم کمی باهاشون کار کردیم ، برای پستها فکتوری ساختیم و استفاده کردیم.
توی قسمت های بعدی این مجموعه رو ادامه میدیم.
🎞 لینک ویدیو:
https://youtu.be/Gh-fbsUupLE
🔖 #Laravel, #PHP, #لاراول
👤 Matin Soleymani
💎 Channel: @DevelopixLaravel
فصل پنج - Migrations and Database
بخش چهارم - اتصالات دیتابیس
در لاراول، مدیریت چندین اتصال به دیتابیس و استفاده از دیتابیسهای مختلف به صورت سادهای امکانپذیر است.
- چندین اتصال به دیتابیس
برای مدیریت چندین اتصال به دیتابیس فایل تنظیمات
مثال:
در اینجا دو کانکشن مختلف با نام های mysql و mysql_second را پیکربندی می کنیم.
——————
- استفاده از چندین کانکشن در کد
پس از تعریف کانکشنها در فایل تنظیمات، میتوانید به صورت زیر از آنها استفاده کنید:
همچنین در یک مدل خاص میتوانید کانکشن را مشخص کنید:
——————
- استفاده از MongoDB
برای استفاده از MongoDB در لاراول، میتوانید از پکیج رسمی
با استفاده از Composer، پکیج را به پروژه خود اضافه کنید:
پس از نصب پکیج، باید تنظیمات مربوط به اتصال به دیتابیس MongoDB را در فایل
پس از آن با کانکشن mongodb به دیتابیس mongodb خود متصل شوید.
——————
- استفاده از Redis در لاراول
لاراول به صورت داخلی از Redis پشتیبانی میکند.
تنظیمات Redis را می توانید در فایل
در این دوره استفاده از ردیس به طور کامل بررسی نمی شود، اما تمامی متد های ردیس از فساد Redis در دسترس هستند:
🔖 #Laravel, #PHP, #فصل_۵, #لاراول
👤 AmirHossein
💎 Channel: @DevelopixLaravel
بخش چهارم - اتصالات دیتابیس
در لاراول، مدیریت چندین اتصال به دیتابیس و استفاده از دیتابیسهای مختلف به صورت سادهای امکانپذیر است.
- چندین اتصال به دیتابیس
برای مدیریت چندین اتصال به دیتابیس فایل تنظیمات
config/database.php
را باز کنید. در آرایهی connections، میتوانید چندین کانکشن مختلف تعریف کنید.مثال:
'connections' => [
'mysql' => [
// ...
],
'mysql_second' => [
// ...
],
]
در اینجا دو کانکشن مختلف با نام های mysql و mysql_second را پیکربندی می کنیم.
——————
- استفاده از چندین کانکشن در کد
پس از تعریف کانکشنها در فایل تنظیمات، میتوانید به صورت زیر از آنها استفاده کنید:
// connect to 'mysql'
$data = DB::connection('mysql')->select('SELECT * FROM users');
// connect to 'mysql_second'
$data = DB::connection('mysql_second')->select('SELECT * FROM products');
// In migrations
public function up()
{
Schema::connection('mysql_second')->create('products', function (Blueprint $table) {
// ...
});
}
همچنین در یک مدل خاص میتوانید کانکشن را مشخص کنید:
class Product extends Model
{
protected $connection = 'mysql_second';
}
——————
- استفاده از MongoDB
برای استفاده از MongoDB در لاراول، میتوانید از پکیج رسمی
mongodb/laravel-mongodb
استفاده کنید. این پکیج توسط MongoDB نگهداری میشود و ادغام کاملی با Eloquent و سایر ویژگیهای لاراول فراهم میکند. در ادامه، مراحل نصب و پیکربندی این پکیج را توضیح میدهم:با استفاده از Composer، پکیج را به پروژه خود اضافه کنید:
composer require mongodb/laravel-mongodb
پس از نصب پکیج، باید تنظیمات مربوط به اتصال به دیتابیس MongoDB را در فایل
config/database.php
اضافه کنید. در بخش connections، کانکشن mongodb را به صورت زیر تعریف کنید:'connections' => [
// others...
'mongodb' => [
'driver' => 'mongodb',
'dsn' => env('MONGODB_URI', 'mongodb://localhost:27017'),
'database' => env('MONGODB_DATABASE', 'laravel_app'),
],
],
پس از آن با کانکشن mongodb به دیتابیس mongodb خود متصل شوید.
——————
- استفاده از Redis در لاراول
لاراول به صورت داخلی از Redis پشتیبانی میکند.
تنظیمات Redis را می توانید در فایل
config/database.php
بررسی کنید.در این دوره استفاده از ردیس به طور کامل بررسی نمی شود، اما تمامی متد های ردیس از فساد Redis در دسترس هستند:
use Illuminate\Support\Facades\Redis;
Redis::set('key', 'value');
$value = Redis::get('key');
🔖 #Laravel, #PHP, #فصل_۵, #لاراول
👤 AmirHossein
💎 Channel: @DevelopixLaravel
Forwarded from | کانال توسعهدهندگان PHP |
❓ خروجی حلقه کدام است؟
1️⃣ Error
2️⃣ 10 9 8 7 6 5 4 3 2 1
3️⃣ Warning
4️⃣ 9 8 7 6 5 4 3 2 1 0
✅ پاسخ خود را همراه با توضیح ارائه دهید.
❗ بدون اجرای کد یا استفاده از هوش مصنوعی، کمی فکر کنید.
🔖 #PHP, #پی_اچ_پی, #چالش
👤 AmirHossein
💎 Channel: @DevelopixPHP
1️⃣ Error
2️⃣ 10 9 8 7 6 5 4 3 2 1
3️⃣ Warning
4️⃣ 9 8 7 6 5 4 3 2 1 0
✅ پاسخ خود را همراه با توضیح ارائه دهید.
❗ بدون اجرای کد یا استفاده از هوش مصنوعی، کمی فکر کنید.
🔖 #PHP, #پی_اچ_پی, #چالش
👤 AmirHossein
💎 Channel: @DevelopixPHP
Forwarded from | کانال توسعهدهندگان PHP |
🔰 در این سوال نکات زیادی حائز اهمیت است که معمولا در نظر گرفته نمیشود.
🔍 در ادامه، ساختار حلقه را بهطور مفصل بررسی میکنیم:
خروجی این حلقه بهصورت زیر خواهد بود:
⁉️ اما چرا؟
بیایید ساختار حلقه را از ابتدا بررسی کنیم.
🔰 ساختار کلی حلقه for
حلقه for از سه بخش تشکیل شده است:
1- شروع: مقداردهی اولیه متغیر حلقه.
این بخش تنها یک بار در ابتدای حلقه اجرا میشود.
2- شرط ادامه: تعیین میکند که آیا حلقه ادامه یابد یا متوقف شود.
این بخش در هر تکرار، قبل از اجرای بدنه اجرا شده و شرط اجرای بدنه را بررسی میکند.
3- تغییر مقدار: مقدار متغیر حلقه را تغییر میدهد.
این بخش پس از اجرای بدنه حلقه اجرا میشود.
🔰 بررسی اجرای حلقه ذکر شده
1- مقداردهی اولیه:
- ابتدا متغیر
2- بررسی شرط (
در این قسمت نکات مهمی وجود دارد:
- هر عدد به جز 0 مقدار true دارد، بنابراین تا زمانی که
- در عبارت
- - به همین دلیل عدد 0 نیز چاپ خواهد شد.
- - مقدار
اگر حلقه به این صورت نوشته میشد:
در این حالت، ابتدا مقدار
3- بررسی قسمت سوم (تغییر مقدار update)
- بخش سوم این حلقه روی مقدار
🔰 مرور روند اجرای حلقه ذکر شده
- مقدار دهی اولیه i با 10
- بررسی 10 == true، کاهش 10 به 9، چاپ 9
- بررسی 9 == true، کاهش 9 به 8، چاپ 8
.
.
.
- بررسی 2 == true، کاهش 2 به 1، چاپ 1
- بررسی 1 == true، کاهش 1 به 0، چاپ 0
- بررسی 0 == true، پایان حلقه
❗️ درک درست post-decrement ($i--) و pre-decrement (--$i) در حلقهها اهمیت زیادی دارد و تفاوتهای ظریفی در خروجی ایجاد میکند.
🔖 #PHP, #پی_اچ_پی, #چالش
👤 AmirHossein
💎 Channel: @DevelopixPHP
🔍 در ادامه، ساختار حلقه را بهطور مفصل بررسی میکنیم:
for ($i = 10; $i--; $i > 0) {
echo "$i ";
}
خروجی این حلقه بهصورت زیر خواهد بود:
9 8 7 6 5 4 3 2 1 0
⁉️ اما چرا؟
بیایید ساختار حلقه را از ابتدا بررسی کنیم.
🔰 ساختار کلی حلقه for
حلقه for از سه بخش تشکیل شده است:
1- شروع: مقداردهی اولیه متغیر حلقه.
این بخش تنها یک بار در ابتدای حلقه اجرا میشود.
2- شرط ادامه: تعیین میکند که آیا حلقه ادامه یابد یا متوقف شود.
این بخش در هر تکرار، قبل از اجرای بدنه اجرا شده و شرط اجرای بدنه را بررسی میکند.
3- تغییر مقدار: مقدار متغیر حلقه را تغییر میدهد.
این بخش پس از اجرای بدنه حلقه اجرا میشود.
🔰 بررسی اجرای حلقه ذکر شده
1- مقداردهی اولیه:
- ابتدا متغیر
$i
مقدار 10 میگیرد و اجرای این بخش پایان مییابد.2- بررسی شرط (
$i--
)در این قسمت نکات مهمی وجود دارد:
- هر عدد به جز 0 مقدار true دارد، بنابراین تا زمانی که
$i
به 0 نرسد، حلقه ادامه خواهد داشت.- در عبارت
$i--
از عملیات post-decrement استفاده شده است، یعنی ابتدا مقدار فعلی $i
برای بررسی شرط استفاده میشود، سپس مقدار $i
کاهش مییابد.- - به همین دلیل عدد 0 نیز چاپ خواهد شد.
- - مقدار
$i
بعد از کاهش وارد بدنه حلقه میشود، بنابراین چاپ اعداد از 9 شروع میشود.اگر حلقه به این صورت نوشته میشد:
for ($i = 10; --$i; $i > 0) {
echo "$i ";
}
در این حالت، ابتدا مقدار
$i
کاهش مییابد و سپس شرط بررسی میشود زیرا از عملیات pre-decrement، بنابراین 0 چاپ نمیشود و خروجی به این شکل خواهد بود:9 8 7 6 5 4 3 2 1
3- بررسی قسمت سوم (تغییر مقدار update)
- بخش سوم این حلقه روی مقدار
$i
تغییری ایجاد نمیکند، بنابراین عملاً بیاثر است و میتوان حلقه را سادهتر نوشت:for ($i = 10; $i--;) {
echo "$i ";
}
🔰 مرور روند اجرای حلقه ذکر شده
- مقدار دهی اولیه i با 10
- بررسی 10 == true، کاهش 10 به 9، چاپ 9
- بررسی 9 == true، کاهش 9 به 8، چاپ 8
.
.
.
- بررسی 2 == true، کاهش 2 به 1، چاپ 1
- بررسی 1 == true، کاهش 1 به 0، چاپ 0
- بررسی 0 == true، پایان حلقه
❗️ درک درست post-decrement ($i--) و pre-decrement (--$i) در حلقهها اهمیت زیادی دارد و تفاوتهای ظریفی در خروجی ایجاد میکند.
🔖 #PHP, #پی_اچ_پی, #چالش
👤 AmirHossein
💎 Channel: @DevelopixPHP
Forwarded from Developix Support
🥳مسابقۀ ۱۰۰ میلیونی ساخت بات در اپلیکیشن بله!🦾
💰 مسابقهای برای ساخت بازو (بات) و مینیاپ در اپلیکیشن بله
🎯 از استعدادت پول در بیار!
❓چطوری؟
بله با مسابقهٔ «زور بازوت رو نشون بده!» یک فرصت عالی برای مهندسین نرمافزار، وب دولوپرها، صاحبان سایتها و اپلیکیشنها و تیمهای محصول فراهم کرده که پاسخگوی این دغدغههاست.
🎁 یه مسابقه با ۱۰۰ میلیون تومن جایزهٔ نقدی و ۱ میلیارد تومن اعتبار تبلیغات منتظرته! ♨️
📎 همین الان در مسابقه ثبتنام کن! ➡️
💬 کانال اخبار بازو دراپلیکیشن بله
کانال اطلاعرسانی بله | @BaleMessenger
💰 مسابقهای برای ساخت بازو (بات) و مینیاپ در اپلیکیشن بله
🎯 از استعدادت پول در بیار!
❓چطوری؟
بله با مسابقهٔ «زور بازوت رو نشون بده!» یک فرصت عالی برای مهندسین نرمافزار، وب دولوپرها، صاحبان سایتها و اپلیکیشنها و تیمهای محصول فراهم کرده که پاسخگوی این دغدغههاست.
🎁 یه مسابقه با ۱۰۰ میلیون تومن جایزهٔ نقدی و ۱ میلیارد تومن اعتبار تبلیغات منتظرته! ♨️
📎 همین الان در مسابقه ثبتنام کن! ➡️
💬 کانال اخبار بازو دراپلیکیشن بله
کانال اطلاعرسانی بله | @BaleMessenger
فصل شش - Requests and Response
بخش اول - پردازش درخواست و پاسخ
در فریمورک لاراول، مفاهیم Request (درخواست) و Response (پاسخ) جزو مهمترین اجزای پردازش درخواستهای وب محسوب میشوند. این دو مفهوم در الگوی MVC بخش ارتباط بین کاربر (Client) و سرور (Backend) را مدیریت میکنند.
1- درخواست (Request)
Request در لاراول به تمام دادههایی گفته میشود که از طرف کاربر (مثلاً مرورگر، Postman یا یک کلاینت دیگر) به سرور ارسال میشود. این دادهها میتوانند شامل موارد زیر باشند:
- دادههای فرم (POST)
- پارامترهای URL (GET)
- هدرهای HTTP
- کوکیها
- فایلهای آپلود شده
- اطلاعات احراز هویت
لاراول برای مدیریت درخواستها از کلاس Illuminate\Http\Request استفاده میکند که قابلیتهای زیادی برای دسترسی و فیلتر کردن دادههای ورودی دارد.
در کنترلرها، برای دریافت اطلاعات ورودی، میتوان از کلاس Request استفاده کرد:
2- پاسخ (Response)
Response یا پاسخ، همان دادهای است که لاراول پس از پردازش درخواست به کلاینت ارسال میکند. این پاسخ میتواند شامل:
- HTML یا View
- JSON یا API Response
- ریدارکت (Redirect)
- دانلود فایل
- ارسال پیامهای خطا یا موفقیت باشد.
در کنترلرها، برای ارسال پاسخ، میتوان از فساد یا هلپر Response استفاده کرد:
در ادامه این بخش به بررسی Request و Response و تمامی متد های در دسترس از آنها خواهیم پرداخت.
🔖 #Laravel, #PHP, #فصل_۶, #لاراول
👤 AmirHossein
💎 Channel: @DevelopixLaravel
بخش اول - پردازش درخواست و پاسخ
در فریمورک لاراول، مفاهیم Request (درخواست) و Response (پاسخ) جزو مهمترین اجزای پردازش درخواستهای وب محسوب میشوند. این دو مفهوم در الگوی MVC بخش ارتباط بین کاربر (Client) و سرور (Backend) را مدیریت میکنند.
1- درخواست (Request)
Request در لاراول به تمام دادههایی گفته میشود که از طرف کاربر (مثلاً مرورگر، Postman یا یک کلاینت دیگر) به سرور ارسال میشود. این دادهها میتوانند شامل موارد زیر باشند:
- دادههای فرم (POST)
- پارامترهای URL (GET)
- هدرهای HTTP
- کوکیها
- فایلهای آپلود شده
- اطلاعات احراز هویت
لاراول برای مدیریت درخواستها از کلاس Illuminate\Http\Request استفاده میکند که قابلیتهای زیادی برای دسترسی و فیلتر کردن دادههای ورودی دارد.
در کنترلرها، برای دریافت اطلاعات ورودی، میتوان از کلاس Request استفاده کرد:
class UserController extends Controller
{
public function store(Request $request)
{
$name = $request->input('name');
$email = $request->input('email', 'default@example.com');
$data = $request->all();
$token = $request->header('Authorization');
}
}
2- پاسخ (Response)
Response یا پاسخ، همان دادهای است که لاراول پس از پردازش درخواست به کلاینت ارسال میکند. این پاسخ میتواند شامل:
- HTML یا View
- JSON یا API Response
- ریدارکت (Redirect)
- دانلود فایل
- ارسال پیامهای خطا یا موفقیت باشد.
در کنترلرها، برای ارسال پاسخ، میتوان از فساد یا هلپر Response استفاده کرد:
class UserController extends Controller
{
public function store(Request $request)
{
return response('Hello, Laravel!');
return response()->json([
'message' => 'Success',
'status' => 200
]);
return response()->view('welcome', ['name' => 'John']);
}
}
در ادامه این بخش به بررسی Request و Response و تمامی متد های در دسترس از آنها خواهیم پرداخت.
🔖 #Laravel, #PHP, #فصل_۶, #لاراول
👤 AmirHossein
💎 Channel: @DevelopixLaravel
فصل شش - Requests and Response
بخش اول - پردازش درخواست و پاسخ
لاراول برای مدیریت درخواستها از کلاس Illuminate\Http\Request استفاده میکند که قابلیتهای زیادی برای دسترسی و فیلتر کردن دادههای ورودی دارد.
این کلاس معمولا در Controller ها یا Route-Closure ها استفاده می شود:
در ادامه با متد های در دسترس از این کلاس آشنا می شویم.
1- متد path
این متد مسیر درخواست شده را بدون دامنه برمیگرداند.
2- متد is
بررسی میکند که مسیر درخواست با یک الگو مطابقت دارد یا نه.
3- متد routeIs
بررسی میکند که مسیر درخواست با نام روت خاصی مطابقت دارد یا نه.
4- متد url
آدرس کامل بدون query string را برمیگرداند.
5- متد fullUrl
آدرس کامل شامل query string را برمیگرداند.
6- متد fullUrlWithQuery
یک پارامتر کوئری را به URL اضافه میکند.
7- متد fullUrlWithoutQuery
برخی از پارامترهای کوئری را از URL حذف میکند.
8- متد host
دامنه درخواست را برمیگرداند.
9- متد httpHost
دامنه همراه با پورت را برمیگرداند.
10- متد schemeAndHttpHost
پروتکل (http یا https) و دامنه را برمیگرداند.
11- متد ip
آدرس IP درخواستدهنده را برمیگرداند.
12- متد ips
لیست IPهای درخواستدهنده را برمیگرداند.
13- متد method
متد HTTP درخواست (GET, POST, PUT, DELETE) را برمیگرداند.
14- متد isMethod
بررسی میکند که متد HTTP درخواست مقدار خاصی دارد یا نه.
15- متد header
مقدار یک هدر خاص را برمیگرداند.
16- متد hasHeader
بررسی میکند که آیا یک هدر مشخص در درخواست وجود دارد یا نه.
17- متد bearerToken
مقدار Bearer Token در هدر Authorization را برمیگرداند.
18- متد getAcceptableContentTypes
لیستی از انواع محتوای مورد قبول در هدر Accept را برمیگرداند.
19- متد accepts
بررسی میکند که آیا نوع محتوای مشخصشده پذیرفته شده است یا نه.
20- متد prefers
نوع محتوای ترجیحی را برمیگرداند.
21- متد expectsJson
بررسی میکند که آیا درخواست انتظار JSON دارد یا نه.
22- متد flash
دادهها را برای درخواست بعدی در سشن ذخیره میکند.
23- متد flashOnly
برخی از دادهها را در سشن ذخیره میکند.
24- متد flashExcept
تمام دادهها بهجز موارد مشخصشده را در سشن ذخیره میکند.
25- متد only
فقط مقادیر مشخصشده را از درخواست دریافت میکند.
26- متد except
تمام مقادیر درخواست بهجز موارد مشخصشده را دریافت میکند.
سایر متد ها در پست بعدی توضیح داده میشود.
🔖 #Laravel, #PHP, #فصل_۶, #لاراول
👤 AmirHossein
💎 Channel: @DevelopixLaravel
بخش اول - پردازش درخواست و پاسخ
لاراول برای مدیریت درخواستها از کلاس Illuminate\Http\Request استفاده میکند که قابلیتهای زیادی برای دسترسی و فیلتر کردن دادههای ورودی دارد.
این کلاس معمولا در Controller ها یا Route-Closure ها استفاده می شود:
class UserController extends Controller
{
public function store(Request $request)
{
$request->...
}
}
// OR
Route::get('/', function(Request $request) {
$request->...
});
در ادامه با متد های در دسترس از این کلاس آشنا می شویم.
1- متد path
این متد مسیر درخواست شده را بدون دامنه برمیگرداند.
$request->path(); // posts/10
2- متد is
بررسی میکند که مسیر درخواست با یک الگو مطابقت دارد یا نه.
if ($request->is('posts/*')) {
}
3- متد routeIs
بررسی میکند که مسیر درخواست با نام روت خاصی مطابقت دارد یا نه.
if ($request->routeIs('post.show')) {
}
4- متد url
آدرس کامل بدون query string را برمیگرداند.
$request->url(); // http://example.com/posts/10
5- متد fullUrl
آدرس کامل شامل query string را برمیگرداند.
$request->fullUrl();
// http://example.com/posts/10?sort=desc
6- متد fullUrlWithQuery
یک پارامتر کوئری را به URL اضافه میکند.
$request->fullUrlWithQuery(['page' => 2]);
// http://example.com/posts?sort=desc&page=2
7- متد fullUrlWithoutQuery
برخی از پارامترهای کوئری را از URL حذف میکند.
$request->fullUrlWithoutQuery(['sort']);
// http://example.com/posts?page=2
8- متد host
دامنه درخواست را برمیگرداند.
$request->host(); // example.com
9- متد httpHost
دامنه همراه با پورت را برمیگرداند.
$request->httpHost(); // example.com:8080
10- متد schemeAndHttpHost
پروتکل (http یا https) و دامنه را برمیگرداند.
$request->schemeAndHttpHost();
// https://example.com
11- متد ip
آدرس IP درخواستدهنده را برمیگرداند.
$request->ip(); // 192.168.1.1
12- متد ips
لیست IPهای درخواستدهنده را برمیگرداند.
$request->ips();
// [192.168.1.1, 10.0.0.2]
13- متد method
متد HTTP درخواست (GET, POST, PUT, DELETE) را برمیگرداند.
$request->method(); // POST
14- متد isMethod
بررسی میکند که متد HTTP درخواست مقدار خاصی دارد یا نه.
if ($request->isMethod('post')) {
}
15- متد header
مقدار یک هدر خاص را برمیگرداند.
$request->header('User-Agent'); // "Mozilla/5.0"
16- متد hasHeader
بررسی میکند که آیا یک هدر مشخص در درخواست وجود دارد یا نه.
if ($request->hasHeader('Authorization')) {
}
17- متد bearerToken
مقدار Bearer Token در هدر Authorization را برمیگرداند.
$request->bearerToken();
18- متد getAcceptableContentTypes
لیستی از انواع محتوای مورد قبول در هدر Accept را برمیگرداند.
$request->getAcceptableContentTypes();
// ['application/json', 'text/html']
19- متد accepts
بررسی میکند که آیا نوع محتوای مشخصشده پذیرفته شده است یا نه.
if ($request->accepts('application/json')) {
}
20- متد prefers
نوع محتوای ترجیحی را برمیگرداند.
$request->prefers(['text/html', 'application/json']);
21- متد expectsJson
بررسی میکند که آیا درخواست انتظار JSON دارد یا نه.
if ($request->expectsJson()) {
}
22- متد flash
دادهها را برای درخواست بعدی در سشن ذخیره میکند.
$request->flash();
23- متد flashOnly
برخی از دادهها را در سشن ذخیره میکند.
$request->flashOnly(['name', 'email']);
24- متد flashExcept
تمام دادهها بهجز موارد مشخصشده را در سشن ذخیره میکند.
$request->flashExcept(['password']);
25- متد only
فقط مقادیر مشخصشده را از درخواست دریافت میکند.
$request->only(['name', 'email']);
26- متد except
تمام مقادیر درخواست بهجز موارد مشخصشده را دریافت میکند.
$request->except(['password']);
سایر متد ها در پست بعدی توضیح داده میشود.
🔖 #Laravel, #PHP, #فصل_۶, #لاراول
👤 AmirHossein
💎 Channel: @DevelopixLaravel
فصل شش - Requests and Response
بخش اول - پردازش درخواست و پاسخ
در این قسمت به سایر متدهای در دسترس از کلاس Request می پردازیم.
1- متد cookie
مقدار یک کوکی را برمیگرداند.
2- متد all
تمام دادههای ورودی (query parameters، POST data، JSON payloads) را بهصورت آرایه برمیگرداند.
3- متد collect
دادههای ورودی را بهعنوان Collection لاراول برمیگرداند.
کالکشنها در لاراول مجموعهای از دادهها هستند که امکانات پیشرفتهای برای کار با آرایهها ارائه میدهند.
در فصل های مربوطه به کار با کالکشن ها خواهیم پرداخت.
4- متد input
مقدار یک ورودی خاص را دریافت میکند.
همچنین می توان input مورد نظر را به صورت پراپرتی دریافت کرد:
5- متد query
مقدار یک متغیر در query string را دریافت میکند.
پارامتر اول کلید کوئری و پارامتر دوم مقدار پیشفرض می باشد.
6- متد string
مقدار یک ورودی را بهعنوان Stringable لاراول برمیگرداند.
در لاراول Stringable همانند کالکشن که برای کار با آرایه ها است، برای کار با رشته ها می باشد.
این متد input با نام name را در قالب شئ از Stringable باز می گرداند و می توان متد های زیادی را بر روی آن فراخوانی کرد:
7- متد integer
مقدار ورودی را به عدد صحیح (integer) تبدیل میکند.
8- متد boolean
مقدار ورودی را به مقدار بولی (true یا false) تبدیل میکند.
9- متد date
مقدار ورودی را به شیء Carbon تبدیل میکند.
کربن نیز یک کلاس برای کار با زمان ها می باشد.
10- متد enum
مقدار ورودی را با یک enum مقایسه میکند.
11- متد enums
چند مقدار ورودی را با یک enum بررسی میکند.
12- متد has
بررسی میکند که آیا مقدار مشخصی در درخواست وجود دارد یا نه.
13- متد hasAny
بررسی میکند که آیا حداقل یکی از مقادیر مشخصشده در درخواست وجود دارد یا نه.
14- متد whenHas
اگر مقدار مشخصشده در درخواست وجود داشته باشد، یک تابع را اجرا میکند.
15- متد isNotFilled
بررسی میکند که مقدار ورودی وجود نداشته باشد یا خالی باشد.
16- متد filled
بررسی میکند که مقدار مشخصشده در درخواست پر شده باشد.
17- متد anyFilled
بررسی میکند که حداقل یکی از مقادیر مشخصشده در درخواست پر شده باشد.
18- متد whenFilled
اگر مقدار مشخصشده در درخواست پر شده باشد، یک تابع را اجرا میکند.
19- متد missing
بررسی میکند که مقدار مشخصشده در درخواست وجود نداشته باشد.
20- متد whenMissing
اگر مقدار مشخصشده در درخواست وجود نداشته باشد، یک تابع را اجرا میکند.
21- متد merge
مقدار جدیدی به دادههای درخواست اضافه میکند.
22- متد mergeIfMissing
مقدار جدیدی را فقط در صورتی که وجود نداشته باشد اضافه میکند.
23- متد file
یک فایل آپلودی را در قالب شئ از فایل دریافت میکند و می توان عملیات های مختلف مانند ذخیره سازی بر روی آن اجرا کرد.
24- متد hasFile
بررسی میکند که آیا فایلی آپلود شده است یا نه.
25- متد old
مقدار یک ورودی را از session دریافت میکند. (معمولا درخواست قبلی)
تا اینجا با تمامی متد های قابل فراخوانی از کلاس Request آشنا شده ایم، در قسمت بعدی به متد های Response خواهیم پرداخت.
🔖 #Laravel, #PHP, #فصل_۶, #لاراول
👤 AmirHossein
💎 Channel: @DevelopixLaravel
بخش اول - پردازش درخواست و پاسخ
در این قسمت به سایر متدهای در دسترس از کلاس Request می پردازیم.
1- متد cookie
مقدار یک کوکی را برمیگرداند.
$value = $request->cookie('user_token');
2- متد all
تمام دادههای ورودی (query parameters، POST data، JSON payloads) را بهصورت آرایه برمیگرداند.
$data = $request->all();
3- متد collect
دادههای ورودی را بهعنوان Collection لاراول برمیگرداند.
کالکشنها در لاراول مجموعهای از دادهها هستند که امکانات پیشرفتهای برای کار با آرایهها ارائه میدهند.
در فصل های مربوطه به کار با کالکشن ها خواهیم پرداخت.
$collection = $request->collect();
4- متد input
مقدار یک ورودی خاص را دریافت میکند.
$name = $request->input('name');
همچنین می توان input مورد نظر را به صورت پراپرتی دریافت کرد:
$name = $request->name;
5- متد query
مقدار یک متغیر در query string را دریافت میکند.
$sort = $request->query('sort', 'asc');
پارامتر اول کلید کوئری و پارامتر دوم مقدار پیشفرض می باشد.
6- متد string
مقدار یک ورودی را بهعنوان Stringable لاراول برمیگرداند.
در لاراول Stringable همانند کالکشن که برای کار با آرایه ها است، برای کار با رشته ها می باشد.
$name = $request->string('name');
این متد input با نام name را در قالب شئ از Stringable باز می گرداند و می توان متد های زیادی را بر روی آن فراخوانی کرد:
$name = $request->string('name')->upper();
7- متد integer
مقدار ورودی را به عدد صحیح (integer) تبدیل میکند.
$age = $request->integer('age');
8- متد boolean
مقدار ورودی را به مقدار بولی (true یا false) تبدیل میکند.
$active = $request->boolean('active');
9- متد date
مقدار ورودی را به شیء Carbon تبدیل میکند.
کربن نیز یک کلاس برای کار با زمان ها می باشد.
$birthday = $request->date('birthday');
10- متد enum
مقدار ورودی را با یک enum مقایسه میکند.
$status = $request->enum('status', OrderStatus::class);
11- متد enums
چند مقدار ورودی را با یک enum بررسی میکند.
$statuses = $request->enums('statuses', OrderStatus::class);
12- متد has
بررسی میکند که آیا مقدار مشخصی در درخواست وجود دارد یا نه.
if ($request->has('name')) {
}
13- متد hasAny
بررسی میکند که آیا حداقل یکی از مقادیر مشخصشده در درخواست وجود دارد یا نه.
if ($request->hasAny(['name', 'email'])) {
}
14- متد whenHas
اگر مقدار مشخصشده در درخواست وجود داشته باشد، یک تابع را اجرا میکند.
$request->whenHas('name', function ($name) {
});
15- متد isNotFilled
بررسی میکند که مقدار ورودی وجود نداشته باشد یا خالی باشد.
if ($request->isNotFilled('email')) {
}
16- متد filled
بررسی میکند که مقدار مشخصشده در درخواست پر شده باشد.
if ($request->filled('email')) {
}
17- متد anyFilled
بررسی میکند که حداقل یکی از مقادیر مشخصشده در درخواست پر شده باشد.
if ($request->anyFilled(['email', 'phone'])) {
}
18- متد whenFilled
اگر مقدار مشخصشده در درخواست پر شده باشد، یک تابع را اجرا میکند.
$request->whenFilled('email', function ($email) {
});
19- متد missing
بررسی میکند که مقدار مشخصشده در درخواست وجود نداشته باشد.
if ($request->missing('email')) {
}
20- متد whenMissing
اگر مقدار مشخصشده در درخواست وجود نداشته باشد، یک تابع را اجرا میکند.
$request->whenMissing('email', function () {
});
21- متد merge
مقدار جدیدی به دادههای درخواست اضافه میکند.
$request->merge(['role' => 'admin']);
22- متد mergeIfMissing
مقدار جدیدی را فقط در صورتی که وجود نداشته باشد اضافه میکند.
$request->mergeIfMissing(['role' => 'user']);
23- متد file
یک فایل آپلودی را در قالب شئ از فایل دریافت میکند و می توان عملیات های مختلف مانند ذخیره سازی بر روی آن اجرا کرد.
$file = $request->file('avatar');
24- متد hasFile
بررسی میکند که آیا فایلی آپلود شده است یا نه.
if ($request->hasFile('avatar')) {
}
25- متد old
مقدار یک ورودی را از session دریافت میکند. (معمولا درخواست قبلی)
$oldValue = $request->old('name');
تا اینجا با تمامی متد های قابل فراخوانی از کلاس Request آشنا شده ایم، در قسمت بعدی به متد های Response خواهیم پرداخت.
🔖 #Laravel, #PHP, #فصل_۶, #لاراول
👤 AmirHossein
💎 Channel: @DevelopixLaravel
فصل شش - Requests and Response
بخش اول - پردازش درخواست و پاسخ
در این قسمت به متدهای Response خواهیم پرداخت.
ریسپانسها، پاسخی هستند ک از سوی کنترلرها برای کلاینت return میشوند.
کد بالا یک نمونه از شیوه ارسال ریسپانس را نشان میدهد که یک متن پس از ذخیره کاربر، به سمت مرورگر کلاینت ارسال می شود.
معمولا برای ارسال ریسپانس از هلپر فانکشن ها استفاده می شود.
در ادامه با این هلپر ها آشنا می شویم.
1- متد response
ایجاد یک پاسخ ساده.
متن "Hello, World!" در مرورگر نمایش داده میشود.
2- متد header
افزودن یک هدر (header) به پاسخ.
3- متد withHeaders
افزودن چندین header به پاسخ.
4- متد cookie
اضافه کردن cookie به پاسخ.
5- متد withoutCookie
حذف یک cookie از پاسخ.
6- متد view
بازگرداندن یک view به عنوان پاسخ. (فایل های Blade)
نمای welcome.blade.php نمایش داده میشود.
7- متد json
بازگرداندن یک JSON به عنوان پاسخ.
8- متد withCallback
اضافه کردن JSONP callback به پاسخ JSON.
9- متد download
دانلود یک فایل از سرور.
10- متد file
نمایش یک فایل بدون دانلود.
11- متد stream
استریم دادهها (ارسال محتوا به صورت chunk-شده).
12- متد streamJson
ارسال JSON بهصورت استریم.
13- متد eventStream
ارسال دادهها بهصورت Server-Sent Events (SSE).
14- متد streamDownload
دانلود یک فایل بهصورت stream.
15- متد redirect
تغییر مسیر (redirect) به یک URL.
16- متد route
تغییر مسیر (redirect) به یک route.
17- متد action
تغییر مسیر (redirect) به یک controller action.
18- متد away
تغییر مسیر (redirect) به یک URL خارجی.
19- متد with
ارسال دادههای session همراه با redirect.
یک message در session ذخیره میشود و پس از redirect قابل دسترسی است.
20- متد back
بازگشت به صفحهی قبلی.
21- متد withInput
ارسال دادههای form input در session هنگام redirect.
🔖 #Laravel, #PHP, #فصل_۶, #لاراول
👤 AmirHossein
💎 Channel: @DevelopixLaravel
بخش اول - پردازش درخواست و پاسخ
در این قسمت به متدهای Response خواهیم پرداخت.
ریسپانسها، پاسخی هستند ک از سوی کنترلرها برای کلاینت return میشوند.
class UserController extends Controller
{
public function store(Request $request)
{
// ...
return response("User Stored!");
}
}
کد بالا یک نمونه از شیوه ارسال ریسپانس را نشان میدهد که یک متن پس از ذخیره کاربر، به سمت مرورگر کلاینت ارسال می شود.
معمولا برای ارسال ریسپانس از هلپر فانکشن ها استفاده می شود.
در ادامه با این هلپر ها آشنا می شویم.
1- متد response
ایجاد یک پاسخ ساده.
return response('Hello, World!');
متن "Hello, World!" در مرورگر نمایش داده میشود.
2- متد header
افزودن یک هدر (header) به پاسخ.
return response('OK')->header('X-Custom-Header', 'MyValue');
3- متد withHeaders
افزودن چندین header به پاسخ.
return response('Headers Set')->withHeaders([
'X-Header-One' => 'Value1',
'X-Header-Two' => 'Value2',
]);
4- متد cookie
اضافه کردن cookie به پاسخ.
return response('Cookie Set')->cookie('user', 'JohnDoe', 60);
5- متد withoutCookie
حذف یک cookie از پاسخ.
return response('Cookie Removed')->withoutCookie('user');
6- متد view
بازگرداندن یک view به عنوان پاسخ. (فایل های Blade)
return response()->view('welcome');
نمای welcome.blade.php نمایش داده میشود.
7- متد json
بازگرداندن یک JSON به عنوان پاسخ.
return response()->json(['name' => 'John', 'age' => 30]);
8- متد withCallback
اضافه کردن JSONP callback به پاسخ JSON.
return response()->json(['name' => 'John'])->withCallback('myCallback');
// Output:
// myCallback({"name":"John"});
9- متد download
دانلود یک فایل از سرور.
return response()->download(storage_path('app/file.pdf'));
10- متد file
نمایش یک فایل بدون دانلود.
return response()->file(storage_path('app/image.jpg'));
11- متد stream
استریم دادهها (ارسال محتوا به صورت chunk-شده).
return response()->stream(function () {
echo 'Streaming content...';
});
12- متد streamJson
ارسال JSON بهصورت استریم.
return response()->streamJson(['status' => 'processing']);
13- متد eventStream
ارسال دادهها بهصورت Server-Sent Events (SSE).
return response()->eventStream(function ($stream) {
$stream->push(['message' => 'Hello, World!']);
});
14- متد streamDownload
دانلود یک فایل بهصورت stream.
return response()->streamDownload(function () {
echo 'File content...';
}, 'myfile.txt');
15- متد redirect
تغییر مسیر (redirect) به یک URL.
return redirect('/home');
16- متد route
تغییر مسیر (redirect) به یک route.
return redirect()->route('dashboard');
17- متد action
تغییر مسیر (redirect) به یک controller action.
return redirect()->action([HomeController::class, 'index']);
18- متد away
تغییر مسیر (redirect) به یک URL خارجی.
return redirect()->away('https://google.com');
19- متد with
ارسال دادههای session همراه با redirect.
return redirect()->route('home')->with('message', 'Welcome back!');
یک message در session ذخیره میشود و پس از redirect قابل دسترسی است.
20- متد back
بازگشت به صفحهی قبلی.
return redirect()->back();
21- متد withInput
ارسال دادههای form input در session هنگام redirect.
return redirect()->back()->withInput();
🔖 #Laravel, #PHP, #فصل_۶, #لاراول
👤 AmirHossein
💎 Channel: @DevelopixLaravel
فصل شش - Requests and Response
بخش دوم - اعتبارسنجی درخواست ها
لاراول یک سیستم اعتبارسنجی قدرتمند و انعطافپذیر ارائه میدهد که به شما امکان میدهد دادهها را به راحتی بررسی کرده و از ورود اطلاعات نامعتبر جلوگیری کنید.
اعتبارسنجی میتواند به روشهای مختلفی انجام شود:
1- استفاده از متد validate در کنترلر
این روش برای اعتبارسنجی ساده استفاده میشود. اگر دادهها نامعتبر باشند، لاراول بهصورت خودکار یک پاسخ خطا ارسال میکند.
2- استفاده از کلاسهای درخواست سفارشی (Form Request Validation)
برای پروژههای بزرگ، بهتر است قوانین اعتبارسنجی را در یک کلاس مجزا تعریف کنید:
سپس در کلاس ایجاد شده، قوانین را در متد rules مشخص کنید.
ایجاد قوانین سفارشی (Custom Rules)
علاوه بر قوانین پیشفرض لاراول، میتوان قوانین سفارشی نیز ایجاد کرد. این ویژگی زمانی مفید است که نیاز به اعتبارسنجی خاصی داشته باشید که در قوانین پیشفرض موجود نیست.
در کلاس ValidUsername میتوان منطق اعتبارسنجی را تعریف و در پروژه استفاده کرد.
سفارشیسازی پیامهای خطا
لاراول به شما اجازه میدهد تا پیامهای خطای اعتبارسنجی را شخصیسازی کنید:
این ویژگی برای چندزبانه کردن پیامهای خطا نیز بسیار مفید است.
سیستم اعتبارسنجی در لاراول بسیار قدرتمند، انعطافپذیر و ساده است. با استفاده از روشهای مختلف مانند Form Request Validation، Custom Rules و شخصیسازی پیامهای خطا، میتوان دادههای ورودی را به شکلی بهینه مدیریت کرد و از بروز خطاهای امنیتی و عملکردی جلوگیری کرد.
در پستهای بعدی، به بررسی دقیقتر ساختار ولیدیشنها و نحوهی پیادهسازی قوانین سفارشی میپردازیم.
🔖 #Laravel, #PHP, #فصل_۶, #لاراول
👤 AmirHossein
💎 Channel: @DevelopixLaravel
بخش دوم - اعتبارسنجی درخواست ها
لاراول یک سیستم اعتبارسنجی قدرتمند و انعطافپذیر ارائه میدهد که به شما امکان میدهد دادهها را به راحتی بررسی کرده و از ورود اطلاعات نامعتبر جلوگیری کنید.
اعتبارسنجی میتواند به روشهای مختلفی انجام شود:
1- استفاده از متد validate در کنترلر
$request->validate([
'name' => 'required|string|max:255',
'email' => 'required|email|unique:users',
'password' => 'required|min:8'
]);
این روش برای اعتبارسنجی ساده استفاده میشود. اگر دادهها نامعتبر باشند، لاراول بهصورت خودکار یک پاسخ خطا ارسال میکند.
2- استفاده از کلاسهای درخواست سفارشی (Form Request Validation)
برای پروژههای بزرگ، بهتر است قوانین اعتبارسنجی را در یک کلاس مجزا تعریف کنید:
php artisan make:request RegisterRequest
سپس در کلاس ایجاد شده، قوانین را در متد rules مشخص کنید.
public function rules(): array
{
return [
'title' => 'required|unique:posts|max:255',
'body' => 'required',
];
}
ایجاد قوانین سفارشی (Custom Rules)
علاوه بر قوانین پیشفرض لاراول، میتوان قوانین سفارشی نیز ایجاد کرد. این ویژگی زمانی مفید است که نیاز به اعتبارسنجی خاصی داشته باشید که در قوانین پیشفرض موجود نیست.
php artisan make:rule ValidUsername
در کلاس ValidUsername میتوان منطق اعتبارسنجی را تعریف و در پروژه استفاده کرد.
public function validate(string $attribute, mixed $value, Closure $fail): void
{
if (strtoupper($value) !== $value) {
$fail('The :attribute must be uppercase.');
}
}
سفارشیسازی پیامهای خطا
لاراول به شما اجازه میدهد تا پیامهای خطای اعتبارسنجی را شخصیسازی کنید:
$messages = [
'email.required' => 'Entering an email is required.',
'password.min' => 'The password must be at least 8 characters.',
];
$request->validate($rules, $messages);
این ویژگی برای چندزبانه کردن پیامهای خطا نیز بسیار مفید است.
سیستم اعتبارسنجی در لاراول بسیار قدرتمند، انعطافپذیر و ساده است. با استفاده از روشهای مختلف مانند Form Request Validation، Custom Rules و شخصیسازی پیامهای خطا، میتوان دادههای ورودی را به شکلی بهینه مدیریت کرد و از بروز خطاهای امنیتی و عملکردی جلوگیری کرد.
در پستهای بعدی، به بررسی دقیقتر ساختار ولیدیشنها و نحوهی پیادهسازی قوانین سفارشی میپردازیم.
🔖 #Laravel, #PHP, #فصل_۶, #لاراول
👤 AmirHossein
💎 Channel: @DevelopixLaravel
فصل شش - Requests and Response
بخش دوم - اعتبارسنجی درخواست ها
اعتبارسنجی ها عمدتا به 3 روش انجام می شوند. در این پست به 2 روش آن اشاره می شود و روش سوم در پست های بعدی کامل بررسی خواهد شد.
یکی از روش های مرسوم اعتبارسنجی بر روی درخواست ها (ورودی ها POST، GET و...) فراخوانی متد validate از متغیر $request می باشد.
کد بالا درخواست ما را اعتبارسنجی می کند، به عنوان مثال، مقدار input با نام title باید required، unique و طول حداکثر 255 کاراکتر داشته باشد.
اگر همه این ویژگی ها را داشته باشد اعتبارسنجی درخواست موفقیت آمیز بوده، در غیر اینصورت یک آرایه از error ها ایجاد می شود.
روش دیگر اعتبارسنجی استفاده از فساد Validator است:
کد بالا همانند روش اول است، با این تفاوت که می توان اعتبارسنجی را روی داده های دلخواه (پارامتر اول متد make که برابر تمامی ورودی های درخواست قرار کرفته) انجام داد.
هر دو روش مرسوم و پرکاربرد هستند که بسته به نیاز استفاده می شوند.
پس از انجام اعتبار سنجی یک شئ از Validator باز می گردد که متدهایی در اختیار ما می گذارد، در ادامه به بررسی آنها خواهیم پرداخت.
1- متد fails
این متد بررسی میکند که آیا عملیات اعتبارسنجی شکست خورده یا نه.
2- متد validated
اگر اعتبارسنجی موفقیتآمیز باشد، این متد فقط دادههای معتبر (validated) را بازمیگرداند. این روش، دادههای تاییدشده را فیلتر میکند.
3- متد stopOnFirstFailure
اگر بخواهید عملیات اعتبارسنجی بهمحض اولین خطا متوقف شود، از این متد استفاده میکنید.
4- متد validate
مقدار اعتبارسنجیشده را باز میگرداند یا اگر خطایی وجود داشته باشد، بهصورت خودکار ValidationException پرتاب میکند. معمولاً در کنترلر استفاده میشود.
در این حالت اگر فیلدی نامعتبر باشد، لاراول بهصورت خودکار به صفحه قبل برمیگردد و خطاها را نمایش میدهد.
5- متد validateWithBag
مشابه validate() است ولی خطاها را داخل یک Error Bag خاص ذخیره میکند. برای مثال وقتی چند فرم در یک صفحه داریم و هرکدام باید خطاهای جداگانه داشته باشند.
درصورت بروز خطا، ارورها در یک Bag با نام updateProfile ذخیره می شوند.
6- متد after
پس از اجرای تمام قوانین اعتبارسنجی، میتوانید با این متد، اعتبارسنجیهای سفارشی اضافه کنید.
7- متد errors
لیست خطاهای اعتبارسنجی را باز میگرداند، معمولاً در ترکیب با fails() استفاده میشود.
8- متد sometimes
اجرا شدن قوانین اعتبارسنجی را وابسته به شرط خاصی میکند.
در این مثال، اگر مقدار subscribe برابر با true باشد، فیلد email اجباری خواهد شد.
متد های دیگری نیز وجود دارد که شامل آموزش نخواهد شد.
درصوتی که یک اعتبارسنجی ناموفق باشد، خطا ها در متغیر $errors در سمت Blade در دسترس خواهد گرفت.
به عنوان مثال:
کد بالا درصورت وجود خطا اعتبارسنجی، خطا آنها را به کاربر نمایش می دهد.
همچنین می توان از دایرکتیو @error استفاده کنید:
این کد در صورتی که اینپوت title با خطا مواجه شود، متن خطای آن را به کاربر نمایش می دهد.
اگر نیاز به خطا ها از یک Bag خاص داشتید می توانید پارامتر دوم را نیز کامل کنید:
تا این بخش با روش اعتبارسنجی درخواست ها و نمایش خطاهای آن آشنا شدید، در قسمت های بعدی با Ruleهای اعتبارسنجی (required|unique|...) آشنا خواهیم شد.
🔖 #Laravel, #PHP, #فصل_۶, #لاراول
👤 AmirHossein
💎 Channel: @DevelopixLaravel
بخش دوم - اعتبارسنجی درخواست ها
اعتبارسنجی ها عمدتا به 3 روش انجام می شوند. در این پست به 2 روش آن اشاره می شود و روش سوم در پست های بعدی کامل بررسی خواهد شد.
یکی از روش های مرسوم اعتبارسنجی بر روی درخواست ها (ورودی ها POST، GET و...) فراخوانی متد validate از متغیر $request می باشد.
public function store(Request $request)
{
$validated = $request->validate([
'title' => 'required|unique:posts|max:255',
'body' => 'required',
]);
}
کد بالا درخواست ما را اعتبارسنجی می کند، به عنوان مثال، مقدار input با نام title باید required، unique و طول حداکثر 255 کاراکتر داشته باشد.
اگر همه این ویژگی ها را داشته باشد اعتبارسنجی درخواست موفقیت آمیز بوده، در غیر اینصورت یک آرایه از error ها ایجاد می شود.
روش دیگر اعتبارسنجی استفاده از فساد Validator است:
$validator = Validator::make($request->all(), [
'title' => 'required|unique:posts|max:255',
'body' => 'required',
]);
کد بالا همانند روش اول است، با این تفاوت که می توان اعتبارسنجی را روی داده های دلخواه (پارامتر اول متد make که برابر تمامی ورودی های درخواست قرار کرفته) انجام داد.
هر دو روش مرسوم و پرکاربرد هستند که بسته به نیاز استفاده می شوند.
پس از انجام اعتبار سنجی یک شئ از Validator باز می گردد که متدهایی در اختیار ما می گذارد، در ادامه به بررسی آنها خواهیم پرداخت.
1- متد fails
این متد بررسی میکند که آیا عملیات اعتبارسنجی شکست خورده یا نه.
if ($validator->fails()) {
return response('fails');
}
2- متد validated
اگر اعتبارسنجی موفقیتآمیز باشد، این متد فقط دادههای معتبر (validated) را بازمیگرداند. این روش، دادههای تاییدشده را فیلتر میکند.
$validated = $validator->validated();
3- متد stopOnFirstFailure
اگر بخواهید عملیات اعتبارسنجی بهمحض اولین خطا متوقف شود، از این متد استفاده میکنید.
$validator = Validator::make($request->all(), [
'name' => 'required',
])->stopOnFirstFailure();
4- متد validate
مقدار اعتبارسنجیشده را باز میگرداند یا اگر خطایی وجود داشته باشد، بهصورت خودکار ValidationException پرتاب میکند. معمولاً در کنترلر استفاده میشود.
$validated = $request->validate([
'name' => 'required',
]);
در این حالت اگر فیلدی نامعتبر باشد، لاراول بهصورت خودکار به صفحه قبل برمیگردد و خطاها را نمایش میدهد.
5- متد validateWithBag
مشابه validate() است ولی خطاها را داخل یک Error Bag خاص ذخیره میکند. برای مثال وقتی چند فرم در یک صفحه داریم و هرکدام باید خطاهای جداگانه داشته باشند.
$request->validateWithBag('updateProfile', [
'name' => 'required',
]);
درصورت بروز خطا، ارورها در یک Bag با نام updateProfile ذخیره می شوند.
6- متد after
پس از اجرای تمام قوانین اعتبارسنجی، میتوانید با این متد، اعتبارسنجیهای سفارشی اضافه کنید.
$validator->after(function ($validator) use ($request) {
if ($request->password !== $request->confirm_password) {
$validator->errors()->add('confirm_password', 'Password is incorrect.');
}
});
7- متد errors
لیست خطاهای اعتبارسنجی را باز میگرداند، معمولاً در ترکیب با fails() استفاده میشود.
$errors = $validator->errors();
8- متد sometimes
اجرا شدن قوانین اعتبارسنجی را وابسته به شرط خاصی میکند.
$validator->sometimes('email', 'required', function ($input) {
return $input->subscribe == true;
});
در این مثال، اگر مقدار subscribe برابر با true باشد، فیلد email اجباری خواهد شد.
متد های دیگری نیز وجود دارد که شامل آموزش نخواهد شد.
درصوتی که یک اعتبارسنجی ناموفق باشد، خطا ها در متغیر $errors در سمت Blade در دسترس خواهد گرفت.
به عنوان مثال:
@if ($errors->any())
@foreach ($errors->all() as $error)
{{ $error }}
@endforeach
@endif
کد بالا درصورت وجود خطا اعتبارسنجی، خطا آنها را به کاربر نمایش می دهد.
همچنین می توان از دایرکتیو @error استفاده کنید:
@error('title')
<div class="alert alert-danger">{{ $message }}</div>
@enderror
این کد در صورتی که اینپوت title با خطا مواجه شود، متن خطای آن را به کاربر نمایش می دهد.
اگر نیاز به خطا ها از یک Bag خاص داشتید می توانید پارامتر دوم را نیز کامل کنید:
@error('title', 'myBag')
تا این بخش با روش اعتبارسنجی درخواست ها و نمایش خطاهای آن آشنا شدید، در قسمت های بعدی با Ruleهای اعتبارسنجی (required|unique|...) آشنا خواهیم شد.
🔖 #Laravel, #PHP, #فصل_۶, #لاراول
👤 AmirHossein
💎 Channel: @DevelopixLaravel
Forwarded from | کانال توسعهدهندگان PHP |
❓ خروجی کد بالا کدام است؟
➖ A
Outer 1
Inner 1
Outer 2
Inner 1
➖ B
Outer 1
Inner 1
Inner 2
Outer 2
Inner 1
➖ C
Outer 1
Inner 1
➖ D
Outer 1
Inner 1
Inner 2
💢 نکته : لطفا اندکی تامل کنید، از اجرای کد و استفاده از هوش مصنوعی خودداری کنید.
⚜️ پاسخ خود را همراه با توضیح ارسال کنید.
🔖 #PHP, #پی_اچ_پی
👤 AmirHossein
💎 Channel: @DevelopixPHP
➖ A
Outer 1
Inner 1
Outer 2
Inner 1
➖ B
Outer 1
Inner 1
Inner 2
Outer 2
Inner 1
➖ C
Outer 1
Inner 1
➖ D
Outer 1
Inner 1
Inner 2
💢 نکته : لطفا اندکی تامل کنید، از اجرای کد و استفاده از هوش مصنوعی خودداری کنید.
⚜️ پاسخ خود را همراه با توضیح ارسال کنید.
🔖 #PHP, #پی_اچ_پی
👤 AmirHossein
💎 Channel: @DevelopixPHP
Forwarded from | کانال توسعهدهندگان PHP |
🔰 این سوال بسیار راحت است، درصورتی که با break و continue که با یک عدد همراه است آشنا باشید.
🔸 کد ما به این صورت است:
🔹 و خروجی آن گزینه C، یعنی:
Outer 1
Inner 1
⁉️ اما چرا؟
⚜️ بیایید ابتدا با دستورات break، و continue به صورت دقیق تر آشنا شویم.
🔻
break به صورت معمول از یک حلقه خارج میشود. اما اگر بنویسیم break 2، به معنی خروج از دو سطح حلقه است.
یعنی در این کد:
اگر شرط
🔻
continue معمولاً ادامه حلقه جاری را رها میکند و میرود سراغ تکرار بعدی همان حلقه. اما continue 2 میگوید برو سراغ تکرار بعدی حلقه سطح دوم.
در این کد:
اگر این شرط اجرا شود، کل حلقه داخلی متوقف میشود و حلقه بیرونی به تکرار بعدی میرود.
🔸 در هر دو حالت، عدد بعد از break یا continue مشخص میکند که چند سطح از حلقه را تحت تأثیر قرار میدهد.
⭕️ نکته: عدد بعد از break یا continue باید به تعداد سطوح حلقه باشد.
⚜️ حالا بیایید ببینیم این کد دقیقاً چطور اجرا میشود:
اولین دور حلقه بیرونی: $i = 1
Outer 1
اولین دور حلقه داخلی: $j = 1
Inner 1
سپس:
شرط درست است، پس اجرای break 2 انجام میشود. یعنی از هر دو حلقه خارج میشویم و برنامه پایان مییابد.
⭕️ نکته: دستور continue هرگز اجرا نخواهد شد.
🔖 #PHP, #پی_اچ_پی
👤 AmirHossein
💎 Channel: @DevelopixPHP
🔸 کد ما به این صورت است:
for ($i = 1; $i < 3; $i++) {
echo "Outer $i\n";
for ($j = 1; $j < 3; $j++) {
echo "\tInner $j\n";
if ($j == 1) break 2;
if ($j == 2) continue 2;
}
}
🔹 و خروجی آن گزینه C، یعنی:
Outer 1
Inner 1
⁉️ اما چرا؟
⚜️ بیایید ابتدا با دستورات break، و continue به صورت دقیق تر آشنا شویم.
🔻
break N
چیست؟break به صورت معمول از یک حلقه خارج میشود. اما اگر بنویسیم break 2، به معنی خروج از دو سطح حلقه است.
یعنی در این کد:
if ($j == 1) break 2;
اگر شرط
$j == 1
برقرار شود، هم از حلقه داخلی و هم خارجی خارج میشود. یعنی اجرای کل حلقهها متوقف میشود.🔻
continue N
چیست؟continue معمولاً ادامه حلقه جاری را رها میکند و میرود سراغ تکرار بعدی همان حلقه. اما continue 2 میگوید برو سراغ تکرار بعدی حلقه سطح دوم.
در این کد:
if ($j == 2) continue 2;
اگر این شرط اجرا شود، کل حلقه داخلی متوقف میشود و حلقه بیرونی به تکرار بعدی میرود.
🔸 در هر دو حالت، عدد بعد از break یا continue مشخص میکند که چند سطح از حلقه را تحت تأثیر قرار میدهد.
⭕️ نکته: عدد بعد از break یا continue باید به تعداد سطوح حلقه باشد.
⚜️ حالا بیایید ببینیم این کد دقیقاً چطور اجرا میشود:
اولین دور حلقه بیرونی: $i = 1
Outer 1
اولین دور حلقه داخلی: $j = 1
Inner 1
سپس:
if ($j == 1) break 2;
شرط درست است، پس اجرای break 2 انجام میشود. یعنی از هر دو حلقه خارج میشویم و برنامه پایان مییابد.
⭕️ نکته: دستور continue هرگز اجرا نخواهد شد.
🔖 #PHP, #پی_اچ_پی
👤 AmirHossein
💎 Channel: @DevelopixPHP