Как публиковать новости через 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

Что такое язык программирования

Разработка #C/C#/C++ #Программы #Обзор #Веб-дизайн #Java Программа на компьютере или смартфоне – это последовательность команд, которую создавали с...

Работаем с объектами в JavaScript

Разработка #Настройка #JavaScript В прошлой статье я рассказывал о массивах в JavaScript. Из нее мы можем понять, что...

Что такое баг: поговорим об ошибках в программировании

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

10 лучших IDE

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

Как измерить и повысить вовлечённость пользователей сайта

Автор: Виталий Купренко ­– маркетинговый копирайтер, компания по разработке мобильных и веб-приложений Cleveroad. Согласно исследованию Gallup, полностью вовлечённые...

Обзор лучших WYSIWYG-редакторов

Разработка #Обзор #Контент #JavaScript #OpenSource Рассматриваем лучшие текстовые WYSIWYG-редакторы, которые можно встроить на сайты и в веб-приложения. Полнофункциональные, быстрые...

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

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

Как установить Java Development Kit

Разработка #IDE #Linux #Разбор #Java Для разработки на Java должен быть установлен комплект разработчика приложений – Java Development Kit...

Как настроить Sublime Text 3

Разработка #Программы #Редакторы кода #JavaScript #HTML/CSS Sublime Text 3 – это текстовый редактор, разработанный для верстальщиков и программистов....

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

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

Как пользоваться редактором Atom

Разработка #GitHub #Редакторы кода #HTML/CSS #PHP Atom – это многофункциональный текстовый редактор от разработчиков GitHub. Он поддерживает огромное...

Лучшие IDE и редакторы кода для Python

Разработка #Программы #IDE #Редакторы кода #Python Писать программный код можно хоть карандашом на листке бумаги. Рационально ли это?...

Что почитать программисту: 10 популярных книг по разработке

Разработка #Подборка #Программы #Веб-дизайн #Наука Какую литературу стоит прочитать программисту, чтобы стать более квалифицированным специалистом и превратиться из...

Как пользоваться Visual Studio Code

Разработка #IDE #Редакторы кода #Программы #Обзор #Windows Visual Studio Code – это один из наиболее популярных редакторов кода,...

Руководство по разработке приложений: как сделать приложение для iOS и Android самостоятельно

Разработка #Конверсия #Подборка #Разбор #UX/UI #Конструктор Разработка мобильного приложения от А до Я – это довольно долгая и...

Что такое скрам-доска

Разработка #Программы #Обзор #Менеджмент #Оптимизация Поговорим об одном из наиболее часто используемых инструментов для повышения эффективности команды.  Что такое...

Метатег viewport: почему он важен и как его правильно использовать

Разработка #Настройка #HTML/CSS #Оптимизация Viewport — это область, которую видит пользователь на экране, когда заходит на страницу сайта...

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

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

Основные элементы эффективной стратегии конверсии: UX, SEO и CRO

Автор: Питер Джоубс (Peter Jobes) – контент-менеджер, Solvid Digital. По мере выстраивания онлайн-присутствия бизнеса в интернете, применяемые маркетинговые стратегии...

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

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