1. 自己写代码产生随机的数字和字母组合,每产生1个去数据库查询该随机码是否已存在,如果已存在,则重新产生,直到不重复为止。
优点:没发现有啥优点。
缺点:产生速度慢,还要查询数据库,当数据量大的时候,可能重复的机率会比较高,要查询多次数据库.
2. guid,该方法应该是用的比较多的。
优点:使用简单方便,不用自己编写额外的代码
缺点:占用数据库空间相对较大,特别是根据guid查询速度比较慢(毕竟是字符串)。
3. 主键+随机码的方式,我们产生的随机码保存到数据库肯定会有个主键,用该主键+随机字符来组合。产生步骤:
1) 先从id生成器中获取id,比如是155.
2)填充成固定位数(比如8位)的字符串(不够位数的左边填0,超过位数直接使用该数字),得到:00000155
3)在每个数字后面随机插入1个字母或其它非数字符号,得到:0A0F0R0Y0H1K5L5M
这样就可以得到1个随机的唯一的邀请码了。
优点:使用也比较简单,不用查询数据库。最大的优点是查询的时候,可以根据邀请码直接得到主键id,
然后根据id去数据库查询(速度很快),再比较查询出来的邀请码和用户提交的邀请码是否一致。
缺点:需要使用id产生器,如果主键是数据库自增长的就不太好用(需要先插入数据库获取id,再更新邀请码)。
4. 有时候产品经理说,我要求邀请码都是数字的。why?no why? 我喜欢。*(&^(^%&^$&^$ 把方法3变通下就可以实现唯一的纯数字随机码了。
1) 获取id: 155
2) 转换成8进制:233
3) 转为字符串,并在后面加'9'字符:2339
4)在后面随机产生若干个随机数字字符:2003967524987
转为8进制后就不会出现9这个字符,然后在后面加个'9',这样就能确定唯一性。最后在后面产生一些随机数字就可以。
优缺点同方法3
目前方法3,4方法在我们产品中都使用了,感觉还可以。
PS:以上是个人浅见,有更好方法的同学请分享下。^_^
[作者]:BearRui(AK-47)
[博客]: http://www.cnblogs.com/BearsTaR/
asp.net 产生唯一随机码的方法分析
2019-09-10 11:33cnblogsBearRui(AK-47) ASP.NET教程
现在的WEB中经常会需要产生一些邀请码、激活码。需要是唯一并且随机的。下面总结下一些常用的产生随机码的方法,并分享自己的1个方法.
延伸 · 阅读
- 2019-09-10asp.net(c#)限制用户输入规定的字符和数字的代码
- 2019-09-10asp.net 下拉列表无级数据绑定实现代码
- 2019-09-10asp.net中Response.Redirect与Server.Transfer的区别分析
- 2019-09-10Asp.net mvc 数据调用示例代码
- 2019-09-10asp base64 utf-8为了兼容asp.net的base64
- 2019-09-09asp.net下将页面内容导入到word模板中的方法
- ASP.NET教程
ASP.NET Sql Server安装向导(aspnet_regsql.exe)错误解决一例
这个程序是注册网站的数据库,从而提供Membership , Role , Profile 等等诸多功能和管理权限的控件的使用。...
- ASP.NET教程
asp.net Repeater显示父子表数据,无闪烁
两天在改项目bug,发现以前有人做的repeater显示父子表结构展开和关闭子表数据时总是有闪烁,于是就试着改成无闪烁的,成功了,与大家分享....
- ASP.NET教程
asp.net下按钮点击后禁用的实现代码
有时候为了不让用户连续的点击某按钮,我们会选择将其在点击后禁用。...
- ASP.NET教程
客户端用JavaScript填充DropDownList控件 服务器端读不到值
今天遇到一个奇怪的问题,某一页面需要使用三级级联下拉列表框。为提高用户体验,采用jQuery的cascadingDropDown插件调用后台Web Services来实现ajax填充。...
- ASP.NET教程
C# 解析 RAS文件 SUM 光栅文件图象的代码
C#解析RAS文件(SUM 光栅文件图象) 我只实现了24位色和8位色 这个结构也太简单了。只有文件头和数据区 。...
- ASP.NET教程
asp.net程序在调式和发布之间图片路径问题的解决方法
图片显示的时候,在VS调式时候,地址中有个虚拟文件名,发布后则没有了.所以会有图片显示叉叉的情况....
- ASP.NET教程
ASP.NET 页面间数据传递方法小结
Web 页面是无状态的, 服务器对每一次请求都认为来自不同用户,因此,变量的状态在连续对同一页面的多次请求之间或在页面跳转时不会被保留。...
- ASP.NET教程
asp.net Request获取url信息的各种方法比较
本页地址: Request.URL; 上页地址: 复制代码 代码如下: Request.UrlReferrer Request.ServerViables[http_referer] Request.RawUrl Request.RawUrl.QueryAndPath System.IO.Path.GetFileName(Request.FilePath.ToString()) 在ASP.NET编程中经常需要用Request获取url的有关信息,Request中有...