asp.net 產(chǎn)生唯一隨機(jī)碼的方法分析
更新時間:2010年10月20日 20:29:04 作者:
現(xiàn)在的WEB中經(jīng)常會需要產(chǎn)生一些邀請碼、激活碼。需要是唯一并且隨機(jī)的。下面總結(jié)下一些常用的產(chǎn)生隨機(jī)碼的方法,并分享自己的1個方法.
1. 自己寫代碼產(chǎn)生隨機(jī)的數(shù)字和字母組合,每產(chǎn)生1個去數(shù)據(jù)庫查詢該隨機(jī)碼是否已存在,如果已存在,則重新產(chǎn)生,直到不重復(fù)為止。
優(yōu)點:沒發(fā)現(xiàn)有啥優(yōu)點。
缺點:產(chǎn)生速度慢,還要查詢數(shù)據(jù)庫,當(dāng)數(shù)據(jù)量大的時候,可能重復(fù)的機(jī)率會比較高,要查詢多次數(shù)據(jù)庫.
2. guid,該方法應(yīng)該是用的比較多的。
優(yōu)點:使用簡單方便,不用自己編寫額外的代碼
缺點:占用數(shù)據(jù)庫空間相對較大,特別是根據(jù)guid查詢速度比較慢(畢竟是字符串)。
3. 主鍵+隨機(jī)碼的方式,我們產(chǎn)生的隨機(jī)碼保存到數(shù)據(jù)庫肯定會有個主鍵,用該主鍵+隨機(jī)字符來組合。產(chǎn)生步驟:
1) 先從id生成器中獲取id,比如是155.
2)填充成固定位數(shù)(比如8位)的字符串(不夠位數(shù)的左邊填0,超過位數(shù)直接使用該數(shù)字),得到:00000155
3)在每個數(shù)字后面隨機(jī)插入1個字母或其它非數(shù)字符號,得到:0A0F0R0Y0H1K5L5M
這樣就可以得到1個隨機(jī)的唯一的邀請碼了。
優(yōu)點:使用也比較簡單,不用查詢數(shù)據(jù)庫。最大的優(yōu)點是查詢的時候,可以根據(jù)邀請碼直接得到主鍵id,
然后根據(jù)id去數(shù)據(jù)庫查詢(速度很快),再比較查詢出來的邀請碼和用戶提交的邀請碼是否一致。
缺點:需要使用id產(chǎn)生器,如果主鍵是數(shù)據(jù)庫自增長的就不太好用(需要先插入數(shù)據(jù)庫獲取id,再更新邀請碼)。
4. 有時候產(chǎn)品經(jīng)理說,我要求邀請碼都是數(shù)字的。why?no why? 我喜歡。*(&^(^%&^$&^$ 把方法3變通下就可以實現(xiàn)唯一的純數(shù)字隨機(jī)碼了。
1) 獲取id: 155
2) 轉(zhuǎn)換成8進(jìn)制:233
3) 轉(zhuǎn)為字符串,并在后面加'9'字符:2339
4)在后面隨機(jī)產(chǎn)生若干個隨機(jī)數(shù)字字符:2003967524987
轉(zhuǎn)為8進(jìn)制后就不會出現(xiàn)9這個字符,然后在后面加個'9',這樣就能確定唯一性。最后在后面產(chǎn)生一些隨機(jī)數(shù)字就可以。
優(yōu)缺點同方法3
目前方法3,4方法在我們產(chǎn)品中都使用了,感覺還可以。
PS:以上是個人淺見,有更好方法的同學(xué)請分享下。^_^
[作者]:BearRui(AK-47)
[博客]: http://www.cnblogs.com/BearsTaR/
優(yōu)點:沒發(fā)現(xiàn)有啥優(yōu)點。
缺點:產(chǎn)生速度慢,還要查詢數(shù)據(jù)庫,當(dāng)數(shù)據(jù)量大的時候,可能重復(fù)的機(jī)率會比較高,要查詢多次數(shù)據(jù)庫.
2. guid,該方法應(yīng)該是用的比較多的。
優(yōu)點:使用簡單方便,不用自己編寫額外的代碼
缺點:占用數(shù)據(jù)庫空間相對較大,特別是根據(jù)guid查詢速度比較慢(畢竟是字符串)。
3. 主鍵+隨機(jī)碼的方式,我們產(chǎn)生的隨機(jī)碼保存到數(shù)據(jù)庫肯定會有個主鍵,用該主鍵+隨機(jī)字符來組合。產(chǎn)生步驟:
1) 先從id生成器中獲取id,比如是155.
2)填充成固定位數(shù)(比如8位)的字符串(不夠位數(shù)的左邊填0,超過位數(shù)直接使用該數(shù)字),得到:00000155
3)在每個數(shù)字后面隨機(jī)插入1個字母或其它非數(shù)字符號,得到:0A0F0R0Y0H1K5L5M
這樣就可以得到1個隨機(jī)的唯一的邀請碼了。
優(yōu)點:使用也比較簡單,不用查詢數(shù)據(jù)庫。最大的優(yōu)點是查詢的時候,可以根據(jù)邀請碼直接得到主鍵id,
然后根據(jù)id去數(shù)據(jù)庫查詢(速度很快),再比較查詢出來的邀請碼和用戶提交的邀請碼是否一致。
缺點:需要使用id產(chǎn)生器,如果主鍵是數(shù)據(jù)庫自增長的就不太好用(需要先插入數(shù)據(jù)庫獲取id,再更新邀請碼)。
4. 有時候產(chǎn)品經(jīng)理說,我要求邀請碼都是數(shù)字的。why?no why? 我喜歡。*(&^(^%&^$&^$ 把方法3變通下就可以實現(xiàn)唯一的純數(shù)字隨機(jī)碼了。
1) 獲取id: 155
2) 轉(zhuǎn)換成8進(jìn)制:233
3) 轉(zhuǎn)為字符串,并在后面加'9'字符:2339
4)在后面隨機(jī)產(chǎn)生若干個隨機(jī)數(shù)字字符:2003967524987
轉(zhuǎn)為8進(jìn)制后就不會出現(xiàn)9這個字符,然后在后面加個'9',這樣就能確定唯一性。最后在后面產(chǎn)生一些隨機(jī)數(shù)字就可以。
優(yōu)缺點同方法3
目前方法3,4方法在我們產(chǎn)品中都使用了,感覺還可以。
PS:以上是個人淺見,有更好方法的同學(xué)請分享下。^_^
[作者]:BearRui(AK-47)
[博客]: http://www.cnblogs.com/BearsTaR/
相關(guān)文章
asp.net 在處理向該請求提供服務(wù)所需的配置文件時出錯
遭遇:“說明: 在處理向該請求提供服務(wù)所需的配置文件時出錯。請檢查下面的特定錯誤詳細(xì)信息并適當(dāng)?shù)匦薷呐渲梦募!卞e誤2010-03-03一文帶你了解.Net基于Threading.Mutex實現(xiàn)互斥鎖
互斥鎖是一個互斥的同步對象,意味著同一時間有且僅有一個線程可以獲取它。這篇文章主要介紹了一文帶你了解.Net基于Threading.Mutex實現(xiàn)互斥鎖,感興趣的可以了解一下2021-06-06Visual Studio 2017 community安裝配置方法圖文教程
這篇文章主要為大家詳細(xì)介紹了Visual Studio 2017 community安裝配置方法圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-09-09Asp.Net實現(xiàn)FORM認(rèn)證的一些使用技巧(必看篇)
下面小編就為大家?guī)硪黄狝sp.Net實現(xiàn)FORM認(rèn)證的一些使用技巧(必看篇)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-08-08SqlDataReader生成動態(tài)Lambda表達(dá)式
這篇文章主要介紹了SqlDataReader生成動態(tài)Lambda表達(dá)式,需要的朋友可以參考下2017-04-04FileUpload上傳圖片前實現(xiàn)圖片預(yù)覽功能(附演示動畫)
FileUpload控件上傳圖片前實現(xiàn)預(yù)覽,很多網(wǎng)友都希望實現(xiàn)這樣的功能,本人總結(jié)了一下,感興趣的朋友可以參考一下,希望對您有幫助2013-01-01