Acortamiento de enlaces sin grasa (F3)

Acortamiento de enlaces sin grasa (F3)

No es ninguna vergüenza acortar los enlaces a los 13, ¿verdad? Un principiante, y no sólo un principiante, debería intentar escribir su propio Link Tamer mientras aprende algún marco nuevo. Que es lo que hice. ¿Qué puedo decir? El quinto bootstrap, un marco bajo en grasas y un pedazo de alma.

aquí está manifestación, Sin embargo, el código. Para lectores como yo 😉

Marco, ¿verdad?

Por supuesto, no Laravel y similares: hoy nos conformaremos con 65 kilobytes. Marco libre de grasa. Si está familiarizado con Python Flask, tendrá la sensación de que ya se ha hecho en alguna parte:

#роутинг во Фласке
@app.route('/')
def hello_world():
    return 'Hello, World!'
//роутинг в Обезжиренном
$f3->route('GET /',
    function() {
        echo 'Hello, world!';
    }
);

OK, olvídalo. Descargar .zip desde fuera del sitio, descomprímalo en una carpeta, que al mismo tiempo se abre en su Editor de código favorito. Claro index.php y quitar todo de /ui.

Aquí todo es extremadamente simple: en la carpeta ui Tenemos todas las Vistas o, para decirlo simplemente, plantillas HTML actualizadas que le mostraremos al usuario cuando visite una URL específica.

Aquí está el esqueleto de nuestra "aplicación":

<?php
//Файл: index.php

// Kickstart the framework
$f3=require('lib/base.php');
$f3->set('DEBUG', 1);
if ((float)PCRE_VERSION<8.0)
    trigger_error('PCRE version is out of date');
$f3->config('config.ini');

//ВЕСЬ ОСТАЛЬНОЙ КОД БУДЕМ ПИСАТЬ ЗДЕСЬ

$f3->run();

Eso es todo lo que necesitas saber para comenzar. ¡Empecemos a codificar!

[para el desarrollo utilicé local XAMPP en Windows y VS Code, artículo escrito en Noushen]

Página Principal

Comencemos con la página principal. Lógico, ¿verdad?

//Файл: index.php

$f3->route('GET /',
    function($f3) { //чтобы использовать функции F3 передаем его в роут
                $view = new View; // создаем вьюшку
        echo $view->render('home.htm'); //рендерим шаблон
    }
);

Ahora necesitas escribir esta misma plantilla. Por simplicidad utilicé arranque v5 alpfa.

No olvides crear todas las plantillas en la carpeta. cebolla, de lo contrario ellos no lo hará visible al marco

<!-- Файл: ui/home.htm -->

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="<?php echo $ENCODING; ?>" />
        <meta name="viewport" content="width=device-width, initial-scale=1">
        <title>Пишем (код), сокращаем (ссылки)!</title>
        <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/5.0.0-alpha1/css/bootstrap.min.css" integrity="sha384-r4NyP46KrjDleawBgD5tp8Y7UzmLA05oM1iAEQ17CSuDqnUK2+k9luXQOfXJCJ4I" crossorigin="anonymous">
    </head>
    <body class="text-center bg-dark text-light"> <!-- темная тема ;) -->

        <!-- менюшка -->
        <nav class="m-2">
            <ul class="nav nav-pills justify-content-center">
                <li class="nav-item">
                    <a class="nav-link active" aria-current="page" href="#">Главная</a>
                </li>
                <li class="nav-item">
                    <a class="nav-link" href="#">Статья на Хабре</a>
                </li>
                <li class="nav-item">
                    <a class="nav-link" href="https://nikonovs.ru">Создатель</a>
                </li>
            </ul>
        </nav>

        <div class="container">
        <h1>Короткие ссылки уже здесь.</h1>

        <!-- Будем отправлять данные POST-запросом на /newLink -->
        <form class="mt-5 mb-3" action="/es/newLink/" method="POST">
            <div class="row justify-content-center">
                <div class="col-auto">
                <label for="inputLink" class="col-form-label">Введи ссылку:</label>
                </div>
                <div class="col-auto">
                <input required placeholder="https://" type="url" name="link" id="inputLink" class="form-control mb-1" aria-describedby="inputLink">
                </div>
                <div class="col-auto">
                <button type="submit" class="btn btn-outline-primary">Сократить!</button>
                </div>
            </div>
        </form>

        <!-- немного -->
        <p class="text-left m-auto mb-5" style="max-width: 30rem;">Lorem ipsum dolor sit, amet consectetur adipisicing elit. Omnis illum molestiae hic fugiat molestias nemo, architecto beatae repellat ullam exercitationem non ab, necessitatibus maxime quod iure ipsa quam quos! Reprehenderit. Lorem ipsum dolor, sit amet consectetur adipisicing elit. Necessitatibus eos sapiente voluptates veniam sequi delectus totam tenetur praesentium obcaecati. Repudiandae quisquam, ipsa ullam corrupti molestiae minima optio nihil est modi?</p>

        <footer class="m-2">Сделано с <img width="20" height="20" src="https://image.flaticon.com/icons/svg/833/833472.svg" alt="любовью">, <a href="https://v5.getbootstrap.com/">пятым Bootstrap'ом</a>    и <a href="https://fatfreeframework.com/">без жира</a></footer>
        </div>
    </body>
