在我的應(yīng)用程序中,大多數(shù) ID(user_id、classroom_id、post_id、assessment_id 等)都是公開可用的,這意味著它們要么位于 URL 中,要么位于目錄名稱中。出于安全原因,我希望每個表都有 10 個字符的隨機(jī) ID,而不是自動遞增的 ID。我可以使用時間戳,但這并不是唯一的,并且添加隨機(jī)數(shù)會變得更長(例如,我必須添加 4 個隨機(jī)數(shù)才能每秒處理多達(dá) 10.000 個數(shù)據(jù)庫插入到表中......純粹是假設(shè)它不可擴(kuò)展)?,F(xiàn)在我更愿意創(chuàng)建一個10 個字符的隨機(jī) ID,這會給我100 億個可能的 ID 組合。所以產(chǎn)生重復(fù)的機(jī)會很小,長度也可以接受。use Keygen;$id = Keygen::numeric(10)->generate();你覺得我的想法有道理嗎?有誰知道使用 10 個字符的主 ID 是否會對我的數(shù)據(jù)庫性能產(chǎn)生負(fù)面影響?謝謝!
3 回答

HUWWW
TA貢獻(xiàn)1874條經(jīng)驗(yàn) 獲得超12個贊
我可以推薦三個用于 ID 生成的包。
Webpatser 的 Laravel UUID 包
允許為您的模型生成 UUID,設(shè)置和使用相當(dāng)簡單。這種類型的 id 是不可預(yù)測的,可能被認(rèn)為更安全,但不能在您的數(shù)據(jù)庫中排序。 GitHubVinkla 的 Laravel Hashids 包
保留您當(dāng)前的 id 并獲得可以解密的哈希以公開混淆 id。GitHubHafael 的 Laraflake 封裝了
Twitter 雪花之類的 id 生成,性能好,功能更好,可以對 id 進(jìn)行排序。GitHub
您可以查看所有三個可用的軟件包,然后選擇一個,或者您可以根據(jù)這些軟件包制作 DIY 解決方案。
- 3 回答
- 0 關(guān)注
- 258 瀏覽
添加回答
舉報
0/150
提交
取消