最近我必須在 Laravel 7 實作 通用唯一識別碼 ( UUIDs ),並遇到一些問題。我希望這篇貼文可為其他正在做相同事情的人解惑。
使用UUIDs 的高階理由
A) 它們從你的統一資源定位符號移除編號的識別號,故用戶不能看到你的應用程式已建立多少確定的物件。例如:
https://myapp.com/api/users/5
對比:
https://myapp.com/api/users/0892b118-856e-4a15-af0c-66a3a4a28eed
B) 它們讓 識別號碼 遠難於猜測。這有益於安全性,但我們可能應該實現其他技術以防範之。
作為主鍵實作UUIDs
#如何改變資料庫遷移
##首先,在資料庫遷移中,你要將目前自動遞增的ID 欄位替換為UUIDs 。你也可以遵循以下方法:保留自動遞增ID 並將UUID 作為表中的附加字段,在用戶展示URL 時使用(在這種情況下,你將ID 隱藏到模型中),但這不是我們能在這裡做的。讓我們看看假設的 employees 表是什麼樣子的。public function up() { Schema::create('employees', function (Blueprint $table) { $table->uuid('id')->primary; $table->string('name'); $table->string('email')->unique(); $table->string('work_location')->nullable(); $table->timestamps(); }); }在這裡,注意我們用 uuid() 取代了 normal id() ;並使其成為主鍵。
讓我們把它變成一種特質
接下來,我們可以實作Laravel 生命週期掛鉤,以確保在建立此模型的新實例時分配了UUID。我們可以直接在模型中編寫程式碼,但是如果你要在多個模型中使用 UUID,我建議用 Trait (我在這篇開發文章中學到了這一點,非常感謝 Dev)。 trait 基本上允許你創建功能,並透過 use 關鍵字呼叫它在多個模型中使用。 要建立新的Trait,請建立一個\App\Http\Traits\資料夾(這只是我的愛好,你也可以將其放到其他位置),並為Trait 建立一個新文件。我們將呼叫檔案 UsesUuid.php。 這是 trait 的具體程式碼:<?php namespace App\Http\Traits; use Illuminate\Support\Str; trait UsesUuid { protected static function bootUsesUuid() { static::creating(function ($model) { if (! $model->getKey()) { $model->{$model->getKeyName()} = (string) Str::uuid(); } }); } public function getIncrementing() { return false; } public function getKeyType() { return 'string'; } }使用 \Illuminate\Support\Str 輕鬆產生 UUID.。 getIncrementing () 方法告訴 Laravel 該模型的主鍵不會自增 (因為我們設定的是 false), 而 getKeyType () 方法告訴 Laravel 該模型的主鍵是字串類型。 bootUsesUuid () 方法讓我們可以使用 Laravel 強大的生命週期鉤子。你可以 在這來哦藕節更多詳細資訊。基本上我們的程式碼已經可以告訴 Laravel,當建立該模型的新實例時,為其設定 UUID 主鍵! 現在,我們可以使用 use 關鍵字在模型上輕鬆實現此特徵。
<?php namespace App; use Illuminate\Database\Eloquent\Model; ... class Employee extends Model { ... use \App\Http\Traits\UsesUuid; ... }
將 UUID 引用為外鍵
要將表上的 UUID 引用為外鍵,只需更改表上外鍵欄位的類型。如下...Schema::create('another_table', function(Blueprint $table) { $table->id(); $table->unsignedBigInteger('employee_id'); $table->string('some_field'); $table->foreign('employee_id') ->references('id') ->on('shifts') ->onDelete('cascade'); });... 我們在引用 employee_id 外鍵時創建了一個無符號大整數的資料類型,對此進行如下修改:
Schema::create('another_table', function(Blueprint $table) { $table->id(); $table->uuid('employee_id'); $table->string('some_field'); $table->foreign('employee_id') ->references('id') ->on('shifts') ->onDelete('cascade'); });那樣簡單!還有一件事...
UUID 和多態關係
您可能會發現自己透過自己的操作或要引入的套件以多態關係引用了該模型。在遷移中,該表可能看起來像這樣:public function up() { Schema::create('some_package_table', function (Blueprint $table) { $table->bigIncrements('id'); $table->morphs('model'); ... } }在這裡,morphs () 方法將在資料庫中建立兩個字段,即無符號大整數類型的model_id 和字串類型的model_type 。問題在於我們的模型現在使用的是UUID 而不是遞增的整數ID,因此這會給您帶來錯誤,並顯示類似以下內容::
Data truncated for column 'model_id' at row 1我們現在需要model_id 欄位來支援我們的新UUID,它的型別是CHAR (36)。別擔心! Laravel 讓這件事變得超級簡單,你不需要手動做這件事。只需將遷移更改為:
public function up() { Schema::create('some_package_table', function (Blueprint $table) { $table->bigIncrements('id'); $table->uuidMorphs('model'); ... } }愛 Laravel 的另一個原因!編碼愉快! 推薦教學:《
Laravel教學》
以上是在 Laravel 7 中優雅使用 UUID 教程的詳細內容。更多資訊請關注PHP中文網其他相關文章!

截至2023年10月,Laravel的最新版本是10.x。 1.Laravel10.x支持PHP8.1,提升了開發效率。 2.Jetstream改進支持Livewire和Inertia.js,簡化前端開發。 3.EloquentORM增加全文搜索功能,提升數據處理性能。 4.使用時需注意依賴包兼容性,並應用緩存優化性能。

laravelmigrationsStreamLinedAtabasemagementbyByProvidingVersionControlforyourDatabaseschema.1)alloweryoutodefineandsharetherteructureofyourdatabase,MakeiteAsyTomanageChangEsovertime.2)MigrationalageChangangeSovertime.2)MigrationcancancanbecreatcanbecreateNdRununusingsImplecommands,Ensurantertatepeve

