برچسب: مشقشرثم

  • کار با بیش از یک دیتابیس در لاراول ۵

    بعضی وقتا نیازه که شما با بیش از یک دیتابیس در ارتباط باشید در لاراول ، مثلا ممکنه برای هر وبلاگی که توی سیستم وبلاگ دهی شما ایجاد میشه یک دیتابیس درست کنید(البته فک نکنم تو این مورد ، این کار معقول باشه) اونجا نیاز هست که در اولین قدم توی فایل config/database.php  کانکشن مربوط به این کار رو ایجاد کنید. بصورت پیشفرض ۴ کانکشن در لاراول ۵ تعریف شده که میتونید شما هم کانکشن دیگه ای برای استفاده تعریف کنید.

    تعریف کانکشن برای اتصال به بیش از یک دیتابیس

    'mysql2' => [
                'driver'    => 'mysql',
                'host'      => env('DB_EXT_HOST', 'localhost'),
                'database'  => env('DB_EXT_DATABASE', 'db2'),
                'username'  => env('DB_EXT_USERNAME', 'username'),
                'password'  => env('DB_EXT_PASSWORD', 'password'),
                'charset'   => 'utf8',
                'collation' => 'utf8_unicode_ci',
                'prefix'    => '',
                'strict'    => false,
            ],

    توی کد بالا ما کانکشن mysql2  رو تعریف کردیم. دقت داشته باشید که کد بالا باید درون connectios تعریف کنید. همچنین توی ریشه اصلی پروژه و توی فایل .env  هم کانکشن باید مشخص شه… اون فایل رو ادیت کنید و مقادیر دلخواهتون رو اضافه کنید :

    DB_EXT_HOST=localhost
    DB_EXT_DATABASE=db2
    DB_EXT_USERNAME=username
    DB_EXT_PASSWORD=password

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

    تغییر کانکشن پیشفرض در لاراول

    برای اینکه در کل پروژه کانکشن پیشفرض رو تغییر بدیم ، در فایل config/database.php  مقدار ‘default’ => ‘mysql’,  رو به ‘default’ => ‘mysql2’,  تغییر میدیم. در این صورت در کل پروژه شما mysql2 بعنوان کانکشن دیفالت استفاده خواهد شد.

    استفاده از یک کانکشن در یک مدل خاص

    اما گاهی لازمه که در یک مدل از یک کانکشن خاص استفاده بشه ، برای انجام این کار به روش زیر عمل میکنیم :

    <?php
    class SomeModel extends Eloquent {
     
        protected $connection = 'mysql2';
     
    }

    از این پس تمام اتصالاتی که با مدل بالا به دیتابیس وصل میشه با کانکشن mysql2 خواهد بود.

    تغییر کانکشن در کنترلر

    شاید بخواید جزئی تر شید و بخواید درون یک کنترلر خاص کانکشن رو عوض کنید . برای اینکار به راحتی از روش زیر اشتفاده کنید :

    <?php
     
    class SomeController extends BaseController {
     
        public function someMethod()
        {
            $someModel = new SomeModel;
     
            $someModel->setConnection('mysql_2');
     
            $something = $someModel->find(1);
     
            return $something;
        }
     
    }

    همونطور که میبینید با استفاده از متد setConnection()  این کار شدنیه…

    و استفاده در Query Builder :

    برای استفاده از کانکشن دیگه توی کوئوری بیلدر هم بصورت زیر عمل میکنیم :

    	
    $users = DB::connection('mysql2')->select(...);

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

    امیدوارم به دردتون خورده باشم 🙂

  • آموزش و کاربرد استفاده IOC container در Laravel

    امروز بحث رو اندکی تخصصی تر میکنیم و میریم سمت container قدرتمند لاراول. یکی از مشخصه هایی که لاراول رو از سایر فریمورک های PHP جدا میکنه ، همین IOC هست. Dependency injection  یا DI یا تزریق نیازمندیها یک موضوع مهم در همه زبانهای شئ گراست. اینکه شما سایر کلاسها رو در کلاس خودتون استفاده کنید خیلی مهمه.

    اما IOC کانتینر چیست؟

    برای اینکه از یک کلاس در کدمون استفاده کنیم باید از اون نمونه بگیریم. یه چیزی مثل کد زیر :

    $myInstance = new MyClass();
    
    $myInstance->method();

    حتما بارها شده که مقدار Request $request رو بعنوان ورودی به یک تابع در کنترلر میفرستید. سوالی که پیش میاد اینه که بدون نمونه گرفتن از کلاس Request چطور PHP اونو میشناسه؟ اینجاست که کاربرد IOC مشخص میشه. لاراول با کانتینرش شرایطی رو مهیا کرده که شما به راحتی با آبجکت ها کار کنید و ازشون نمونه بگیرید. لاراول وقتی کدی مثل FOO $foo رو میبینه دنبال کلاس FOO میگرده که از اون نمونه بگیره به شرطی که کلاس FOO به کانتینر معرفی شده باشه قبلا. این خیلی خوبه. شما بدون اینکه از کلاس نمونه بگیرید نمونه گرفته میشه. بعضی وقتا پیش میاد که شما میخواید یک ریپازیتوری بنویسید که دیگران هم بتونن ازش استفاده کنن. اینجا نیاز هست که کلاس خودتون رو به لاراول برای نمونه گیری معرفی کنید و شما باید بصورت دستی کلاس رو به IOC بچسبونید یا به اصطلاح bind کنید.

    نحوه ی bind یک کلاس به IOC در لاراول

    ساده ترین روش بایند کردن کلاس به ioc استفاده از فساد App هست که باهاش میتونید هر جایی در برنامه یه کلاس رو به کانتینر بایند کنید. (هر چند بهترین جا برای بایند کردن استفاده از service provider ها هست)

    App::bind('Hamid\Repositories\User\UserRepository', function($app)
    {
        return new EloquentUserRepository( new User );
    });

    در کد بالا EloquentUserRepository رو چسبوندیم به کانتینر و از این به بعد لاراول کلاس EloquentUserRepository رو میشناسه همه جا و resolve اش میکنه.

    حتما در مورد فساد ها در لاراول اطلاعاتی دارید. همه ی کلاسهایی که در فساد ها ازشون استفاده میکنیم قبلا به کانتینر بایند شدن. مثلا در زیر بخشی فایل Illuminate/Support/Facades/Auth.php رو میبینید که مربوط به فساد Auth هست که هر روز ازش استفاده میکنیم:

    class Auth extends Facade
    {
        /**
         * Get the registered name of the component.
         *
         * @return string
         */
        protected static function getFacadeAccessor()
        {
            return 'auth';
        }

    همونطور که میبینید متد استاتیک getFacadeAccessor داره یه رشته رو برمیگردونه که در فایل Illuminate/Auth/AuthServiceProvider.php بصورت زیر به کانتینر بایند شده:

    $this->app->singleton('auth', function ($app) {
         return new AuthManager($app);
    });