Как публиковать новости через API в любом паблике. Пошаговая инструкция

В этой статье я расскажу и покажу, как настроить автоматический постинг любой информации из открытых API в свою группу во ВКонтакте. Этот скрипт также можно использовать для телеграм-чата, изменив функцию самого постинга под Telegram API.

Подготовка

Мы настроим автопостинг на примере API, который отдает информацию о коронавирусе. Также будем использовать:

  • язык программирования Node.js;
  • модули VK-Promise и Node-Fetch;
  • редактор исходного кода Visual Studio Code;
  • виртуальный сервер (так как не все могут держать компьютер всегда включенным).

VDS советую брать в Timeweb — здесь высокая скорость, нормальные цены, и сразу можно выбрать установку Node.js и нужной операционной системы. Я использую Ubuntu 18.04.

Настройка

Создаем группу в соцсети и приступаем к началу написания кода в редакторе.

1. Указываем вышеупомянутые модули и токен своей страницы:

 const fetch = require("node-fetch"); var VK = require("VK-Promise"), vk = new VK(" "); // В кавычки вставляем токен своей страницы, который можно получить на специальном сайте, выбрав вариант VK API.

Должно получиться так:

2. Создаем проверку времени, чтобы посты выходили каждый час в ровное время:

 var startScript = (new Date().getHours()+1)%24;  if(new Date().getMinutes() == 0) // Таким образом указываем, что минут должно быть «0».  postvk(); // Эту функцию разберем далее.  loop();  function loop(){  var date = new Date();  if(date.getMinutes() == 0 && date.getHours()==startScript){  startScript = (startScript+1)%24 ;  postvk();  }  setTimeout(loop,30000); // Так задаем проверку раз в 30 минут.  }