Laravel的遷移系統是開發者進行數據庫設計和管理的強大工具。 1)確保遷移文件命名清晰明了,使用動詞描述操作。 2)考慮數據完整性和性能,如為字段添加唯一約束。 3)使用事務處理確保數據庫一致性。 4)在遷移最後創建索引以優化性能。 5)保持遷移的原子性,每個文件只包含一個邏輯操作。通過這些實踐,可以編寫高效、可維護的遷移代碼。

Laravel的最新版本是10.x,發佈於2023年初。該版本帶來增強的EloquentORM功能和簡化的路由系統,提升了開發效率和性能,但升級時需謹慎測試以防引入問題。

laravelsoftdeletesallow“刪除” withoutremovingRecordSssfromtheDatabase.toimplement:1)usethesoftdeletdeleterationyourmodel.2)usewithtrashed()toincludesoft-deletedrecordsinquordsinquordsinquordsinquordsinquordsinquordsinquordsinquordsinquordsinquordsinquor sinecustomscopemscopemscopeslikeonlikeOnlikeOnlikeOnlikeOnlikeNiqueniendselline)

在Laravel中,恢復被軟刪除的記錄使用restore()方法,永久刪除使用forceDelete()方法。 1)恢復單個記錄使用withTrashed()->find()->restore(),多個記錄使用onlyTrashed()->restore()。 2)永久刪除單個記錄使用withTrashed()->find()->forceDelete(),多個記錄使用onlyTrashed()->forceDelete()。

你應該下載併升級到最新的Laravel版本,因為它提供了增強的EloquentORM功能和新的路由特性,這些更新可以提高應用程序的效率和安全性。要升級,請按照以下步驟:1.備份當前應用程序,2.更新composer.json文件至最新版本,3.運行更新命令。雖然可能會遇到一些常見問題,如廢棄函數和包兼容性,但通過參考文檔和社區支持,這些問題都可以解決。

youshouldupdateTotheLateStlaraverversionwhentheBeneFitsClearlyOutweighTheCosts.1)newfeaturesandimprovementCanenHanceCarenHanceYourApplication.2)SecurityUpdatesArecrucialifvulnerabilitysareaddresse.3)


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

WebStorm Mac版
好用的JavaScript開發工具

mPDF
mPDF是一個PHP庫,可以從UTF-8編碼的HTML產生PDF檔案。原作者Ian Back編寫mPDF以從他的網站上「即時」輸出PDF文件,並處理不同的語言。與原始腳本如HTML2FPDF相比,它的速度較慢,並且在使用Unicode字體時產生的檔案較大,但支援CSS樣式等,並進行了大量增強。支援幾乎所有語言,包括RTL(阿拉伯語和希伯來語)和CJK(中日韓)。支援嵌套的區塊級元素(如P、DIV),

Dreamweaver CS6
視覺化網頁開發工具