数字ID和字符串ID互相转化

对于想隐藏真实id的需求,比如想加密userId等
使用示例:

	 * 不指定长度
     * AlphaIDCustom(12354);  //会将数字转换为字母。
     * AlphaIDCustom('PpQXn7COf',true);//会将字母ID转换为对应的数字。
     * 指定长度
     * AlphaIDCustom(123456,false,6);//指定生成字母ID的长度为6.
     * AlphaIDCustom('xyMSSI',ture,6);//会将字母ID转换为对应的数字.

源码:

    /**
     * 数字ID和字符串ID互相转换
     * 如:
     * 不指定长度
     * AlphaIDCustom(12354);  //会将数字转换为字母。
     * AlphaIDCustom('PpQXn7COf',true);//会将字母ID转换为对应的数字。
     * 指定长度
     * AlphaIDCustom(123465,false,6);//指定生成字母ID的长度为6.
     * AlphaIDCustom('xyMSSI',ture,6);//会将字母ID转换为对应的数字.
     * @param $in
     * @param false $to_num 是否转成数字
     * @param false $pad_up 长度限制
     * @param null $passKey 加密
     * @return false|string
     */
    function AlphaIDCustom($in, $to_num = false, $pad_up = false, $passKey = null)
    {
//        $index = "abcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
        //乱序
        $index = 'SITEQZFyWtpPjRxVYc7uL094bOA8rDCBMmgki23XJnsfHd5oqNwzhUlGKave61';

        if ($passKey !== null) {

            for ($n = 0; $n<strlen($index); $n++) {
                $i[] = substr( $index,$n ,1);
            }

            $passhash = hash('sha256',$passKey);
            $passhash = (strlen($passhash) < strlen($index))
                ? hash('sha512',$passKey)
                : $passhash;

            for ($n=0; $n < strlen($index); $n++) {
                $p[] =  substr($passhash, $n ,1);
            }

            array_multisort($p,  SORT_DESC, $i);
            $index = implode($i);
        }

        $base  = strlen($index);

        if ($to_num) {
            // Digital number  <<--  alphabet letter code
            $in  = strrev($in);
            $out = 0;
            $len = strlen($in) - 1;
            for ($t = 0; $t <= $len; $t++) {
                $bcpow = bcpow($base, $len - $t);
                $out   = $out + strpos($index, substr($in, $t, 1)) * $bcpow;
            }

            if (is_numeric($pad_up)) {
                $pad_up--;
                if ($pad_up > 0) {
                    $out -= pow($base, $pad_up);
                }
            }
            $out = sprintf('%F', $out);
            $out = substr($out, 0, strpos($out, '.'));
        } else {
            // Digital number  -->>  alphabet letter code
            if (is_numeric($pad_up)) {
                $pad_up--;
                if ($pad_up > 0) {
                    $in += pow($base, $pad_up);
                }
            }

            $out = "";
            for ($t = floor(log($in, $base)); $t >= 0; $t--) {
                $bcp = bcpow($base, $t);
                $a   = floor($in / $bcp) % $base;
                $out = $out . substr($index, $a, 1);
                $in  = $in - ($a * $bcp);
            }
            $out = strrev($out); // reverse
        }

        return $out;
    }
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在达梦数据库中,字符串换为数字可以使用CAST函数。其中,将整型换为字符串可以使用以下语法: CAST(expression AS INTEGER) 例如,将一个名为"ID"的整型字段换为字符串,可以使用以下语句: CAST(ID AS VARCHAR) 需要注意的是,在达梦数据库中,不需要指定字符串长度,所以可以省略长度参数。 另外,如果需要将字符串换为其他数字类型,可以使用不同的数据类型名称,例如将字符串换为浮点数可以使用以下语法: CAST(expression AS FLOAT) 注意,在达梦数据库中,字符串换为数字时,需要确保字符串的格式是有效的数字格式,否则可能会引发错误。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [达梦数据库--强制字符串类型](https://blog.csdn.net/Ly_LittleStar/article/details/119906712)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [详解达梦数据库字符串大小写敏感](https://blog.csdn.net/qq_35273918/article/details/130410191)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值