3. Так как мы будем использовать await, добавляем к функции async:

 async function postvk(){

4. Используя любой открытый API, который отдает данные в виде JSON (это общий формат для представления значений и объектов), мы берем информацию:

 let urlru = 'https://thevirustracker.com/free-api?countryTotal=RU'; // Ссылка взята из документации API, с которым мы работаем.  let response = await fetch(urlru);  let ru = await response.json();

5. С помощью VK-Promise делаем пост в группе:

 return vk.wall.post({

6. В параметрах указываем строки и массивы, из которых будем брать данные:

 owner_id: -193422280, // ID вашей группы (отрицательное число).  from_group: 1, message: (`Коронавирус в РоссииnСлучаев сегодня:  ${ru.countrydata[0].total_new_cases_today}nСмертей сегодня: ${ru.countrydata[0].total_new_deaths_today}nВсего случаев: ${ru.countrydata[0].total_cases}nУмерло: ${ru.countrydata[0].total_deaths}nВыздоровело: ${ru.countrydata[0].total_recovered}nСерьезных случаев: ${ru.countrydata[0].total_serious_cases}`),  attachments: ('photo-193422280_457239018') // Таким образом добавляем фотографию в пост.  })  }

7. Нажимаем кнопку «Сохранить» и указываем имя и расширение файла в виде “index.js”. 

8. Используя данные, которые мы получили при создании сервера, подключаемся к нему по протоколу SSH и устанавливаем Node.js. Если вы заказали VDS в Timeweb и указали в дополнительном софте Node.js, то устанавливать еще раз не нужно (этот шаг пропускаем). 

9. Подключаемся к серверу по протоколу SFTP, создаем папку с любым названием и копируем в нее наш скрипт.

10. Подключаемся по SSH и прописываем в консоли:

 cd имя_папки // Здесь указываем название папки, которую создали на предыдущем шаге.  npm i VK-Promise@0.3.2  npm i node-fetch

11. Запускаем скрипт:

 node index.js

Чтобы скрипт не выключался после выхода из консоли, используем screen:

 sudo apt install screen  screen node index.js

Вот что получилось (пример поста):

Межтекстовые Отзывы
Посмотреть все комментарии
guest

Как сделать лендинг своими руками за 30 минут

Разработка #Лендинги #Настройка #Веб-дизайн #Хостинг #Конструктор Разработка лендинга – это важный этап для тех, кто собирается продвигать услуги...

Авторское право на код – как работает, когда защищает и как его зарегистрировать

Разработка #Программы #Законы #Разбор Поговорим о том, как работает авторское право на код в России и за рубежом....

Что такое дополненная реальность

Разработка #Google #Продажи #Технологии #Сервисы Выбирали когда-нибудь кроссовки или диван в интернете? Не очень удобно, верно? Было бы...

PHP: работа с БД MySQL

Разработка #Серверы #MySQL #PHP #Базы данных Базы данных используются для удобного хранения информации, а также для её структурирования....

Работа в IT: современные тенденции

Разработка #Технологии #Карьера #Менеджмент #Разбор Работа в IT-сфере как была перспективным направлением и путем к успешной карьере, так...

Как создать туристический сайт

Разработка #Веб-дизайн #Контент #Конструктор Туристический сайт – это важный интернет-источник для людей, планирующих путешествия. Его основная цель – познакомить...

Лучшие компиляторы кода и IDE для C++

Разработка #C/C#/C++ #Программы #IDE #Редакторы кода #Подборка Рассказываем о лучших компиляторах и инструментах для разработки на С++. Что...

Как вставить картинку в HTML

Разработка #Авторское право #Фото/Видео #Редакторы кода #HTML/CSS Невозможно представить ни один сайт без визуальной составляющей, в часть которой...

О CSS-препроцессорах и фреймворках: зачем они нужны и с чем их едят

Разработка #Фреймворки #Обзор #Технологии #HTML/CSS Сегодня поговорим о том, как можно сделать работу с CSS проще и удобнее,...

Сравнение VPS и облачного хостинга для Bitrix

В современном мире веб-технологий выбор между VPS (виртуальным частным сервером) и облачным хостингом для системы управления контентом, такой...

Как обучиться программированию на любом языке

Разработка #C/C#/C++ #Карьера #Веб-дизайн #Разбор #HTML/CSS Поговорим о том, что нужно делать разработчику, чтобы освоить любой язык программирования...

Как открыть закрытые вкладки в Google Chrome

Все мы хотя бы раз случайно закрывали вкладку в браузере и тут же испытывали сожаление. Но есть несколько...

10 лучших IDE

Разработка #C/C#/C++ #Ubuntu #Java #JavaScript #HTML/CSS #PHP #Python #Windows IDE (Integrated Development Environment) – это интегрированная, единая среда...

Как ускорить ответы клиентам с помощью чат-бота в VK. Пошаговая инструкция

Разработка #ВКонтакте #Боты #JavaScript Нередко бывает так, что в вашу группу во «Вконтакте» в один момент написали много...

Создаем бесплатный callback-виджет с SMS и Telegram-оповещением

Разработка #Telegram #JavaScript #HTML/CSS В этой статье мы пошагово создадим виджет обратного звонка с красивой минималистичной анимацией и...

Как публиковать новости через API в любом паблике. Пошаговая инструкция

Разработка #Telegram #ВКонтакте #JavaScript В этой статье я расскажу и покажу, как настроить автоматический постинг любой информации из...

Push-уведомления: типы, назначение, советы по созданию

Разработка #Конверсия #Интернет-магазин #Веб-дизайн #Продажи Сегодня поговорим о push-уведомлениях. Как они работают, зачем нужны и какими должны быть.  Что такое...

Создание email рассылок на Joomla

Создание почтовых рассылок – это эффективный способ рекламы и привлечения внимания к своему сайту. Я уже рассказывала о...

Лучшие сайты для изучения программирования

Разработка #Сервисы #Подборка #IDE #Карьера Рассказываем о лучших сайтах для изучения программирования.  Для удобства все ресурсы поделены на...

Как безопасно удалить неиспользуемый CSS в WordPress

Разработка #Плагины #WordPress #HTML/CSS #Оптимизация Неиспользуемый CSS – это код, который загружается при открытии страницы, но фактически не...