</html>

Eso es todo, nuestra página principal ya está funcionando. El formulario envía una solicitud POST con un enlace que debe acortarse.
Ahora viene la parte divertida (no).

Trabajando con la base de datos

Creemos una base de datos: MySQL. Si tiene PhpMyAdmin instalado, cree una nueva base de datos "izquierda" y luego ejecute este SQL:

SET SQL_MODE = "NO_AUTO_VALUE_ON_ZERO";
SET time_zone = "+00:00";

CREATE TABLE IF NOT EXISTS `links` (
  `code` varchar(4) NOT NULL,
  `link` varchar(1000) NOT NULL,
  `hits` int(255) NOT NULL DEFAULT '0'
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4;

ALTER TABLE `links`
  ADD UNIQUE KEY `code` (`code`);

Tendremos 3 campos para cada enlace:

  1. El código son 4 caracteres aleatorios después del dominio a través del cual se producirá la redirección, como ejemplo.com/ABC1
  2. Enlace - no acortado referencia.
  3. Visitas: la cantidad de clics en el enlace acortado.

Te contaré brevemente el principio de trabajar con una base de datos, sin grasa.

<?php
//сначала нужно подключиться к БД
$db = new DBSQL(
    'mysql:host=localhost;port=3306;dbname=linker',
    'root',
    ''
);

//Дальше есть два варианда работы с данными:

//Можно установить переменную в Фреймворк c помощью обычного SQL-запроса:
$f3->set('result', $db->exec('SELECT * FROM wherever')); 
//они будут доступны в шаблонах, как <?= $resul ? >

//А можно использовать встроенный SQL Mapper:
$row = new DBSQLMapper($db, 'links');

$row->load(array('link="https://habrahabr.ru"')); //теперь из этого объекта доступны все колонки строки, где ссылка на Хабр:
$row_value = $row->somerow; //Вот так

// Естесственно можно изменять значения:
$row->link = 'https://habr.com';
$row->save(); //изменения нужно сохранить, а что вы думали

// больше информации по работе с БД доступно здесь: https://a.nikonovs.ru/MPHR Настоятельно рекомендую прочитать, хотябы с помощью переводчика, встроенного в браузер.
?>

Empecemos a acortar.

Procesando un nuevo enlace

Crear una nueva vista en índice, que procesará la solicitud desde el formulario de la página principal.

Primero, creemos una plantilla nueva, pero muy similar a la primera (home.htm): "nuevoEnlace.htm".
Allí mostraremos el enlace ya acortado y el número de clics en él (para ver estas "estadísticas" nuevamente, debe acortar el mismo enlace nuevamente; la dirección seguirá siendo la misma).
Para producir el resultado, usaremos el truco de “paso de variables”:

<?php
//Файл: нет (пример)

//устанавливаем переменную в index'е и рендерим шаблон
$f3->set('link', $shorted_link);
$view = new View;
echo $view->render('newLink.htm');
//теперь в шаблоне можно использовать:
<?= $link ?>

Y aquí está el listado. nuevoEnlace.html:

<!-- Файл: newLink.htm -->

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="<?php echo $ENCODING; ?>" />
        <meta name="viewport" content="width=device-width, initial-scale=1">
        <title>Пишем (код), сокращаем (ссылки)!</title>
        <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/5.0.0-alpha1/css/bootstrap.min.css" integrity="sha384-r4NyP46KrjDleawBgD5tp8Y7UzmLA05oM1iAEQ17CSuDqnUK2+k9luXQOfXJCJ4I" crossorigin="anonymous">
    </head>
    <body class="text-center bg-dark text-light">
        <nav class="m-2">
            <ul class="nav nav-pills justify-content-center">
                <li class="nav-item">
                    <a class="nav-link" aria-current="page" href="/es/">Главная</a>
                </li>
                <li class="nav-item">
                    <a class="nav-link" href="#">Статья на Хабре</a>
                </li>
                <li class="nav-item">
                    <a class="nav-link" href="https://nikonovs.ru">Создатель</a>
                </li>
            </ul>
        </nav>

        <div class="container">
        <h1>Короткие ссылки уже здесь.</h1>

        <!-- Убираем из формы функционал формы и выводим переменные -->
        <form class="mt-5 mb-3">
            <div class="row justify-content-center">
                <div class="col-auto">
                    <label for="inputLink" class="col-form-label">Сократили:</label>
                </div>
                <div class="col-auto">
                    <input disabled required type="url" name="link" id="inputLink" class="form-control disabled" aria-describedby="inputLink" value="<?= $link ?>">
                </div>
            </div>
            <p class="m-2 text-secondary">По этой ссылке перешли: `<?= $hits ?>`</p>
        </form>

        <a href="/es/" class="mt-3 mb-5 btn btn-primary btn-lg">ВЕРНУТЬСЯ НА ГЛАВНУЮ</a>

        <footer class="m-2">Сделано с <img width="20" height="20" src="https://image.flaticon.com/icons/svg/833/833472.svg" alt="любовью">, <a href="https://v5.getbootstrap.com/">пятым Bootstrap'ом</a>    и <a href="https://fatfreeframework.com/">без жира</a></footer>
        </div>
    </body>
</html>

Escribimos la ruta en sí.

$f3->route('GET|POST /newLink', //мы будем обрабатывать и POST и GET
    function($f3) {

            $db = new DBSQL( //Подключение к БД новое в каждом Роуте
                'mysql:host=localhost;port=3306;dbname=linker',
                'root',
                ''
            );

            //прекрасная функция генерации радомных символов:
            $permitted_chars = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ';
            function generate_string($input, $strength = 4) {
                $input_length = strlen($input);
                $random_string = '';
                for($i = 0; $i < $strength; $i++) {
                    $random_character = $input[mt_rand(0, $input_length - 1)];
                    $random_string .= $random_character;
                }

                return $random_string;
            }

            //проверка на повторение link - нам же не нужно чтобы каждый раз генерировались новые ссылки. link - уникальный.
            $check = new DBSQLMapper($db,'links');
            $check->load(array('link="'. $link .'"'));
            if ($check->dry()) {
                $g_code = generate_string($permitted_chars);
                $row = new DBSQLMapper($db,'links');
                $row->reset();
                $row->code = $g_code;
                $row->link = $link;
                $row->save();
            } else {
                $g_code = $check->code; //если link повторяется, то показываем старый код
            }

            $short_link = 'https://'. $_SERVER['HTTP_HOST'] . '/' . $g_code; //собираем конечную ссылку

            //параметры из $_POST можно получить с помощью $f3->get('POST'), поддерживается точечная нотация (поправьте, если неправильно называю): параметр "link" можно получить так: 
            $link = $f3->get('POST.link');

            if ( !empty($f3->get('POST')) ) { //Выдаем HTML, только если POST не пустой.

            $f3->set('link', $short_link);
            $f3->set('hits', $check->hits);
            $view = new View;
            echo $view->render('newLink.htm');

            } else { //иначе - редирект на главную
                $f3->$f3->reroute('/');
            }

        }
);

¡Listo! En realidad, fue simple.

Redireccionando

Ya sólo queda un poquito por hacer:

  1. Obtener parámetro de la URL
  2. Comprobar su presencia en la base de datos.
  3. Obtenga el enlace correspondiente de la base de datos.
  4. Redirigir usuario
  5. ¡Beneficio!

Seguimos escribiendo código después de la última Ruta.

$f3->route('GET /@code', //указываем параметр после "@", он попадет в PARAMS
    function($f3) {

        //снова определяем $db
        $db = new DBSQL(
            'mysql:host=localhost;port=3306;dbname=linker',
            'root',
            ''
        );

        $code = $f3->get('PARAMS.code'); //получаем параметр

        $link = new DBSQLMapper($db,'links'); 

        //если получается получить ссылку из БД - получаем, увеличиваем количество переходов и перенаправляем
        if ($link->load(array('code="'.$code.'"', 'link=?'))) {
            $link->hits++;
            $link->save();

            $f3->reroute($link->link);
        } else {
            $f3->reroute('/'); //а если такой ссылки нет - милости просим на главную
        }
    }
);

Habrás notado que en y en la ruta nuevo enlace, y en la ruta de arriba se definirá lo mismo - después de todo código puede coincidir con "newLink" (no puede, el generador solo contiene letras mayúsculas), pero como se define primero, se ejecutará primero.

$f3→ejecutar()!

¡Gracias por leer!
Estaré encantado de que escribas un comentario y me corrijas si algo anda mal.

Y como tarea o prueba de la desidia del autor (yo), dejo una lista de lo que se puede hacer. ¡Es mejor aprender haciendo!

  • Por supuesto, esto es poco probable, pero al generar $g_código Puede volver a suceder, por lo que le sugiero que escriba una función que verifique esto.
  • También puede realizar estadísticas normales y mostrarlas después de cambiar a /@código/estadísticas
  • Prohibir la creación de enlaces al propio servicio de acortamiento de enlaces, crear una lista de recursos "protegidos" contra el acortamiento
  • Recomiendo encarecidamente que incluso en un asunto tan pequeño, realice una validación de entrada en el lado del servidor, con los errores correspondientes mostrados, no debe confiar en agregar el atributo requerido y escribir = "url" en el campo de entrada.
    camarada rojo

  • Sugerir en los comentarios...

    En contacto)

Fuente: habr.com

Añadir un comentario