Dans le vaste monde d'Internet, les liens longs sont devenus un élément incontournable de la vie quotidienne. Les liens longs rendent non seulement la mémorisation difficile pour les gens, mais ils sont également très inesthétiques en termes de mise en page du texte. Alors, comment convertir des liens longs en liens courts ? PHP est un langage de programmation largement utilisé. Cet article explique comment utiliser PHP pour convertir simplement des liens longs en liens courts.
Une brève introduction aux liens courts
Un lien court est un lien spécial basé sur Internet. Il utilise un algorithme spécial pour convertir les liens longs en liens courts, améliorant ainsi l'esthétique, la lisibilité et la partageabilité du lien. Les liens courts se présentent généralement sous la forme de chaînes courtes, ne comportant généralement que 10 à 20 caractères. Après avoir converti les liens longs en liens courts, il peut non seulement être plus pratique de partager et de diffuser le lien, mais également de mieux compter les visites. du lien.
Comment générer des liens courts en utilisant php
La génération de liens courts doit être divisée en deux étapes. La première étape consiste à concevoir l'algorithme de génération de liens courts, et la deuxième étape consiste à stocker les liens courts dans la base de données, puis. analyser les liens courts lors de l'interrogation. Obtenez des liens longs et sautez.
Concevoir un algorithme de génération de liens courts
Habituellement, l'algorithme de génération de liens courts doit répondre aux exigences suivantes :
1. Le lien court généré doit être unique et non répété.
2. Le lien court généré doit être aussi proche que possible d'une chaîne courte.
3. Le lien court généré doit être réversible, c'est-à-dire que le lien long peut être restauré via le lien court.
Actuellement, il existe deux algorithmes de liens courts couramment utilisés. L'un consiste à chiffrer les liens longs pour les convertir en liens courts. Les algorithmes de chiffrement couramment utilisés incluent md5 et base64, mais la longueur des liens courts de cet algorithme est plus longue et le sera. répété ; un autre algorithme consiste à convertir les liens longs en liens courts en décimal ou en hexadécimal, et à les générer en fonction de l'horodatage actuel et des valeurs personnalisées. Cet algorithme est plus rapide à générer, et les liens courts générés sont plus courts et ne seront pas répétés. .
Ensuite, nous introduisons la méthode d'implémentation PHP consistant à utiliser le deuxième algorithme pour générer des liens courts.
Tout d'abord, nous définissons quelques variables :
$url = 'http://www.example.com/longurl'; //待转换的长链接 $base = 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ0123456789'; //定义62进制字符 $prefix = 'http://s.com/'; //自定义短链接前缀
Ensuite, nous devons convertir le lien long en un lien court décimal ou hexadécimal :
$hex = md5($url); $hexLen = strlen($hex); $subHexLen = $hexLen / 8; $output = array(); for ($i = 0; $i < $subHexLen; $i++) { $subHex = substr($hex, $i * 8, 8); $int = 0x3FFFFFFF & (1 * ('0x' . $subHex)); $out = ''; for ($j = 0; $j < 6; $j++) { $val = 0x0000003D & $int; $out .= $base[$val]; $int = $int >> 5; } $output[] = $out; } $key = array_rand($output); $shortUrl = $prefix . $output[$key];
Dans le code ci-dessus, nous utilisons d'abord md5 pour effectuer le chiffrement du lien long, puis traitons le résultat crypté et convertissez-le en un lien court décimal ou à 62 chiffres. Ensuite, un lien court est sélectionné parmi plusieurs liens courts en générant aléatoirement une valeur de clé unique, et enfin le préfixe personnalisé et le lien court unique sélectionné sont fusionnés dans le lien court final.
Stockage du lien court dans la base de données
Dans le code ci-dessus, nous avons généré le lien court, mais nous ne l'avons pas encore stocké dans la base de données. Ici, nous utilisons la base de données mysql pour stocker le lien court dans la base de données. suit :
include 'config.php'; //包含数据库连接配置文件 $long_url = 'http://www.example.com/longurl'; //长链接 //生成短链接的代码 $hex = md5($long_url); $hexLen = strlen($hex); $subHexLen = $hexLen / 8; $output = array(); for ($i = 0; $i < $subHexLen; $i++) { $subHex = substr($hex, $i * 8, 8); $int = 0x3FFFFFFF & (1 * ('0x' . $subHex)); $out = ''; for ($j = 0; $j < 6; $j++) { $val = 0x0000003D & $int; $out .= $base[$val]; $int = $int >> 5; } $output[] = $out; } $key = array_rand($output); $short_url = $prefix . $output[$key]; //将短链接存储到数据库中 $insert_sql = "INSERT INTO `short_url` (`long_url`, `short_url`, `create_time`) VALUES ('{$long_url}', '{$short_url}', NOW())"; //将长链接和短链接插入数据库中 $conn->query($insert_sql); //执行插入操作 $conn->close(); //关闭数据库连接
Dans le code ci-dessus, nous définissons deux variables long_url et short_url pour stocker respectivement les liens longs et les liens courts, puis insérons les liens longs et les liens courts dans la table short_url
en insérant des instructions SQL. Parmi eux, le champ create_time stocke l'heure à laquelle le lien court a été créé et le type de données est DATETIME.
Sauter au lien long via un lien court
Enfin, nous devons analyser le lien court, interroger le lien long correspondant dans la base de données et sauter. Le code est implémenté comme suit :
include 'config.php'; //包含数据库连接配置文件 $short_url = 'http://s.com/abcd'; //短链接 //从数据库中查询出对应的长链接 $select_sql = "SELECT long_url FROM `short_url` WHERE `short_url`='{$short_url}'"; $result = $conn->query($select_sql); //执行查询操作 $row = $result->fetch_array(MYSQLI_ASSOC); //跳转到长链接 if ($row) { $long_url = $row['long_url']; header('location:' . $long_url); //跳转到原来的长链接 exit; } else { echo '短链接不存在'; //如果短链接不存在,则输出短链接不存在 } $conn->close(); //关闭数据库连接
Dans le code ci-dessus, nous interrogeons d'abord la base de données avec le lien court comme paramètre, trouvons le lien long correspondant, et s'il existe, sautons l'utilisateur vers le lien long, sinon la sortie le lien court n'existe pas.
Résumé
php est un langage de programmation largement utilisé En vous familiarisant avec la syntaxe de base et la bibliothèque de fonctions de php, vous pouvez facilement réaliser la fonction de conversion de liens longs en liens courts. Bien que l'algorithme de génération de liens courts présenté dans cet article ne soit pas le plus complexe, il a une bonne vitesse de calcul et un caractère unique de lien, et convient à la plupart des scénarios d'application. Il est recommandé aux lecteurs d'améliorer le code en fonction des besoins réels afin d'améliorer la stabilité et la vitesse de requête de la génération de liens courts.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!