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
👍3❤1🔥1
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
👍6❤2🔥1
فصل هفت - Services و Dependency Injection
بخش اول - سرویس کانتینر
Service Container (IoC Container) یکی از قدرتمندترین ابزارها در لاراول هست، وظیفه این سرویس قدرتمند Dependency Injection و Inversion of Control میباشد.
یعنی اگر کلاسی نیاز به یک سرویس یا کلاس دیگهای داشته باشه، لاراول به کمک سرویس کانتینر خودش اون نیاز رو براش فراهم میکنه.
همونطور که گفته شد لاراول به صورت خودکار کلاسهایی که وابستگی ندارن، یا فقط به کلاسهای کامل (concrete) وابستهان رو بدون نیاز به تنظیم دستی و به صورت خودکار resolve بکنه. مثلا:
وقتی یک کلاس ساده مثل Service به صورت type-hint تعریف شده باشه، کانتینر خودش اون رو instantiate و inject میکنه بدون این که ما جای دیگهای مشخص کنیم.
اما همه این دپندنسی ها به صورت خودکار فراهم نمیشوند، به همین دلیل Service Providerها به کمک ما میآیند.
لاراول به صورت پیشفرض یک پروایدر در مسیر App\Providers\AppServiceProvider.php دارد، شما نیز میتوانید پروایدرهای خود را با دستور زیر در همین مسیر ایجاد کنید:
گفته شد که لاراول همیشه نمیتواند یک سرویس را بدون تنظیم قبلی inject کند. اما در چه زمان هایی؟
1- وقتی برای یک interface چند پیاده سازی داریم و میخواهیم مشخص کنیم که لاراول از کدام پیادهسازی استفاده کند.
2- وقتی که یک پکیج برای لاراول توسعه دادهایم و میخواهیم سرویسهایی تعریف کنیم.
در این موارد کافی است در یکی از متدهای boot یا register (بسته به نیاز که بعدا توضیح داده میشود) در سرویس پروایدر خود آن پیادهسازی را به کانتینر bind کنیم:
در این کد گفته شده زمانی که Transistor نیاز شود، کالبک اجرا شود و یک نمونه از کلاس Transistor ایجاد و به کانتینر اضافه کند.
انواع binding
1- bind
این نوع از binding در مثال قبل گفته شد. و در هر بار درخواست یک سرویس، یک نمونه جدید از آن را ایجاد میکند.
2- singleton
همانطور که از نامش پیداست، تنها یک نمونه از کلاس را میسازد و در هر درخواست سرویس، از نمونه ایجاد شده قبلی استفاده میکند:
3- instance
زمانی استفاده میشود که خودمان یک instance آماده از یک آبجکت داشته باشیم و بخواهیم آن را به کانتینر bind کنیم:
4- scoped
در اپهایی که هر request (یا queue job) باید نسخه جداگانهای از کلاس داشته باشند ولی در همون request بین کلاسها مشترک باشند.
این نوع برای stateful کردن کلاسهایی مثل کانکشن دیتابیس بسیار مهم است.
در پروژههای Laravel Octane یا اپهای multi-tenant یا زمانی که Queue Jobها به ایزولاسیون نیاز دارن کاربرد دارد.
5- bindIf
فقط زمانی bind رو انجام میده که کلاس یا کلیدی با اون نام bind نشده باشه:
6- singletonIf
مشابه bindIf عمل خواهد کرد با این تفاوت که نمونهای که ایجاد میکند از نوع singleton خواهد بود.
7- scopedIf
مشابه bindIf و singletonIf برای scoped bindigها.
Interface Binding
ما میتوانیم مشخص کنیم که وقتی یک کلاس خاص (یا Interface) خواسته شد، چه پیادهسازی (concrete class) برایش استفاده شود.
فرض کنید:
در این صورت کافی است در سراسر برنامه از PaymentGateway استفاده کنیم و لاراول خودش تصمیم میگیرد چه چیز را inject کند.
برای این کار کافی است در سرویس پروایدر خود به صورت زیر عمل کنیم:
در این صورت اگر PaymentGateway نیاز شود، یک نمونه از StripeGateway ساخته و inject میشود.
در قسمتهای بعدی با سایر Injectionها آشنا خواهیم شد.
🔖 #Laravel, #PHP, #لاراول, #فصل_۷
👤 AmirHossein
💎 Channel: @DevelopixLaravel
بخش اول - سرویس کانتینر
Service Container (IoC Container) یکی از قدرتمندترین ابزارها در لاراول هست، وظیفه این سرویس قدرتمند Dependency Injection و Inversion of Control میباشد.
یعنی اگر کلاسی نیاز به یک سرویس یا کلاس دیگهای داشته باشه، لاراول به کمک سرویس کانتینر خودش اون نیاز رو براش فراهم میکنه.
همونطور که گفته شد لاراول به صورت خودکار کلاسهایی که وابستگی ندارن، یا فقط به کلاسهای کامل (concrete) وابستهان رو بدون نیاز به تنظیم دستی و به صورت خودکار resolve بکنه. مثلا:
Route::get('/', function (Service $service) {
dd($service::class);
});
وقتی یک کلاس ساده مثل Service به صورت type-hint تعریف شده باشه، کانتینر خودش اون رو instantiate و inject میکنه بدون این که ما جای دیگهای مشخص کنیم.
اما همه این دپندنسی ها به صورت خودکار فراهم نمیشوند، به همین دلیل Service Providerها به کمک ما میآیند.
لاراول به صورت پیشفرض یک پروایدر در مسیر App\Providers\AppServiceProvider.php دارد، شما نیز میتوانید پروایدرهای خود را با دستور زیر در همین مسیر ایجاد کنید:
php artisan make:provider MyServiceProvider
گفته شد که لاراول همیشه نمیتواند یک سرویس را بدون تنظیم قبلی inject کند. اما در چه زمان هایی؟
1- وقتی برای یک interface چند پیاده سازی داریم و میخواهیم مشخص کنیم که لاراول از کدام پیادهسازی استفاده کند.
2- وقتی که یک پکیج برای لاراول توسعه دادهایم و میخواهیم سرویسهایی تعریف کنیم.
در این موارد کافی است در یکی از متدهای boot یا register (بسته به نیاز که بعدا توضیح داده میشود) در سرویس پروایدر خود آن پیادهسازی را به کانتینر bind کنیم:
$this->app->bind(Transistor::class, function (Application $app) {
return new Transistor($app->make(PodcastParser::class));
});
در این کد گفته شده زمانی که Transistor نیاز شود، کالبک اجرا شود و یک نمونه از کلاس Transistor ایجاد و به کانتینر اضافه کند.
انواع binding
1- bind
این نوع از binding در مثال قبل گفته شد. و در هر بار درخواست یک سرویس، یک نمونه جدید از آن را ایجاد میکند.
2- singleton
همانطور که از نامش پیداست، تنها یک نمونه از کلاس را میسازد و در هر درخواست سرویس، از نمونه ایجاد شده قبلی استفاده میکند:
$this->app->singleton('RedisClient', function () {
return new RedisClient(config('redis'));
});
3- instance
زمانی استفاده میشود که خودمان یک instance آماده از یک آبجکت داشته باشیم و بخواهیم آن را به کانتینر bind کنیم:
$logger = new \App\Services\CustomLogger();
$this->app->instance('logger', $logger);
4- scoped
در اپهایی که هر request (یا queue job) باید نسخه جداگانهای از کلاس داشته باشند ولی در همون request بین کلاسها مشترک باشند.
این نوع برای stateful کردن کلاسهایی مثل کانکشن دیتابیس بسیار مهم است.
$this->app->scoped(MyService::class, function ($app) {
return new MyService(now());
});
در پروژههای Laravel Octane یا اپهای multi-tenant یا زمانی که Queue Jobها به ایزولاسیون نیاز دارن کاربرد دارد.
5- bindIf
فقط زمانی bind رو انجام میده که کلاس یا کلیدی با اون نام bind نشده باشه:
$this->app->bindIf(SomeInterface::class, DefaultImplementation::class);
6- singletonIf
مشابه bindIf عمل خواهد کرد با این تفاوت که نمونهای که ایجاد میکند از نوع singleton خواهد بود.
7- scopedIf
مشابه bindIf و singletonIf برای scoped bindigها.
Interface Binding
ما میتوانیم مشخص کنیم که وقتی یک کلاس خاص (یا Interface) خواسته شد، چه پیادهسازی (concrete class) برایش استفاده شود.
فرض کنید:
interface PaymentGateway {
public function charge($amount);
}
class StripeGateway implements PaymentGateway {
public function charge($amount) {
//
}
}
در این صورت کافی است در سراسر برنامه از PaymentGateway استفاده کنیم و لاراول خودش تصمیم میگیرد چه چیز را inject کند.
برای این کار کافی است در سرویس پروایدر خود به صورت زیر عمل کنیم:
$this->app->bind(PaymentGateway::class, StripeGateway::class);
در این صورت اگر PaymentGateway نیاز شود، یک نمونه از StripeGateway ساخته و inject میشود.
در قسمتهای بعدی با سایر Injectionها آشنا خواهیم شد.
🔖 #Laravel, #PHP, #لاراول, #فصل_۷
👤 AmirHossein
💎 Channel: @DevelopixLaravel
👍4
Forwarded from | کانال ربات تلگرام |
LaraGram یک فریمورک توسعهپذیر، منعطف و مدرن به زبان PHP برای ساخت رباتهای تلگرامه که با الهام از ساختار لاراول طراحی شده.
اگر با لاراول آشنایی دارید، کار با LaraGram براتون راحت، لذتبخش و قابل پیشبینی خواهد بود — و حتی اگه آشنایی ندارید، ساختار منظمش خیلی زود براتون جا میافته.
LaraGram امکانات زیادی درون خودش داره که میتونید سختترین رباتها رو با چند خط کد پیادهسازی کنید، اگر قابلیتی رو هم نداشته باشه میتونید به عنوان پکیج جانبی بهش اضافه کنید یا حتی برای اون پکیج توسعه بدید.
به عنوان مثال، LaraGram مجهز به یک سیستم Update Listener پیشرفته هست که به شما امکاناتی مانند گروهبندی لیسنرها، نامدهی به هر لیسنر، اعمال محدودیت و Middleware بر روی لیسنر، پردازش متن و ورودیها، و... رو میده.
همچنین نسخه بازنویسی شده Eloquent ORM رو در خودش جا داده با پشتیبانی از ۵ دیتابیس مختلف، همراه با تعریف روابط، Migrations، Seeders و Factoryها.
سایر قابلیت های کلیدی اون:
🔐 سیستم کنترل مجوز با قابلیت تعریف Gate و Policy برای مدیریت دقیق سطح دسترسی کاربران به منابع مختلف.
💻 Commander System برای ساخت و اجرای راحت commandها، مدیریت سادهتر پروژه، و زمانبندی اجرای وظایف (Scheduled Tasks).
📨 Queue و Job System برای ساخت صف و اجرای کارها در پسزمینه با زمانبندی دلخواه.
🧰 رابط Redis با امکانات لازم برای توسعههای وابسته به کش، صف و پیامرسانی آنی.
🧠 سیستم کشینگ با پشتیبانی از ۷ درایور مختلف برای ذخیرهسازی دادههای موقتی، بههمراه پیادهسازی Step Manager بر همین بستر.
🔁 کالکشنها برای کار سادهتر و منعطفتر با دادههای Iterable، مشابه کالکشنهای Laravel.
⚙️ Concurrency داخلی با امکان پردازش همزمان چند درخواست در پسزمینه بدون پیچیدگی اضافه.
🔒 ابزارهای امنیتی با پشتیبانی از سیستمهای رمزنگاری (Crypt) و هشینگ (Hash).
📢 Event Dispatcher برای تعریف و مدیریت رویدادها و واکنش به آنها.
🎛 کیبورد بیلدر توسعهیافته با استفاده ساده و انعطاف پذیری بالا.
🧩 موتور قالبسازی پیشرفته الهامگرفته از Blade برای ساخت پیامها بهصورت پویا و قابل نگهداری.
🌍 سیستم چندزبانه (Translation) برای ساخت رباتهایی با پشتیبانی از زبانهای مختلف.
✅ سیستم اعتبارسنجی با قوانین متنوع و امکان تعریف Ruleهای سفارشی.
🤖 پشتیبانی از چند ربات همزمان و امکان تعریف چند کانکشن و مدیریت آنها بهصورت مستقل.
یک مثال ساده برای ایجاد یک کامند بن با user_id به مدت 7 روز، با کنترل دسترسی و شرط ریپلای نشدن کامند:
برخی از ویژگیها با افزونهها و پکیجهای جانبی به LaraGram اضافه میشوند، به عنوان مثال:
⚡️ LaraGram Surge
پکیجی برای اجرای سریعتر رباتها با پشتیبانی از Swoole و OpenSwoole
🔧 LaraGram Installer
برای نصب و راهاندازی سریع و ساده پروژههای LaraGram
🛢 LaraGram MongoDB
درایور پایگاهداده MongoDB برای Eloquent ORM
📚 مستندات رسمی LaraGram نیز از طریق لینک زیر در دسترس است:
🔗 laraxgram.github.io
💬 گروه پرسش و پاسخ:
🔹 @LaraGramChat
📌 پروژه در گیتهاب:
♦️ LaraGram
🔖 #TelegramBot, #ربات, #تلگرام
👤 AmirHossein
💎 Channel: @DevelopixRobot
اگر با لاراول آشنایی دارید، کار با LaraGram براتون راحت، لذتبخش و قابل پیشبینی خواهد بود — و حتی اگه آشنایی ندارید، ساختار منظمش خیلی زود براتون جا میافته.
LaraGram امکانات زیادی درون خودش داره که میتونید سختترین رباتها رو با چند خط کد پیادهسازی کنید، اگر قابلیتی رو هم نداشته باشه میتونید به عنوان پکیج جانبی بهش اضافه کنید یا حتی برای اون پکیج توسعه بدید.
به عنوان مثال، LaraGram مجهز به یک سیستم Update Listener پیشرفته هست که به شما امکاناتی مانند گروهبندی لیسنرها، نامدهی به هر لیسنر، اعمال محدودیت و Middleware بر روی لیسنر، پردازش متن و ورودیها، و... رو میده.
همچنین نسخه بازنویسی شده Eloquent ORM رو در خودش جا داده با پشتیبانی از ۵ دیتابیس مختلف، همراه با تعریف روابط، Migrations، Seeders و Factoryها.
سایر قابلیت های کلیدی اون:
🔐 سیستم کنترل مجوز با قابلیت تعریف Gate و Policy برای مدیریت دقیق سطح دسترسی کاربران به منابع مختلف.
💻 Commander System برای ساخت و اجرای راحت commandها، مدیریت سادهتر پروژه، و زمانبندی اجرای وظایف (Scheduled Tasks).
📨 Queue و Job System برای ساخت صف و اجرای کارها در پسزمینه با زمانبندی دلخواه.
🧰 رابط Redis با امکانات لازم برای توسعههای وابسته به کش، صف و پیامرسانی آنی.
🧠 سیستم کشینگ با پشتیبانی از ۷ درایور مختلف برای ذخیرهسازی دادههای موقتی، بههمراه پیادهسازی Step Manager بر همین بستر.
🔁 کالکشنها برای کار سادهتر و منعطفتر با دادههای Iterable، مشابه کالکشنهای Laravel.
⚙️ Concurrency داخلی با امکان پردازش همزمان چند درخواست در پسزمینه بدون پیچیدگی اضافه.
🔒 ابزارهای امنیتی با پشتیبانی از سیستمهای رمزنگاری (Crypt) و هشینگ (Hash).
📢 Event Dispatcher برای تعریف و مدیریت رویدادها و واکنش به آنها.
🎛 کیبورد بیلدر توسعهیافته با استفاده ساده و انعطاف پذیری بالا.
🧩 موتور قالبسازی پیشرفته الهامگرفته از Blade برای ساخت پیامها بهصورت پویا و قابل نگهداری.
🌍 سیستم چندزبانه (Translation) برای ساخت رباتهایی با پشتیبانی از زبانهای مختلف.
✅ سیستم اعتبارسنجی با قوانین متنوع و امکان تعریف Ruleهای سفارشی.
🤖 پشتیبانی از چند ربات همزمان و امکان تعریف چند کانکشن و مدیریت آنها بهصورت مستقل.
یک مثال ساده برای ایجاد یک کامند بن با user_id به مدت 7 روز، با کنترل دسترسی و شرط ریپلای نشدن کامند:
Bot::onCommand("ban {id}", function (Request $request, $id) {
$request->banChatMember(
chat_id: chat()->id,
user_id: $id,
until_date: now()->addDays(7)->timestamp
);
})->can('administrator')->hasNotReply();
برخی از ویژگیها با افزونهها و پکیجهای جانبی به LaraGram اضافه میشوند، به عنوان مثال:
⚡️ LaraGram Surge
پکیجی برای اجرای سریعتر رباتها با پشتیبانی از Swoole و OpenSwoole
🔧 LaraGram Installer
برای نصب و راهاندازی سریع و ساده پروژههای LaraGram
🛢 LaraGram MongoDB
درایور پایگاهداده MongoDB برای Eloquent ORM
📚 مستندات رسمی LaraGram نیز از طریق لینک زیر در دسترس است:
🔗 laraxgram.github.io
💬 گروه پرسش و پاسخ:
🔹 @LaraGramChat
📌 پروژه در گیتهاب:
♦️ LaraGram
🔖 #TelegramBot, #ربات, #تلگرام
👤 AmirHossein
💎 Channel: @DevelopixRobot
🔥12👍4❤2