时间:2017-1-2来源:本站原创作者:佚名

在我们注册某些网站的时候,很多需要提供手机号,用来接收验证码来完成注册。我们知道,每次的验证码都是随机的,那么这里面的验证码到底是如何随机生成的呢?今天,我就给大家展示一种6位随机密码生成的例子。本算法是小编原创猜测,如有雷同不胜荣幸。

首先贴出代码。

#define_CRT_SECURE_NO_WARNINGS#include#include#includecharcode[10];intflag;voidinput();voidoutput();voidCodeGen();voidmain(){while(1){input();output();}}voidinput(){printf(“Tocontinue,按1继续,按0退出\n”);scanf(“%d”,flag);}voidoutput(){if(flag==1){CodeGen();printf(“therandomcodeforyouis:%s\n”,code);}elseprintf(“thanksforusing!\n”);}voidCodeGen(){inti,mark;srand((unsigned)time(NULL));//初始化时间种子for(i=0;i6;i++)//循环6次,生成6个字符密码{mark=rand()%36;//产生从0到35共36个随机数,用来区分代表10个阿拉伯数字和26个小写英文字母if(mark=0mark=9)code[i]=mark+48;//如果随机数在0到9之间,则密码转化为字符型的0到9elsecode[i]=mark+87;//a的ascII码为97,比如随机数是10,则代表产生的字符是a;随机数是11,则代表产生的字符是b}code[i]=‘\0’;//字符串结束符}

程序的核心部分我已经做了详细注释,不再多说。主要值得一提的是该算法的核心在于srand和rand()随机数生成算法。srand和rand函数配合产生伪随机数列。srand函数在前,作用是初始化时间种子,为rand函数产生随机数提供种子。srand(unsignedT)通过参数T改变系统提供的种子值,从而使每次产生的种子值不同,这样rand函数调用产生的伪随机数就不同。通常情况下,我们可以使用系统时间来改变种子值,srand(time(NULL)),为rand函数提供不同的种子,从而产生不同的随机数。至于rand函数的用法,简单来讲就是,rand()%M,M是正整数,表示可能随机产生0到M-1种随机数值。

密码生成的的原理非常简单,大家可以自己去尝试,如果有不明白的地方也可以回复我,我会尽快给大家回复!









































白癜风哪家最好
治疗白癜风要花多少钱

转载请注明原文网址:http://www.gzdatangtv.com/bcyyys/5447.html
------分隔线----------------------------