第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

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

Laravel ID 主要自動增量替代方案

Laravel ID 主要自動增量替代方案

PHP
富國滬深 2021-07-01 09:43:36
在我的應(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 生成的包。

  1. Webpatser 的 Laravel UUID 包
    允許為您的模型生成 UUID,設(shè)置和使用相當(dāng)簡單。這種類型的 id 是不可預(yù)測的,可能被認(rèn)為更安全,但不能在您的數(shù)據(jù)庫中排序。 GitHub

  2. Vinkla 的 Laravel Hashids 包
    保留您當(dāng)前的 id 并獲得可以解密的哈希以公開混淆 id。GitHub

  3. Hafael 的 Laraflake 封裝了
    Twitter 雪花之類的 id 生成,性能好,功能更好,可以對 id 進(jìn)行排序。GitHub

您可以查看所有三個可用的軟件包,然后選擇一個,或者您可以根據(jù)這些軟件包制作 DIY 解決方案。


查看完整回答
反對 回復(fù) 2021-07-02
  • 3 回答
  • 0 關(guān)注
  • 258 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號