1

2 つの問題に直面しているため、少し助けが必要です。

  1. ドメイン拡張子 (.com、.net、ect) のないリンクは、単一の単語としてデータベースに保存されます

  2. スクリプトは、主要な問題である短縮 URL の自己短縮を可能にします。

どうやって

  1. ドメイン拡張子を確認するか、そうでなければ送信に失敗します

  2. ユーザーが自分のリンクを短縮しようとしているかどうかを確認し、同様に失敗します。

私のコード:

function remove_http($url) 
{
  $disallowed = array('http://', 'https://', 'http//', 'https//');
  foreach($disallowed as $d) {
    if(strpos($url, $d) === 0) {
     return str_replace($d, '', $url);
     }
  }
  return $url;
}

$url_to_shorten = get_magic_quotes_gpc() ? stripslashes(trim($_REQUEST['url'])) : trim($_REQUEST['url']);

if(!empty($url_to_shorten) || parse_url($url_to_shorten, PHP_URL_SCHEME) )
{
    require('framework/core/config.xml.php');
    
    // check if the URL has already been shortened
    $already_shortened = mysql_result(mysql_query('SELECT id FROM ' . DB_TABLE. ' WHERE long_url="' . mysql_real_escape_string(remove_http($url_to_shorten)) . '"'), 0);
    if(!empty($already_shortened))
    {
        // URL has already been shortened
        $shortened_url = getShortenedURLFromID($already_shortened);
    }
    else
    {
        // URL not in database, insert
        mysql_query('LOCK TABLES ' . DB_TABLE . ' WRITE;');
        mysql_query('INSERT INTO ' . DB_TABLE . ' (long_url, created, creator) VALUES ("' . mysql_real_escape_string(remove_http($url_to_shorten)) . '", "' . time() . '", "' . mysql_real_escape_string($_SERVER['REMOTE_ADDR']) . '")');
        $shortened_url = getShortenedURLFromID(mysql_insert_id());
        mysql_query('UNLOCK TABLES');
    }
    echo BASE_HREF . $shortened_url;
}


function getShortenedURLFromID ($integer, $base = ALLOWED_CHARS)
{
   $length = strlen($base);
   while($integer > $length - 1)
   {
    $out = $base[fmod($integer, $length)] . $out;
    $integer = floor( $integer / $length );
   }
   return $base[$integer] . $out;
}
4

0 に答える 0