Good Night,
Here I will show you how to create your own url shortener.
First of all you need to create a table like this:
CREATE TABLE IF NOT EXISTS `urls` (
`uid` int(11) NOT NULL auto_increment,
`url` text default NULL,
`unique_chars` varchar(25) BINARY NOT NULL,
PRIMARY KEY (`uid`),
UNIQUE KEY `unique_chars` (`unique_chars`)
);
This code was taken from Abhise in this post “Create your own tinyurl with php and mySQL” that was my bigest reference, from it I took some functions and update other ones to be more efficient. For an example I changed the field to BINARY so it be CASE SENSITIVE (aaaa different from AAAA)
The Abhise says to create many files, I particularly, created one file with all functions where I add all the functions and just called the functions in the files.
We need a fucntion to connect/disconnect to mysql
error_reporting(E_ALL);
$link;
$config;
function connect_db_lurl() {
global $link;
global $config;
$hostname = “localhost”;
$username = “USUARIO”;
$password = “SENHA”;
$dbname = “DATABASE”;
$link = mysql_connect($hostname, $username, $password); // Conecta ao mysql.
mysql_select_db($dbname) or die(“Unknown database!”); // Seleciona o Banco de dados.
$config[“domain”] = “http://seudominio.com”; // Define a configuração da URL inicial
}function close_db_lurl() {
mysql_close(); // Fecha a conexão com o banco de dados
}
After this I created a function to redirect to the URL.
function redirect($url) {
header(“Location:”.$url); // Redireciona para a url.
}
Than I used the function from Abhise to generate the char sequence. (I add some chars to elevate the number of combinations
function generate_chars() {
$num_chars = 6; // Tamanho que você deseja as strings
$i = 0;
$my_keys = “123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ”; // Caracteres que valem para formação de endereço
$keys_length = strlen($my_keys);
$url = “”;
while($i<$num_chars) { // Gera sequencia aleatoria $rand_num = mt_rand(1, $keys_length-1); $url .= $my_keys[$rand_num]; $i++; } return $url; }
Created a function to verify if the key is unique.
function isUnique($chars) {
global $link;
$q = “SELECT * FROM `urls` WHERE `unique_chars`='”.$chars.”‘”;
$r = mysql_query($q, $link); // Verifica se a chave é unica.
if( mysql_num_rows($r)>0 ) {
return false;
} else {
return true;
}
}
And other to verify if the URL is in DB
function isThere($url) {
global $link;
$q = “SELECT * FROM `urls` WHERE `url`='”.$url.”‘”;
$r = mysql_query($q); // Verifica se já existe a url
if(mysql_num_rows($r)>0) {
return true;
} else {
return false;
}
}
Function to create
function create() {
global $link;
global $config;
$chars = generate_chars(); // Gera sequencia de caracteres.while(!isUnique($chars)){ // Verifica se é unico, se não for gera denovo.
$chars = generate_chars();
}$url = $_GET[“u”]; // Pega o endereço que está em ?u=endereço
$url = trim($url); // Retira espaços em branco do inicio e do fim
$url = mysql_real_escape_string($url);if(!isThere($url)) { // Caso não exista o endereço no banco.
$q = “INSERT INTO `urls` (url, unique_chars) VALUES (‘”.$url.”‘, ‘”.$chars.”‘)”;
$r = mysql_query($q, $link); // Insere o endereço
if(mysql_affected_rows()) {
$q = “SELECT * FROM `urls` WHERE `url`='”.$url.”‘”;
$r = mysql_query($q);
$row = mysql_fetch_row($r);
echo $config[“domain”].”/”.$row[2]; // Imprime endereço para acesso da nova url
} else {
echo “Desculpe, problemas com o banco de dados.”;
}
} else { // Caso já exista
$q = “SELECT * FROM `urls` WHERE `url` = ‘”.$url.”‘”;
$r = mysql_query($q); // Seleciona endereço para URL
$row = mysql_fetch_row($r);
echo $config[“domain”].”/”.$row[2]; // Imprime endereço para acesso da url.
}
}
Looking to the code I thought to create a function to get the url.
function take_lurl($lurl) {
global $link;
$q = “SELECT url FROM `urls` WHERE `unique_chars` = ‘”.$lurl.”‘”;
$r = mysql_query($q, $link); // Pega endereço original para tal string.
if(mysql_num_rows($r)>0) {
$info = mysql_fetch_array($r);
$url = $info[“url”];
} else {
echo “Sorry, link not found!”;
}
return $url;
}
Created the file “functions-little-url.php” with these functions.
index.php:
ob_start(); //Inicia Buffer de saida include("functions-little-url.php"); connect_db_lurl(); $lurl = $_GET["u"]; //Sequencia de caracteres $url = take_lurl($lurl); redirect($url); close_db_lurl(); ob_end_flush(); // Fecha buffer de saida ?>
create.php:
include("functions-little-url.php"); connect_db_lurl(); create(); close_db_lurl(); ?>
We need to add some lines do .htaccess and enable mod_rewrite.
RewriteEngine On
RewriteRule ^([1-9a-zA-Z]*)$ index.php\?u=$1 [L]
I did this in my system that uses wordpress (that already uses mod_rewrite) so it work a little bit different. This is my .htaccess
RewriteEngine On
RewriteBase /RewriteCond %{REQUEST_FILENAME} !-f # Verifica se a página acessada não é um arquivo real
RewriteCond %{REQUEST_FILENAME} !-d# Verifica se a página acessada não é um diretório
RewriteRule ^([A-Za-z0-9]{6})$ /lurl/index.php?u=$1 [L] # Caso coincida com a expressão regular redirecione para /lurl/index.php?u=$1 onde /lurl/ é o diretório que está os meus arquivos de tiny-url e [L] indica que é a ultima instrução a ser executada.# Caso não feche com a parte em cima continua nas regras “padrões” do WordPress
RewriteCond %{REQUEST_FILENAME} !-f # Verifica se a página acessada não é um arquivo real
RewriteCond %{REQUEST_FILENAME} !-d# Verifica se a página acessada não é um diretório
RewriteRule . /index.php [L]
(my URL shortener is inside /lurl/ directory but the redirect was done in matbra.com/XXXXXXX so it redirects to /lurl/
To create URLs acess create.php?u=ADDRESS
If you have any problem feel free to contact me.
Best Regards,
Matheus Bratfisch
References:
—- “Tiny Url”:
www.php.net
Wynia.org
htmlCenter
—- “Mod Rewrite”:
Apache Mod Rewrite
создание сетки pbn под ключ без воды создание сетки pbn под ключ без воды
seo продвижение москва seo продвижение москва
заказать кухню с замером https://zakazat-kuhnyu-19.ru
заказать кухню с замером https://zakazat-kuhnyu-18.ru
кухня на заказ спб от производителя недорого кухня на заказ спб от производителя недорого
кухни на заказ в спб недорого кухни на заказ в спб недорого
рулонные шторы с электроприводом на пластиковые окна рулонные шторы с электроприводом на пластиковые окна
рулонные жалюзи москва рулонные жалюзи москва
рулонные шторы автоматические купить рулонные шторы автоматические купить
шторы в оконный проем https://avtomaticheskie-rulonnye-shtory5.ru
ютуб загрузчик онлайн https://skachat-video-s-youtube-9.ru
вызов врача нарколога на дом https://narkolog-na-dom-voronezh-11.ru
прокапать от алкоголя самара прокапать от алкоголя самара
стоимость капельницы на дому екатеринбург https://kapelnicza-ot-pokhmelya-ekaterinburg-14.ru
капельница от алкоголизма капельница от алкоголизма
yacht rent Montenegro sailing Montenegro
Эта обзорная заметка содержит ключевые моменты и факты по актуальным вопросам. Она поможет читателям быстро ориентироваться в теме и узнать о самых важных аспектах сегодня. Получите краткий курс по современной информации и оставайтесь в курсе событий!
Получить дополнительные сведения – https://vivod-iz-zapoya-2.ru/
В этой информационной статье вы найдете интересное содержание, которое поможет вам расширить свои знания. Мы предлагаем увлекательный подход и уникальные взгляды на обсуждаемые темы, побуждая пользователей к активному мышлению и критическому анализу!
Подробнее тут – https://vivod-iz-zapoya-2.ru/
jili slot malaysia jili slot malaysia
100cuci bonus 100cuci bonus
slot malaysia slot malaysia
phuket homes for sale thailand phuket homes for sale thailand
Чаще всего домашний формат применяется при следующих состояниях:
Получить дополнительную информацию – анонимный вывод из запоя на дому санкт-петербург
После алкоголя в организме накапливаются токсичные продукты распада, нарушается водно-солевой баланс и страдает нервная система, что особенно выражено после запоя или при алкоголизме. Это проявляется головной болью, слабостью, тошнотой и нарушением сна. Капельница помогает ускорить процессы очищения и восстановить внутренние системы, обеспечивая более быстрое облегчение состояния и помогая человеку выйти из состояния запоев.
Получить дополнительную информацию – kapelnicza-ot-pokhmelya-voronezh-8.ru/
К основным показаниям относятся:
Подробнее тут – нарколог вывод из запоя в стационаре в нижнем новгороде
Вывод из запоя на дому в Екатеринбурге: срочная помощь, детоксикация и восстановление под контролем специалистов в наркологической клинике «Детокс»
Подробнее можно узнать тут – нарколог на дом вывод из запоя екатеринбург
Капельница от похмелья в Нижнем Новгороде: снятие симптомов похмелья, восстановление и поддержка под наблюдением врачей в наркологической клинике «Похмельная служба»
Разобраться лучше – http://www.domen.ru
Алкогольная интоксикация оказывает серьёзное влияние на организм, вызывая головную боль, тошноту, слабость и головокружение. Капельница помогает организму быстро избавиться от продуктов распада алкоголя, восстановить нормальное функционирование органов и минимизировать последствия для здоровья. Важно, что мы обеспечиваем полное наблюдение врача на протяжении всей процедуры, что помогает гарантировать безопасность пациента и максимальную эффективность лечения.
Выяснить больше – капельница от похмелья в екатеринбурге
Помощь на дому рассматривают при состояниях, связанных с острым ухудшением самочувствия после алкоголя. Чаще всего это несколько дней запоя, тяжелое похмелье, бессонница, тревога, дрожь в руках, слабость, отсутствие аппетита, тошнота, сухость во рту и ощущение истощения. В подобных случаях врачебный осмотр нужен для оценки общего состояния и выбора безопасной тактики.
Детальнее – нарколог на дом цена
888 казино 888starz-uzbekistan4.com .
Непрерывный мониторинг витальных показателей — ключевое отличие стационарного формата, обеспечивающее безопасную детоксикацию. В палатах клиники «Элегия Мед» установлены системы отслеживания частоты пульса, сатурации, температуры и артериального давления, данные с которых автоматически передаются в электронную медицинскую карту. Медицинский персонал дежурит круглосуточно, что обеспечивает мгновенную реакцию на ухудшение состояния: коррекцию инфузионной терапии, введение симптоматических препаратов, привлечение смежных специалистов при необходимости. Такая организация процесса исключает хаотичное назначение средств, предотвращает полипрагмазию и гарантирует, что каждый этап детоксикации проходит под строгим клиническим контролем. При необходимости применяются дополнительные методы очищения крови, включая плазмаферез, который эффективно помогает вывести стойкие токсины и метаболиты, не удаляемые стандартной инфузионной терапией.
Детальнее – вывод из запоя в стационаре клиника санкт-петербург
Наркологическая помощь — это комплекс медицинских мероприятий, направленных на стабилизацию состояния пациента при алкогольной или наркотической интоксикации, а также при абстинентном синдроме. В наркологической клинике «Частный медик 24» в Нижнем Новгороде помощь оказывается с учётом текущего состояния пациента, без избыточных вмешательств и с чёткой ориентацией на клинические показатели. Выезд нарколога позволяет начать лечение в первые часы ухудшения самочувствия, что снижает риски осложнений и облегчает восстановление.
Изучить вопрос глубже – наркологическая помощь
Вывод из запоя на дому в Санкт-Петербурге с анонимным выездом врача, снятием интоксикации и поддержкой в наркологической клинике «Частный медик 24»
Подробнее тут – нарколог на дом вывод из запоя
Процедура начинается с осмотра пациента. Врач оценивает основные показатели, включая давление и пульс, а также выраженность симптомов. После этого формируется состав капельницы и определяется тактика лечения, что позволяет эффективно провести вывод из запоя.
Подробнее – капельница от похмелья вызов на дом воронеж
888 starz зеркало https://www.888starz-uz3.org .
За выездом врача чаще обращаются тогда, когда человеку тяжело добраться до клиники, он ослаблен после нескольких дней употребления алкоголя или родственникам важно быстрее понять, какая тактика будет безопасной. После осмотра можно определить, нужна ли капельница, достаточно ли детоксикации на дому, требуется ли повторное наблюдение, а в дальнейшем — консультация по лечению алкоголизма, кодирование или реабилитация. В части случаев уже первый звонок позволяет понять, идет ли речь только о временном ухудшении самочувствия или о состоянии, при котором может потребоваться вывод из запоя в стационаре.
Подробнее тут – врач нарколог на дом в екатеринбурге
Вывод из запоя в стационаре в Нижнем Новгороде: профессиональное лечение, капельницы и контроль состояния пациента в наркологической клинике «Стармед».
Детальнее – вывод из запоя в стационаре в нижнем новгороде
Стационарное лечение рассматривают при состояниях, когда после длительного употребления алкоголя сохраняется выраженное ухудшение самочувствия и требуется наблюдение в течение более продолжительного времени. Обычно речь идет о нескольких днях запоя, тяжелой интоксикации, выраженной слабости, дрожи в руках, бессоннице, тревоге, скачках давления, сердцебиении, тошноте и признаках обезвоживания. В таких случаях значение имеет не только снятие острых симптомов, но и контроль общего состояния на протяжении всего периода выхода из запоя.
Подробнее – стационар вывод из запоя в санкт-петербурге
1xbet yeni giriş 1xbet yeni giriş
1xbet yeni adresi 1xbet yeni adresi
1xbet g?ncel giri? 1xbet g?ncel giri?
заказать рулонные шторы цена https://rulonnye-elektroshtory.ru
8888 bet http://www.888starz-bet1.com .
Co wyróżnia Slottica na tle innych stron podobnych do Kasyno Total? Lobby gier stale rośnie dzięki współpracy z uznanymi studiami developerskimi, takimi jak Maskot Gaming, BGaming, Play’n Go, Gamzix, NetEnt oraz Playson. Dzięki temu gracze mają dostęp zarówno do klasycznych automatów, jak i nowoczesnych slotów z rozbudowaną grafiką i dodatkowymi funkcjami bonusowymi.
1xbet giriş azerbaycan 1xbet giriş azerbaycan
1xbet azeri 1xbet azeri
тінь над зоною смотреть фильм проект конец света
1xbet giriş azerbaycan 1xbet giriş azerbaycan
xbet giriş xbet giriş
для рулонных штор https://avtomaticheskie-rulonnye-shtory5.ru