cdkey和激活码的生成

本文介绍了如何通过结合`date +%s%N`和`md5sum`命令生成固定长度的cdkey,并讨论了如何在MySQL数据库中检查并插入这些cdkey。代码示例展示了如何设置数据库连接参数,避免中文乱码问题,以及执行SQL查询来确保cdkey的唯一性。
摘要由CSDN通过智能技术生成

      在很多产品中都有cdkey或者激活码需求,这就牵扯到cdkey的生成。cdkey(或激活码,后面已cdkey代替)一般都是由固定长度的一串数字和字母组成,生成的方法有很多,好比最简单的一种就是在26个字母和10个数字中随机抽取一个,然后重复N次,这样就生成了一个长度为N的cdkey。下面介绍一种简单实现的方法,直接上代码:

  1 #!/bin/sh
  2 CDKeyLen=10
  3 CDNum=10
  4 MYSQLCmd="mysql -h127.0.0.1 -P3306 -uroot -p123456 -Dmydb --default-character-set=utf8 -N -s -e"
  5 i=0
  6 while((i<$CDNum))
  7 do
  8     cdkey=`date +%s%N | md5sum | head -c ${CDKeyLen}`
  9     cnt=$($MYSQLCmd "select count(*) from cdkey where key='$cdkey'")
 10     if [[ $cnt == "0" ]]; then
 11         i=$(($i+1))
 12         cdkeyid=$($MYSQLCmd "insert into cdkey(key,time) valuse('$cdkey', unix_timestamp(now()));select last_insert_id();")
 13         echo $cdkeyid
 14     fi
 15 done

        其实cdkey的生成就是这句“cdkey&#

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值