博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
php 两种短网址生成方法
阅读量:6925 次
发布时间:2019-06-27

本文共 2473 字,大约阅读时间需要 8 分钟。

使用以下PHP代码可以生成唯一的6位的短网址。

代码如下:

1 
0) {14 $s = $crc32 % 62;15 if ($s > 35) {16 $s = chr($s + 61);17 } elseif ($s > 9 && $s <= 35) {18 $s = chr($s + 55);19 }20 $show .= $s;21 $x = floor($crc32 / 62);22 }23 return $show;24 }25 26 echo shorturl2('http://www.google.com/');27 //4whP5428 29 //生成短网址方法230 function shortUrl2($input)31 {32 $base32 = array(33 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h',34 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p',35 'q', 'r', 's', 't', 'u', 'v', 'w', 'x',36 'y', 'z', '0', '1', '2', '3', '4', '5'37 );38 39 $hex = md5($input);40 $hexLen = strlen($hex);41 $subHexLen = $hexLen / 8;42 $output = array();43 for ($i = 0; $i < $subHexLen; $i++) {44 // 把加密字符按照8位一组16进制与0x3FFFFFFF(30位1)进行位与运算45 $subHex = substr($hex, $i * 8, 8);46 $int = 0x3FFFFFFF & (1 * ('0x' . $subHex));47 $out = '';48 for ($j = 0; $j < 6; $j++) {49 // 把得到的值与0x0000001F进行位与运算,取得字符数组chars索引50 $val = 0x0000001F & $int;51 $out .= $base32[$val];52 $int = $int >> 5;53 }54 $output[] = $out;55 }56 return $output;57 }58 59 $input = 'http://www.google.com/';60 61 $output = shorturl($input);62 var_dump($output);

 

<?php

//生成短网址方法1
function shortUrl1($url)
{
if (empty($url)) {
return FALSE;
}
$url = crc32($url);
$crc32 = sprintf("%u", $url);
$show = '';
while ($crc32 > 0) {
$s = $crc32 % 62;
if ($s > 35) {
$s = chr($s + 61);
} elseif ($s > 9 && $s <= 35) {
$s = chr($s + 55);
}
$show .= $s;
$x = floor($crc32 / 62);
}
return $show;
}

echo shorturl2('http://www.google.com/');

//4whP54

//生成短网址方法2

function shortUrl2($input)
{
$base32 = array(
'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h',
'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p',
'q', 'r', 's', 't', 'u', 'v', 'w', 'x',
'y', 'z', '0', '1', '2', '3', '4', '5'
);

$hex = md5($input);

$hexLen = strlen($hex);
$subHexLen = $hexLen / 8;
$output = array();
for ($i = 0; $i < $subHexLen; $i++) {
// 把加密字符按照8位一组16进制与0x3FFFFFFF(30位1)进行位与运算
$subHex = substr($hex, $i * 8, 8);
$int = 0x3FFFFFFF & (1 * ('0x' . $subHex));
$out = '';
for ($j = 0; $j < 6; $j++) {
// 把得到的值与0x0000001F进行位与运算,取得字符数组chars索引
$val = 0x0000001F & $int;
$out .= $base32[$val];
$int = $int >> 5;
}
$output[] = $out;
}
return $output;
}

$input = 'http://www.google.com/';

$output = shorturl($input);

var_dump($output);

 

转载地址:http://czecl.baihongyu.com/

你可能感兴趣的文章
iOS 登录页面设计
查看>>
特殊权限set_uid set_gid stick_bit 软/硬链接文件
查看>>
企业分布式SpringCloud+SpringBoot+Mybatis+shiro+微服务 技术分享
查看>>
hibernate 查询条件 对象expression
查看>>
分布式事务
查看>>
Linux就该这么学 - 第四课 - 打包压缩~第3章重定向与环境变量
查看>>
简单的单臂路由的 配置实验(华为)
查看>>
技术和商业的碰撞,谈阿里云与天猫双11这十年
查看>>
智能家居应该怎样来维护和保养—成都首脑智能家居项目
查看>>
C语言100个经典算法源码片段
查看>>
精美流程图模板分享
查看>>
Cobbler
查看>>
手机照片误删怎么恢复?这两种专业方法可以试试看
查看>>
Struts2之2.5.10.1HelloWorld
查看>>
我的友情链接
查看>>
angularjs-常用angular函数
查看>>
我们如何来轻松部署Exchange
查看>>
模板实现双向链表
查看>>
浅谈RUP的9个核心工作流(Core Workflows)
查看>>
Android开发之布局
查看>>