溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

如何使用PHP和MySQl實(shí)現(xiàn)短網(wǎng)址的生成和讀取

發(fā)布時間:2022-03-30 14:54:16 來源:億速云 閱讀:176 作者:小新 欄目:編程語言

這篇文章主要介紹了如何使用PHP和MySQl實(shí)現(xiàn)短網(wǎng)址的生成和讀取,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

PHP+MySQl實(shí)現(xiàn)短網(wǎng)址的生成和讀取

常規(guī)的方案我們將生成好的短網(wǎng)址和原網(wǎng)址對應(yīng)到一張數(shù)據(jù)表中,然后供讀取使用。我們先來看如何生成唯一的短網(wǎng)址。

//生成短網(wǎng)址 
function code62($x){ 
  $show=''; 
  while($x>0){ 
    $s=$x % 62; 
    if ($s>35){ 
      $s=chr($s+61); 
    }elseif($s>9&&$s<=35){ 
      $s=chr($s+55); 
    } 
    $show.=$s; 
    $x=floor($x/62); 
  } 
  return $show; 
} 
function shorturl($url){ 
  $url=crc32($url); 
  $result=sprintf("%u",$url); 
  return code62($result); 
} 
echo shorturl('https://www.jb51.net/'); 
//1EeIv2

使用以上PHP代碼可以生成唯一的6位的短網(wǎng)址,然后我們將生成的短網(wǎng)址與原網(wǎng)址一起寫入到MySQL表中,插入數(shù)據(jù)庫的代碼這里我就不寫了,這是PHP基礎(chǔ)。
接著,我們有一個link.php用來接收讀取url并實(shí)現(xiàn)真實(shí)跳轉(zhuǎn)。

include_once('connect.php'); //連接數(shù)據(jù)庫 
$url = $_GET['url']; 
if(isset($url) && !empty($url)){ 
  $sql = "select url from shorturl where codeid='$url'"; 
  $query = mysql_query($sql); 
  if($row=mysql_fetch_array($query)){ 
    $real_url = $row['url']; 
    header('Location: ' . $real_url); 
  }else{ 
    header('HTTP/1.0 404 Not Found'); 
    echo 'Unknown link.'; 
  } 
}else{ 
  header('HTTP/1.0 404 Not Found'); 
  echo 'Unknown link.'; 
}

代碼中,如果得到短網(wǎng)址對應(yīng)的真實(shí)url,會使用header跳轉(zhuǎn)到真實(shí)的頁面上去,否則返回404代碼。這樣我們可以使用如: http://yourdomain/link.php?url=xxx來實(shí)現(xiàn)短網(wǎng)址訪問。

繼續(xù),我們使用URL rewrite即重寫功能來實(shí)現(xiàn)諸如可以通過地址:http://yourdomain/xxx 來訪問。

以下是rewrite規(guī)則:

#Apache規(guī)則: 
RewriteRule ^/(.*)$ /link.php?url=$1 [L] 
 
#如果使用nginx,規(guī)則這樣寫: 
rewrite ^/(.*)$ /link.php?url=$1 last;

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“如何使用PHP和MySQl實(shí)現(xiàn)短網(wǎng)址的生成和讀取”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI