數據庫能夠說是後端開發最經常使用,也是最重要的部分。laravel 提供了很實用的 Eloquent ORM 模型類,簡單、直觀的與數據庫進行交互。同時使用數據遷移管理數據庫,能夠與團隊進行共享以及編輯。兩者的更多介紹請查看下方的文檔。
如下使用兩者進行示例,需求是記錄用戶瀏覽記錄。請勿將本示例帶入實際項目中,本文僅做示例。實際項目根據需求進行記錄,以及選擇存儲方式。php
第一步固然是建立數據表了。使用 artisan
命令能夠很方便的建立模型以及數據遷移。php artisan make:model Models/BrowseLog -m
,-m
參數在建立模型的同時也建立了數據遷移文件。執行過上述命令後,新增了 app/Models/BrowseLog.php
以及 database/migrations/{now_date}_create_browse_logs_table.php
兩個文件。
接下來編輯 {now_date}_create_browse_logs_table.php
來建立數據表html
/** * Run the migrations. * * @return void */ public function up() { Schema::create('browse_logs', function (Blueprint $table) { $table->increments('id'); $table->ipAddress('ip_addr')->comment('ip 地址'); $table->string('request_url', 20)->comment('請求 url'); $table->char('city_name', 10)->comment('根據 ip 獲取城市名稱'); $table->timestamps(); }); DB::statement("ALTER TABLE `browse_logs` comment'瀏覽記錄表'"); // 表註釋 }
代碼如上,編輯完成後,執行命令 php artisan migrate
會將全部未執行遷移的數據表建立。以下laravel
我的感受,laravel 默認的數據類型值得商榷。例如 ipAddress()
,數據格式爲 varchar(45)
,其實能夠使用 ip2long
轉換成 int
進行存儲。timestamps()
也能夠使用時間戳進行存儲。固然 laravel 也提供了 訪問器 & 修改器 方便維護。各位實際項目中自行選擇。數據庫
定義一個全局中間件,每一次請求都會被執行。執行 php artisan make:middleware BrowseLog
,建立了 app/Http/Middleware/BrowseLog.php
文件。
將建立好的中間件添加到 app/Http/Kernel.php
中,以下後端
最後在中間件中,記錄數據到數據庫便可,代碼以下app
/** * Handle an incoming request. * * @param \Illuminate\Http\Request $request * @param \Closure $next * @return mixed */ public function handle($request, Closure $next) { $log = new \App\Models\BrowseLog(); $log->ip_addr = $request->getClientIp(); $log->request_url = $request->path(); $log->city_name = get_city_by_ip(); $log->save(); return $next($request); }
訪問幾個連接後,去數據庫看下post
數據寫入正常,本次的示例就到此爲止。url
參考資料:數據庫操做 —— 遷移、Eloquent ORM —— 快速入門。spa