• PHP生成唯一ID的方法


    PHP自带生成唯一id的函数:uniqid()

    它是基于当前时间微秒数的

    用法如下:

     echo uniqid(); //13位的字符串
     echo uniqid("php_"); //当然你可以加上前缀
     echo uniqid("php_", TRUE); //如果第二个参数more_entropy为true则生成23位字符串
    

    但是它生成的标识有可能不是唯一的,所以很多人会:

    //这是第一种简单的方法,当然用sha1()函数也可以。
    echo md5(uniqid());
    //第二种,利用时间戳的方法
    echo md5(time() . mt_rand(1,1000000));
    

    如果你还担心,可以用更严谨的方法:

    function create_unique() {   
        $data = $_SERVER['HTTP_USER_AGENT'] . $_SERVER['REMOTE_ADDR']   
        .time() . rand();   
        return sha1($data);   
        //return md5(time().$data);
    }  
    
    php生成唯一订单号的方法 
    第一种
    $danhao = date('Ymd') . str_pad(mt_rand(1, 99999), 5, '0', STR_PAD_LEFT);
    
    第二种
    $danhao = date('Ymd').substr(implode(NULL, array_map('ord', str_split(substr(uniqid(), 7, 13), 1))), 0, 8);
    
    第三种 
    //生成24位唯一订单号码,格式:YYYY-MMDD-HHII-SS-NNNN,NNNN-CC,其中:YYYY=年份,MM=月份,DD=日期,HH=24格式小时,II=分,SS=秒,NNNNNNNN=随机数,CC=检查码

    @date_default_timezone_set("PRC");
     
     while(true){
     
      //订购日期
     
      $order_date = date('Y-m-d');
     
      //订单号码主体(YYYYMMDDHHIISSNNNNNNNN)
     
      $order_id_main = date('YmdHis') . rand(10000000,99999999);
     
      //订单号码主体长度
     
      $order_id_len = strlen($order_id_main);
     
      $order_id_sum = 0;
     
      for($i=0; $i<$order_id_len; $i++){
     
      $order_id_sum += (int)(substr($order_id_main,$i,1));
     
      }
     
      //唯一订单号码(YYYYMMDDHHIISSNNNNNNNNCC)
     
      $order_id = $order_id_main . str_pad((100 - $order_id_sum % 100) % 100,2,'0',STR_PAD_LEFT);
    
    第四种
    <?php 
    $yCode = array('A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J');
    $orderSn = $yCode[intval(date('Y')) - 2011] . strtoupper(dechex(date('m'))) . date('d') . substr(time(), -5) . substr(microtime(), 2, 5) . sprintf('%02d', rand(0, 99));
    ?>
    

      

  • 相关阅读:
    【BZOJ-3712】Fiolki LCA + 倍增 (idea题)
    【BZOJ-1941】Hide and Seek KD-Tree
    【BZOJ-2400】Spoj839Optimal Marks 最小割 + DFS
    【BZOJ-3709】Bohater 贪心
    【BZOJ-2342】双倍回文 Manacher + 并查集
    【BZOJ-3790】神奇项链 Manacher + 树状数组(奇葩) + DP
    【BZOJ-4568】幸运数字 树链剖分 + 线性基合并
    【BZOJ-4520】K远点对 KD-Tree + 堆
    【BZOJ-4127】Abs 树链剖分 + 线段树 (有趣的姿势)
    【BZOJ-2648&2716】SJY摆棋子&天使玩偶 KD Tree
  • 原文地址:https://www.cnblogs.com/foxy/p/9882221.html
Copyright © 2020-2023  润新知