• loadrunner生成唯一值


    LoadRunner生成唯一数
    2009年02月17日 星期二 22:57
    void Main()
    {
        int i;
        char uStr[64];
        srand( (unsigned)time( NULL ) );// 最好放在vuser_init里
        for (i=0;i<10;i++) {
            GetUniqueString(i,uStr);
            lr_output_message(uStr);
        }
    }
    void GetUniqueString(int inValue,char *outStr)
    {
        int id, scid;
        char *vuser_group;    
        
        lr_whoami(&id, &vuser_group, &scid);
        web_save_timestamp_param("tStamp", LAST);
        sprintf(outStr,"%s%05d%010d%04d",lr_eval_string("{tStamp}"),id,rand(),inValue);
        free(vuser_group);
    }
        建议把随机种子(srand( (unsigned)time( NULL ) );)放在脚本初始化函数里,只需要初始化一次。若放在子函数里,每次调用都初始化一下的话,产生的随机数可能是一样的。是不安全的代码!这个唯一数,有四关:毫秒级的时间+虚拟用户ID+随机数+传入的参数;基本上在同一个Controller里不会出现重复了!再稍微处理一下就可以得到想法的东西了,譬如:LoadRunner实现:计算字符串Md5 加密成md5串,再改装一下就成GUID了!
        这里有一个安全问题值得说明,随机种子最好只初始化一次,随机数的算法是和时间有一定关系的。若把随机种子放在子函数里,你会发现生成出来的随机数都是一样的。
        不要惊讶,为什么说是个安全问题,说严重一点,随机数是一种算法,有可能被别人劫获并计算出下一个随机值,故不安全!
  • 相关阅读:
    [HAOI2015]按位或——Min-Max容斥+FWT
    HDU 4773 Problem of Apollonius——圆反演
    类欧几里得小结
    线性规划(单纯形法)知识整理
    奇怪的数学题(51nod1847)——min_25筛+杜教筛+第二类斯特林数
    CSP-S 2019 游记
    2019.11.11~2019.11.12考试总结
    2019.11.6~2019.11.7考试总结
    1019.11.1~2019.11.2考试总结
    Final-阶段站立会议4
  • 原文地址:https://www.cnblogs.com/yuxuan/p/2105538.html
Copyright © 2020-2023  润新知