亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

Laravel 7 sainttum 數據庫連接問題

Laravel 7 sainttum 數據庫連接問題

PHP
智慧大石 2023-07-01 17:29:52
我正在使用 Sanctum laravel 包為 API 制作項目。它需要連接2個數據庫服務器。一種是MySQL來保存一些數據,包括登錄用戶。另一種是 SQL Server 來獲取 API 路由的數據。在MySQL數據庫服務器中登錄Sanctum沒有問題,我已經測試登錄并取回了token。當我在不使用 Laravel Sanctum 的情況下檢索數據時,從 SQL Server 檢索數據也運行良好。我需要從 MySQL 數據庫服務器登錄檢查并從 SQL Server 數據庫服務器檢索數據。我現在面臨的問題是如何以及在哪里定義 Sanctum auth 中間件的 MySQL 數據庫服務器需求。連接如下:DB_MYSQL_CONNECTION=mysqlDB_MYSQL_HOST=127.0.0.1DB_MYSQL_PORT=3306DB_MYSQL_DATABASE=apiDB_MYSQL_USERNAME=rootDB_MYSQL_PASSWORD=DB_SQLSRV_CONNECTION=sqlsrvDB_SQLSRV_HOST=127.0.0.1DB_SQLSRV_PORT=1433DB_SQLSRV_DATABASE=StoreDataDB_SQLSRV_USERNAME=saDB_SQLSRV_PASSWORD=對于那條路線Route::middleware(['auth:sanctum'])->group(function () {      Route::get('/items', 'APIController@getAllItems');});我在記錄成功后使用身份驗證令牌運行它,收到如下錯誤:Illuminate\Database\QueryException:SQLSTATE[42S02]:[Microsoft][SQL Server 的 ODBC 驅動程序 11][SQL Server]對象名稱“personal_access_tokens”無效。(SQL: select top 1 * from [personal_access_tokens] where [token] = bd1de1df8bc2ac289dbd89f7d640a4c65ebc1b709b565ee500315ee710f12b62) 在文件 ...\vendor\laravel\framework\src\Illuminate\Database\Connection.php 第 671 行Personal_access_tokens 和 users 表位于 MySQL 數據庫中。我可以自定義 Sanctum Auth 的數據庫連接嗎?如何?
查看完整描述

1 回答

?
慕森卡

TA貢獻1806條經驗 獲得超8個贊

那么您需要對個人訪問令牌進行一些自定義。創建一個名稱為 SanctumPersonalAccessClient 的普通模型(在本例中您想要什么)并在 AuthServiceProvider.php 中編寫此內容


namespace App\Providers;


use Laravel\Sanctum\Sanctum;

use App\SanctumPersonalAccessClient as PersonalAccessClient;


class AuthServiceProvider extends ServiceProvider

{

    /**

     * The policy mappings for the application.

     *

     * @var array

     */

    protected $policies = [

        //

    ];


    /**

     * Register any authentication / authorization services.

     *

     * @return void

     */

    public function boot()

    {

        $this->registerPolicies();

        Sanctum::usePersonalAccessClientModel(PersonalAccessClient::class);

    }

}

然后在剛剛創建的模型中設置連接和表名稱,如下所示:


namespace App;

use Laravel\Sanctum\PersonalAccessClient;


class SanctumPersonalAccessClient extends PersonalAccessClient

{

    protected $connection = 'my_custom_connection';

    protected $table = 'personal_access_tokens';

}

有用的鏈接,但帶有護照:https://github.com/laravel/passport/issues/247#issuecomment-424095961


查看完整回答
反對 回復 2023-07-01
  • 1 回答
  • 0 關注
  • 165 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號