问小白 wenxiaobai
资讯
历史
科技
环境与自然
成长
游戏
财经
文学与艺术
美食
健康
家居
文化
情感
汽车
三农
军事
旅行
运动
教育
生活
星座命理

短链接解码:短连接实现的原理及方法

创作时间:
作者:
@小白创作中心

短链接解码:短连接实现的原理及方法

引用
1
来源
1.
https://www.aifabu.com/details/499

短链接的实现主要分为两部分:短链接的生成和短链接的解析。下面将详细介绍这两个过程的实现原理及方法。

短链接生成原理

  1. 数据库存储:将传入的长链接存入数据库,记录创建时间,并返回自增ID。
  2. 十六进制编码:将返回的ID转换为16进制编码。例如,自增ID为10时,64位转换为A。即使记录一亿条记录,一亿个十六进制编码也只有5个字符长,非常适合用作短链接的参数。
  3. 组合短链接:将编码参数与域名组合成完整的短链接。例如,如果域名是example.com,编码参数是F9eEA,那么生成的短链接就是example.com/F9eEA

短链接解析原理

当用户访问短链接时,系统会执行以下步骤:

  1. 解析参数:从短链接中提取编码参数。
  2. 十六进制转十进制:将编码参数从十六进制转换为十进制。
  3. 数据库查询:根据转换后的ID在数据库中查找对应的长链接。
  4. 301跳转:将用户重定向到查找到的长链接。

技术实现细节

1. 配置服务器环境

需要修改主机文件并配置网站虚拟目录,启用URL重写功能。例如,在Apache服务器中,可以通过配置.htaccess文件来实现URL重写。

2. 十六进制编解码函数

以下是具体的十六进制编解码函数实现:

function b64dec($b64) { //十六进制转十进制
    $map = array(
        '0'=>0,'1'=>1,'2'=>2,'3'=>3,'4'=>4,'5'=>5,'6'=> 6,'7'=>7,'8'=>8,'9'=>9,
        'A'=>10,'B'=>11,'C'=>12,'D'=>13,'E'=>14,'F'=>15,'G'=> 16,'H'=>17,'I'=>18,'J'=>19,
        'K'=>20,'L'=>21,'M'=>22,'N'=>23,'O'=>24,'P'=>25,'Q'=> 26,'R'=>27,'S'=>28,'T'=>29,
        'U'=>30,'V'=>31,'W'=>32,'X'=>33,'Y'=>34,'Z'=>35,'a'=> 36,'b'=>37,'c'=>38,'d'=>39,
        'e'=>40,'f'=>41,'g'=>42,'h'=>43,'i'=>44,'j'=>45,'k'=> 46,'l'=>47,'m'=>48,'n'=>49,
        'o'=>50,'p'=>51,'q'=>52,'r'=>53,'s'=>54,'t'=>55,'u'=> 56,'v'=>57,'w'=>58,'x'=>59,
        'y'=>60,'z'=>61,'_'=>62,'='=>63
    );
    $dec = 0;
    $len = strlen($b64);
    for ($i = 0; $i < $len; $i++) {
        $b = $map[$b64{$i}];
        if ($b === NULL) {
            return false;
        }
        $j = $len - $i - 1;
        $dec += ($j == 0 ? $b : (2 ** $j * $b));
    }
    return $dec;
}

function b64enc($dec) { //十进制转十六进制
    $map = array(
        0=>'0',1=>'1',2=>'2',3=>'3',4=>'4' ,5=>'5',6=>'6',7=>'7',8=>'8',9=>'9',
        10=>'A',11=>'B',12=>'C',13=>'D',14=>'E',15=>'F',16=>'G ',17=>'H',18=>'I',19=>'J',
        20=>'K',21=>'L',22=>'M',23=>'N',24=>'O',25=>'P',26=>'Q ',27=>'R',28=>'S',29=>'T',
        30=>'U',31=>'V',32=>'W',33=>'X',34=>'Y',35=>'Z',36=>'a ',37=>'b',38=>'c',39=>'d',
        40=>'e',41=>'f',42=>'g',43=>'h',44=>'i',45=>'j',46=>'k ',47=>'l',48=>'m',49=>'n',
        50=>'o',51=>'p',52=>'q',53=>'r',54=>'s',55=>'t',56=>'u ',57=>'v',58=>'w',59=>'x',
        60=>'y',61=>'z',62=>'_',63=>'=',
    );
    $b64 = '';
    do {
        $b64 = $map[($dec % 64)] . $b64;
        $dec /= 64;
    } while ($dec >= 1);
    return $b64;
}

3. 数据库连接与操作

使用PDO进行数据库连接和操作:

define("HOST","localhost");
define("DB_NAME","db");
define("USER","root");
define("PASS","");

function make_short_url($url){
    $url=str_ireplace("http://","",$url);
    $pdo = new PDO("mysql:host=".HOST.";dbname=".DB_NAME,USER,PASS);
    $rs = $pdo ->query("select id from links where url='".$url."'");
    $row = $rs -> fetch();
    if ($row==false){
        $pdo -> exec("insert into links(url,ctime) values('".$url."','".mktime()."')");
        $id=$pdo -> lastInsertId();
        $short_url = b64enc($id);
        return $short_url;
    } else {
        return b64enc($row['id']);
    }
}

通过以上步骤,就可以实现一个完整的短链接生成和解析系统。这个系统不仅能够有效缩短URL长度,还能提高链接的可读性和分享效率。

© 2023 北京元石科技有限公司 ◎ 京公网安备 11010802042949号