php数字加密解密的程序
发布:smiling 来源: PHP粉丝网 添加日期:2018-10-16 10:55:46 浏览: 评论:0
- <?php
- /**
- * Created by PhpStorm.
- * User: Administrator
- * Date: 2016/11/1
- * Time: 12:26
- */
- /*把数字转换成字符对应解析
- * @param mixed $in String or long input to translate
- * @param boolean $to_num Reverses translation when true
- * @param mixed $pad_up Number or boolean padds the result up to a specified length
- * @param string $passKey Supplying a password makes it harder to calculate the original ID
- */
- function alphaID($in, $to_num = false, $pad_up = false, $passKey = null)
- {
- $index = "abcdefghijklmnopqrstuvwxyz0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
- if ($passKey !== null) {
- // Although this function's purpose is to just make the
- // ID short - and not so much secure,
- // with this patch by Simon Franz (http://blog.snaky.org/)
- // you can optionally supply a password to make it harder
- // to calculate the corresponding numeric ID
- 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
- } //phpfensi.com
- return $out;
- }
- $str = alphaID("1245");
- echo $str."<br/>";
- echo alphaID($str,true);
Tags: php数字加密 php数字解密
- 上一篇:php避免form表单重复提交
- 下一篇:深入分析sugarcrm php代码注入
推荐文章
热门文章
最新评论文章
- 写给考虑创业的年轻程序员(10)
- PHP新手上路(一)(7)
- 惹恼程序员的十件事(5)
- PHP邮件发送例子,已测试成功(5)
- 致初学者:PHP比ASP优秀的七个理由(4)
- PHP会被淘汰吗?(4)
- PHP新手上路(四)(4)
- 如何去学习PHP?(2)
- 简单入门级php分页代码(2)
- php中邮箱email 电话等格式的验证(2)