某些软件在登录的时候,经常会要求用户输入一个系统发过来的随机密码(或称校验码),用于对用户的身份进行校验,防止恶意登录。
要求用C语言生成一组长度为6位的随机密码串。
rand函数简介
rand函数是真正的随机数生成器,它会返回一个范围在0到RAND_MAX(2147483647)之间随机数值。
该函数的原型为:int rand(void);
在使用该函数的时候,要包含头文件“stdlib.h”。
/********************************************************************** * 版权所有 (C)2015, Zhou Zhaoxiong。 * * 文件名称:TestRand.c * 文件标识:无 * 内容摘要:测试rand()函数的用法 * 其它说明:无 * 当前版本: V1.0 * 作 者: Zhou Zhaoxiong * 完成日期: 20150316 * **********************************************************************/ #include <stdio.h> #include <stdlib.h> #include <string.h> // 重定义数据类型 typedef unsigned char UINT8; typedef signed int INT32; typedef unsigned int UINT32; /********************************************************************** * 功能描述:主函数 * 输入参数:无 * 输出参数:无 * 返 回 值:无 * 其它说明:无 * 修改日期 版本号 修改人 修改内容 * ------------------------------------------------------------------- * 20150316 V1.0 Zhou Zhaoxiong 创建 ***********************************************************************/ INT32 main() { UINT32 iLoopFlag = 0; UINT32 iRandValue = 0; UINT8 szRandValue[100] = {0}; UINT8 szFetchValue[100] = {0}; for (iLoopFlag = 0; iLoopFlag < 20; iLoopFlag ++) // 生成20个随机密码 { iRandValue = rand(); snprintf(szRandValue, sizeof(szRandValue)-1, "%d", iRandValue); if (strlen(szRandValue) >= 6) // 获取后六位 { strncpy(szFetchValue, szRandValue+strlen(szRandValue)-6, 6); printf("%s\n", szFetchValue); } else // 位数不足, 在左边补0 { snprintf(szFetchValue, sizeof(szFetchValue)-1, "%0*d%s", 6-strlen(szRandValue), 0, szRandValue); printf("%s\n", szFetchValue); } } return 0; }
makefile文件内容
TestRand : TestRand.c
gcc -c -g TestRand.c
gcc -g -o release/TestRandTestRand.o
rm *.o
随机密码的生成
执行“make”命令之后,转到“release”目录之下,执行“TestRand”命名,生成的随机密码如下所示:
289383
930886
692777
636915
747793
238335
885386
760492
516649
641421
202362
490027
368690
520059
897763
513926
180540
383426
089172
455736