Хак DLE Короткая ссылка на новости (ваш_домен/id)
Хак DLE Короткая ссылка на новости (ваш_домен/{id}), полезный вариант для сокращения ссылок вашего сайта с редиректом на основную, включение тип SEO-ссылок: 1 или 2 обязательно, числовой номер id новости и УРЛ с цельной ссылкой. Представляем на https://dle9.com/ хак для DLE Короткая ссылка на новости (site.ru/{id}) [плагин], будет работать при условие установленного в настройках системы DataLife Engine SEO-ссылок: 1 или 2 тип ЧПУ.
Зачем же нужно сокращение URL?
Под URL ссылкой (гиперссылкой) подразумевается выделенный визуально текстовый или графический элемент на HTML-странице перенаправляющий (ссылающийся) на другой элемент на странице, другую интернет страницу или сайт, а также файл или картинку.
Короткая ссылка – альтернативная замена длинного адреса на короткий, является переадресацией на основную новость. Сокращенный вариант будет на тот же ресурс, отличие состоит только в ее внешнем виде. Благодаря этому, ссылка становится очень короткой и понятной, с ней удобно работать. С короткими ссылками не будет проблем, если нужно её вставить в документы, они не будет обрезаться и сокращаться. Короткие ссылки и сокращение URL намного проще публиковать, распространять, чем оригинальные, так как при публикации можно допустить ошибку, или они могут содержать слишком много знаков, и разные площадками запрещается. Сокращение URL намного меньше вызывают подозрения, можно беспрепятственно рассчитывать на премиальные партнеров, они качественно скрывают саму ссылку, но в том числе идентификатор партнера.
Удобная штука короткая ссылка, существует много сервисов по сокращению URL с разными функционалом, они позволяют, настроить отслеживание переходов, учитывают количество, считать клики по обычной ссылке и укороченной. Сам код отслеживания переходов (UTM например) виден, он содержится в ссылке — при сокращении он продолжает работать. Отслеживание кликов (click tracking) — классный инструмент, чтобы узнать количество ваших посетителей.
Сокращённый URL — один из методов передачи адресов сайтов в Интернете, где реальная ссылка, слишком может быть длинной, сокращается до максимально короткой (символов на 10–20). В базе данных сервиса укорачивателя адресов URL хранятся все ссылки.
6 причин использовать сокращенные URL в маркетинге
Многие пользуются сервисами для создания коротких адресов URL — это один из самых недооцененных инструментов интернет-маркетинга. В некоторых ситуациях может быть незаменимым инструментом в Интернете. Особенно это актуально для соцсетей с их короткими сообщениями.
Ссылки, могут быть очень длинными, в десятки и даже сотни символов:
Её не вставишь в твит, в СМС-рассылку, да и в обычном тексте она будет смотреться неэстетично.
Однако есть множество сервисов — например, гугловский goo.gl — которые позволяют уменьшить длину ссылки до компактной, удобной для использования в любых сообщениях:
Где это может пригодиться, помимо уже упомянутых соцсетей? Предлагаем вашему вниманию несколько полезных советов на эту тему.
Оптимизация конверсии с помощью URL: есть ли смысл?
Чем опасны сокращенные ссылки и как от этого защититься
Укороченные или короткие ссылки — отличный инструмент для разных решений. Он помогает отобразить чрезвычайно длинный URL, сделать так, чтобы ссылка выглядела аккуратно и профессионально. Ещё, как написано выше короткие URL используются в сообщении, где установлен порог, чтобы не превышало допустимый социальными сетями максимум общее число символов. Короткие ссылки нужны для того, чтобы интернетом было проще пользоваться. Обратная сторона медали или чем опасны сокращенные ссылки и как от этого защититься?
Как злоумышленники используют короткие URL-адреса
DataLife Engine тип ЧПУ:
Тип 1 - ссылки на полную новость будут иметь вид: http://ваш_домен/id-имя новости.html
Тип 2 — ссылки на полную новость будут иметь вид:
http://ваш_домен/категория/подкатегория/id-имя новости. .]+)/([0-9]+)-(.*).html$ /$2 [R=301,L]
* можно добавить оба — будет работать.
* не меняются ссылки в BlockPro? есть решение:
engine/modules/base/core/base.php
все что с :
$url = ...
меняем на:
$url = $this->dle_config['http_home_url'] . $data['id'];
Краткая информация о модуле (хаке)
Автор: dj-avtosh
Версия DLE: 13
Контакты: telegram: @blob42
Условия продажи: Freeware
Цена: Бесплатно
Легкий и быстрый плагин для изменения ссылок по всему сайту.
Добавил версию 0.18beta
— Исправлена постраничная навигация в новости
— Исправлена генерация sitemap
Вопросы и ответы:
Давненько искал подобное решение! Только у меня почему то на DLE 13.2 не работает, карявит немного шаблон, и урл не изменяет, при попытке удалить все кроме id, выдает хрень какую-то, новости за 1990 год,
убедитесь, что прописали в .htaccess правило
Подскажите как сделать так (http://ваш_домен/248-id.
([0-9]+)-id.html(/?)$ index.php?newsid=$1 [L]Уважаемый автор, возможно ли сделать так, чтобы в URL фигурировала категория (категории) — http://ваш_домен/category1/234 или http://ваш_домен/category1/category2/345?
Все на самом деле проще есть тег {news-id} он выводит id новости, к нему лепите http://ваш_домен/{news-id}-.html и все у вас есть короткая ссылка только нужно включить вроде ЧПУ.
это только для поделиться если делать
Спасибо за ответ и за плагин. Классная штука!
Dle хаки скачать ,как плагин (версия 0.18) news-new-link-type.xml или «Короткая ссылка на новости (site.ru/{id})», файлы с установкой кода доступны по следующей ссылке
news-new-link-type_xml.zip [13,79 Kb] (cкачиваний: 47)
Короткие ссылки для чат-ботов в мессенджерах
Если вы хотите
Их настройку производят в разделе «Рекламные кампании«.
При необходимости вы можете добавить UTM-метки в ваши трекинговые ссылки, чтобы отслеживать клики по ним и передавать их как «Цели» в системы аналитики Яндекс.Метрика, Google Analytics, Facebook Pixel.
1
.
Зайдите в модуль «Рекламные кампании» и нажмите «Добавить».
2
.
Обязательные поля для заполнения: Наименование кампании — служит для идентификации «Рекламной кампании». Дата окончания — служит для ограничения времени действия ссылки. Необязательные поля для заполнения:
Дополнительно вы можете указать id вашей системы аналитики и идентификатор цели. В таком случае при переходе по ссылке система аналитики зафиксирует достижение цели. После заполнения полей нажмите « Сохранить».
Если Целью создания Рекламной кампании было сокращение ссылки длинного URL адреса, то после нажатия кнопки Сохранить, вы увидите короткую ссылку:
Если целью создания «Рекламной кампании» было получение ссылки, которая ведет в выбранный мессенджер, при необходимости в нужный сценарий бота, то после нажатия кнопки «
Сохранить» — выберите «Редактировать» у созданной «Рекламной кампании»
Внизу страницы вы увидите подключенные у вас мессенджеры, а напротив них — ссылки. При переходе по ним вы попадете в выбранный мессенджер. Если вы указали фразу для отслеживания, которая совпадает с фразой запуска чат-бота, также запустится нужный вам сценарий бота.
УНИКУ.ID
УНИКУ.IDПрограмма для сокращения URL
от INFINITE UNY для unyku.id позволяет легко отслеживать вашу аудиторию с помощью простых и легко запоминающихся, но мощных ссылок.
Начало работыО нас
Одна короткая ссылка, БЕСКОНЕЧНЫЕ возможности.
Короткая ссылка — мощный маркетинговый инструмент, если использовать ее осторожно. Это не просто связь, а средство связи между вашим клиентом и пунктом назначения. Короткая ссылка позволяет вам собрать так много данных о ваших клиентах и их поведении.
Цель. Перенацелить.
Ориентируйтесь на своих клиентов, чтобы увеличить охват, и перенаправляйте их на соответствующую страницу. Добавьте пиксель, чтобы перенаправить их в свою рекламную кампанию в социальных сетях, чтобы захватить их.
Мера. Оптимизировать.
Делитесь своими ссылками со своей сетью и измеряйте данные, чтобы оптимизировать эффективность своей маркетинговой кампании. Получите аудиторию, которая соответствует вашим потребностям.
Таргетинг на заинтересованных пользователей. Мощные инструменты, которые работаютunyku.id позволяет вам нацеливать своих пользователей, чтобы лучше понять их поведение и предоставить им лучший общий опыт с помощью интеллектуального повторного таргетинга. Мы предоставляем вам много мощных инструментов, чтобы достичь их лучше.
Контроль над всем и вся. Полный контроль над вашими ссылкамиС премиальным членством unyku.id вы будете иметь полный контроль над своими ссылками.
Это означает, что вы можете изменить пункт назначения в любое время. Добавляйте, изменяйте или удаляйте любые фильтры в любое время.https://unyku.id/black-friday-deals-live Начало работы
5 секунд
https://unyku.id/electronics-deals Начать
https://bra.nd/fb-campaign Начало работы
Целевые клиенты
Нацеливайте своих пользователей на основе их местоположения и устройства и перенаправляйте их на специализированные страницы, чтобы повысить конверсию.
Пользовательская целевая страница
Создайте пользовательскую целевую страницу, чтобы продвигать свой продукт или услугу и вовлекать пользователей в свою маркетинговую кампанию.
Наложения
Используйте наш инструмент наложения для отображения ненавязчивых уведомлений на целевом веб-сайте. Идеальный способ отправить сообщение своим клиентам или провести рекламную кампанию.
Отслеживание событий
Добавьте свой собственный пиксель от поставщиков, таких как Facebook, и отслеживайте события, когда они происходят.
Готовы начать?
Начните использовать unyku.id и эффективно обращайтесь к своим клиентам с помощью всех необходимых инструментов. Наша платформа создана для вас, и мы постоянно совершенствуем ее.
Зарегистрируйтесь сейчас
Как создать собственное средство сокращения URL-адресов с помощью Node.js, Express и MongoDB | Инженерное образование (EngEd) Программа
Использование ссылок или URL-адресов долгое время было нормой для серфинга в Интернете. Иногда нам нужно рекламировать наш бизнес в социальных сетях. Длинные URL-ссылки — не лучший способ размещения таких ссылок, особенно в социальных сетях. Это поможет вам продвигать свои продукты или любые услуги с помощью предоставленных ссылок.
Преимущество инструментов сокращения URL-адресов заключается в том, что они помогают вернуть трафик на ваш веб-сайт.
В этом руководстве мы создадим службу сокращения URL-адресов с помощью Node.js.
Предпосылки
Базовое понимание языка программирования JavaScript.
Базовое понимание Node.js и среды Express.
В вашей системе должен быть установлен клиент Postman HTTP API.
Текстовый редактор, желательно VS Code.
В вашей системе установлен сервер базы данных MongoDB.
Настройка проекта
Создайте папку с именем URL-Shortener-Service
и откройте его в своей любимой IDE. Здесь я буду использовать VS Code. Зайдите в папку и введите npm init
, чтобы сгенерировать исходный package.json
для нашего проекта.
Эта команда потребует некоторых подсказок, чтобы пропустить это, вы можете использовать npm init -y
. Наш проект будет использовать различные пакеты npm из реестра npm.
Пакеты npm будут включать:
express
: Express — это серверная платформа веб-приложений для Node. js, используемая для создания веб-приложений и API.mongoose
: Mongoose — это асинхронный драйвер базы данных или средство сопоставления данных объектов для MongoDB. Он отвечает за подключение к базе данных и выполнение операций запроса.short-id
: Модульshort-id
создает удобные и уникальные идентификаторы для наших URL-адресов.valid-url
: это модуль, который проверяет все URL-адреса, отправленные в API.nodemon
: пакет nodemon будет установлен как зависимость разработки. Он будет постоянно контролировать наши приложения, автоматически перезапуская сервер при изменении любого файла.
Теперь нам нужно загрузить пакеты.
Выполните следующую команду на своем терминале, чтобы загрузить их:
npm install express mongoose shortid valid-url
Это загрузит именованные пакеты в папку node_modules
и обновит package. json
файл с зависимостями.
Примечание:
nodemon
является зависимостью разработки. Чтобы установить это, выполните командуnpm install --save-dev nodemon
.
Настройка экспресс-сервера
В папке URL-Shortener-Service
создайте файл с именем server.js
.
Затем следует исходный код для запуска сервера Express:
// импорт экспресс-пакета (общий синтаксис JS) константный экспресс = требуется ('экспресс') // запускаем экспресс-приложение постоянное приложение = экспресс() const PORT = process.env.PORT || 5000 // Слушаем входящие запросы app.listen(PORT, () => console.log(`сервер запущен, прослушивание PORT ${PORT}`))
Этот стартовый код импортирует экспресс-пакет. Приложение = express()
создает экземпляр нашего приложения. В нашем приложении нам нужно прослушать входящий запрос.
app.listen
принимает номер порта и функцию обратного вызова, которая вызывается при успешном подключении.
Настройка соединения MongoDB внутри «db.config.js»
Мы будем использовать пакет mongoose
, который мы установили через npm, в качестве драйвера базы данных. Для настройки базы данных создайте config
внутри нашей папки URL-Shortener-Service
. В папку config
добавьте файл с именем db.config.js
.
Это файл для добавления следующего кода подключения к базе данных:
// импорт пакета мангуста const мангуст = требуется ('мангуст') // объявить URI строки базы данных const DB_URI = 'mongodb://localhost:27017/urlshortener' // установка соединения с базой данных mongoose.connect (DB_URI, { useNewUrlParser: правда, useUnifiedTopology: правда }) константное соединение = mongoose.connection // экспортируем объект подключения module.exports = соединение
const mongoose = require('mongoose')
импортирует пакет mongoose
из папки node_modules
. Чтобы начать подключение к нашей базе данных MongoDB, нам нужен порт подключения к базе данных. Это называется строкой подключения DB_URI
с urlshortener
в качестве имени базы данных.
mongoose.connect()
— это метод, который принимает DB_URI
и объект параметров для установления соединения. module.exports
экспортирует соединение, которое будет добавлено в наш index.js
файл записи сервера.
Модель базы данных для сведений об URL
При использовании mongoose модели определяются с использованием интерфейса Schema
. Схема позволит нам определить все поля, хранящиеся в каждом документе, вместе с проверкой или значениями по умолчанию.
Затем схемы будут преобразованы в модели с помощью метода mongoose.model(). Модель — это то, что мы используем для поиска, создания, обновления и удаления документов заданного типа.
Чтобы создать нашу модель, создайте папку с именем models
.
В эту папку добавьте файл с именем UrlModel.js
и добавьте следующий код:
const mongoose = require('mongoose') // создать экземпляр схемы мангуста const URLSchema = новый mongoose.Schema({ URL-код: строка, длинный URL: строка, короткий URL: строка, свидание: { тип: Строка, по умолчанию: Date.now } }) // создаем модель из схемы и экспортируем ее module.exports = mongoose.model('Url', URLSchema)
Чтобы создать модель, нам нужно создать интерфейс схемы, импортировав пакет npm mongoose. Создается экземпляр метода mongoose.Schema
для определения с аргументом объекта и . Этот объект принимает значения, которые будут храниться в нашем документе MongoDB.
Значения включают:
urlCode
— это строковое свойство, в котором будет храниться уникальный идентификатор, связанный с каждым URL-адресом.longUrl
— это URL-адрес по умолчанию, который нам нужно сократить.Свойство
shortUrl
— это фактический короткий URL-адрес, который будет создан.Свойство
даты
имеет свойство по умолчанию и создается после создания экземпляра модели
Определение маршрутов
Наши маршруты будут в отдельной папке. Внутри папки URL-Shortener-Service
создайте папку с именем route
.
Мы создадим два файла маршрута с именами:
url.js
: это будет маршрут POST, который принимает входящий запрос с длинным URL-адресом, создает короткий URL-адрес и вставляет его в базу данных. Перейдите в папкуroute
и создайте файл с именемurl.js
.redirect.js
: это GET для наших перенаправлений URL. Он берет короткий URL-адрес и перенаправляет его на фактический длинный URL-адрес в браузере. Чтобы добавить этот файл, создайте отдельный файл с именемredirect. js 9.0123 внутри папки
маршрутов
.
url.js
Маршрут POSTТеперь давайте создадим маршрут POST.
Добавьте в файл url.js
следующий код:
// пакеты, необходимые в этом файле константный экспресс = требуется ('экспресс') const validUrl = требуется («действительный URL-адрес») const shortid = требуется ('короткий') // создание экспресс-обработчика маршрута постоянный маршрутизатор = экспресс. Маршрутизатор () // импортируем модель базы данных URL const Url = требуется ('../models/Url') // @route POST /api/url/сокращать // @description Создать короткий URL // Конечная точка базового URL-адреса API константа baseUrl = 'http:localhost:5000' router.post('/shorten', async (req, res) => { константа { длинный URL } = req.body // деструктурировать longUrl из req.body.longUrl // проверяем базовый URL, если он действителен, используя метод validUrl.isUri если (!validUrl. isUri(baseUrl)) { вернуть res.status(401).json('Неверный базовый URL') } // если допустимо, мы создаем код URL константный urlCode = shortid.generate() // проверка длинного URL, если он действителен, с помощью метода validUrl.isUri если (validUrl.isUri(longUrl)) { пытаться { /* findOne() обеспечивает соответствие только подмножеству документов в коллекции, которые соответствуют запросу. В этом случае перед созданием короткого URL-адреса мы проверяем, был ли длинный URL-адрес в БД, иначе мы его создаем. */ пусть url = ожидание Url.findOne({ длинный URL }) // URL существует и возвращает ответ если (адрес) { res.json (адрес) } еще { // присоединяем сгенерированный короткий код к базовому URL const shortUrl = baseUrl + '/' + urlCode // вызов модели Url и сохранение в БД URL-адрес = новый URL-адрес ({ длинный URL, короткий URL, URL-код, дата: новая дата() }) ждать url. save () res.json (адрес) } } // обработчик исключений поймать (ошибиться) { console.log(ошибка) res.status(500).json('Ошибка сервера') } } еще { res.status(401).json('Недопустимый длинный URL') } }) модуль.экспорт = маршрутизатор
Пошаговое руководство по коду для нашего файла url.js
:
Маршрут перенаправления
Теперь, когда мы создали маршрут POST, который создает короткий URL-адрес, нам нужно выполнить перенаправление, чтобы наш короткий URL-адрес указывал на фактический URL. Это запрос GET к нашему API Node.js для запроса.
Вот код для добавления в файл redirect.js :
const express = require('express') постоянный маршрутизатор = экспресс. Маршрутизатор () const Url = требуется ('../models/Url') // : app.get(/:код) // @маршрут ПОЛУЧИТЬ /:код // @description Перенаправление на длинный/исходный URL router. get('/:code', async (req, res) => { пытаться { // найти документ, соответствующий коду в req.params.code const url = ожидание Url.findOne({ urlCode: req.params.code }) если (адрес) { // когда допустимо, мы выполняем перенаправление вернуть res.redirect (url.longUrl) } еще { // иначе вернуть статус 404 не найдено вернуть res.status(404).json('URL не найден') } } // обработчик исключений поймать (ошибиться) { console.error(ошибка) res.status(500).json('Ошибка сервера') } }) модуль.экспорт = маршрутизатор
Давайте теперь разберемся с кодом выше. Чтобы настроить маршрутизатор в экспрессе, нам нужно импортировать модуль express
и инициализировать метод express.Router()
. Для этого маршрута API требуется созданная нами модель базы данных для сохранения короткого URL-адреса, который будет сгенерирован.
Чтобы это произошло, нам нужно импортировать действительный URL-адрес
для проверки и короткий идентификатор
, который создаст уникальный идентификатор для нашего короткого URL-адреса. Наше приложение localhost будет использовать базовый URL-адрес ( baseUrl
переменная) как http:\\localhost:5000
.
Теперь нам нужно извлечь longUrl
из тела запроса, проверить идентификатор с помощью пакета valid-url
, выполнив метод validUrl.isUri(baseUrl)
и передать URL-адрес в качестве аргумента.
Если URL-адрес действителен, мы генерируем короткий код, используя const urlCode = shortid.generate()
, и добавляем его к нашему базовому URL-адресу перед сохранением в базе данных. Этот процесс асинхронный, поэтому мы используем обещания или синтаксис асинхронного ожидания.
Окончательный файл записи index.js
const express = require("express") постоянное приложение = экспресс() // Конфигурация базы данных постоянное соединение = требуется ('./config/db') connection.once('open', () => console.log('БД подключена')) connection.on('ошибка', () => console.log('Ошибка')) // Конфигурация маршрутов app. use(express.json({ расширенный: ложь })) //разбираем тело входящего запроса в формате JSON. app.use('/', require('./routes/redirect')) app.use('/api/url', require('./routes/url')) // Слушаем входящие запросы const PORT = process.env.PORT || 5000 app.listen(PORT, console.log(`сервер запущен, прослушивание PORT ${PORT}`))
Чтобы наши маршруты работали, мы должны использовать шаблон промежуточного программного обеспечения, такой как Express. Функции промежуточного ПО имеют доступ к запросу (req) и объекту ответа (res) в цикле запроса-ответа приложения. Это объясняет методы app.use() .
Первое промежуточное ПО позволяет нашему приложению анализировать формат данных входящего запроса в формате JSON. app.use('/', require('./routes/redirect'))
— это базовый URI, который будет настраивать маршрут перенаправления.
В нашем маршруте POST базовый URL-адрес равен /api/url
и промежуточное ПО как app.use('/api/url', require('.