Как работать с vk API вконтакте
Здравствуйте, уважаемые читатели блога,
у многих из нас есть собственная страница в социальной сети вконтакте,
все мы знаем, что каждый пользователь вконтке имеет возможность
оставлять комментарии на стене других пользователей и различных
сообществ. Сегодня я хочу показать вам как можно работать с данными
этого сервиса, через предоставляемый вконтактом инструмент vk api , а именно как с помощью PHP получить все сообщения любого пользователя и его друзей.
Также в статье будет рассказано, как без использования API вконтакте
осуществить автоматическую отправку текста на стену группы.
Создание приложения для получения доступа к vk API
Нас будет интересовать обращение по HTTP протоколу к адресу http://api.vk.com/api.php
. На него мы будем высылать команды с определенными параметрами, а в
ответ получать какие либо данные, предоставляемые сервисом вконтакте.
Самым первым делом необходимо создать новое приложения в VK.com,
поскольку для работы с vk API надо иметь на это специальную подпись.
Кроме того надо проштудировать всю информацию представленную в документации сервиса
Внимание! Если нам нужно только обращаться со
своего сайта к API, и при этом мы совершенно не думаем о каких либо
приложениях для мобильных телефонов, или декстопных приложениях,то все
равно придется зарегистрировать его во вконтакте.
Чтобы создать свое приложение нужно перейти к форме создания приложения вконтакте и заполнить все необходимые поля:
После заполнения сохраняем введенные значения и получаем интересующие нас данные: id приложения и секретный ключ. Используя их мы в дальнейшем сможем работать с vk API.
После регистрации своего приложения мы сможем управлять настройками приложения созданного приложения
После этого нам потребуется класс для работы с vk API для этого скачиваем php библиотеку прямо с vk.com.
скачать vkapi.class.php ( Скачали: 62 чел. )
Права приложения
Для доступа к данным пользователя, приложение должно обладать набором соответствующих прав.
Предварительно, перед началом использования vkapi.class.php, надо разобраться, с тем как нашему созданному приложению, получать права для работы с тем или иным пользователем.
По умолчанию права созданного приложения – минимальны, и их не
достаточно даже для того чтобы получить список друзей указанного
пользователя, не говоря уже об оставлении записей на его стене.
Для всех приложений, api вконтакте предоставляет таблицу битовых масок, другими словами набор прав для приложения.
Советую вам самостоятельно ознакомиться с перечнем прав и их битовых масок.
Если Вы хотите получить права на "доступ к друзьям" и "доступ к
обычным и расширенным методам работы со стеной", то ваша битовая маска
будет равна: 2 + 8192 = 81924.
Если, имея битовую маску 81924, вы хотите проверить, имеет ли она доступ к расширенным методам работы со стеной, то можете сделать это таким образом:
Если права подтверждены, то 81926 & 81924 даст результат = 8192, иначе = 0
Чтобы web-приложение запросило разрешение на те или иные права, нужно дать пользователю ссылку специального формата:
1 2 3 4 5
| https://oauth.vk.com/authorize?
client_id=APP_ID&
scope=SETTINGS&
redirect_uri=REDIRECT_URI&
response_type=code |
- APP_ID – идентификатор вашего приложения;
- SETTINGS – запрашиваемые права доступа приложения;
- REDIRECT_URI – адрес, на который будет передан code. Этот адрес должен находиться в пределах домена, указанного в настройках приложения.
Перейдя по такой ссылке, пользователю, будет предложено
авторизоваться на vk.com и подтвердить разрешение на запрашиваемые
нашим приложением права.
В моем случае ссылка будет выглядеть таким образом:
1 2 3 4 5
| <a href="https://oauth.vk.com/authorize?
client_id=3471327&
scope=
notify,friends,photos,audio,video,docs,notes,pages,status,offers,questions,wall,groups,messages,notifications,stats,ads,offline,nohttps,
&
redirect_uri=http://moguta.ru/&
response_type=code ">Разрешить приложению Moguta работать с моими данными из VK</a> |
Параметром scope, я запрашиваю у пользователя разрешение на использование всех имеющихся данных, перечислив все известные идентификаторы прав.
После подтверждения, vk api высылает назад на указанный redirect_uri
код, по которому мы сможем в течении часа получать access_token чтобы
работать с API вконтакте.
Закончив процесс получения разрешения, от пользователя на доступ к
его информации, мы можем начинать работу с API вконтакте, а именно с
классом vkapi.class.php
PHP Пример работы с API vkontakte
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
| <?
$api_id = 4471324;
$secret_key = 'Y1fXgdIl3aPiejBHO4g';
function verRoles($maskBit){
$assocBitandRole= array(
'1'=>'notify',
'2'=>'friends',
'4'=>'photos',
'8'=>'audio',
'16'=>'video',
'32'=>'docs',
'64'=>'notes',
'128'=>'pages',
'256'=>'status',
'512'=>'offers',
'1024'=>'questions',
'2048'=>'wall',
'4096'=>'groups',
'8192'=>'messages',
'32768'=>'notifications',
'131072'=>'stats',
'262144'=>'ads',
'524288'=>'offline',
'1048576'=>'nohttps',
);
$res = '<br/>Доступно:';
$nores = '<br/>Не доступно:';
foreach($assocBitandRole as $bit=>$role){
if((int)($maskBit) & (int)$bit){
$res .= ",".$role;
} else {
$nores .= ",".$role;
}
}
return $res.'</br>'.$nores;
}
if(!empty($_GET['code'])){
header('Location: https://oauth.vk.com/access_token?
client_id='.$api_id.'&
client_secret='.$secret_key.'&
code='.$_GET['code'].'&
redirect_uri=http://moguta.ru/vk& ');
} else {
echo '<a target="_blank" href="https://oauth.vk.com/authorize?
client_id='.$api_id.'&
scope=notify,friends,photos,audio,video,docs,notes,pages,status,offers,questions,groups,notifications,stats,ads,offline,nohttps,&
redirect_uri=http://moguta.ru/vk&
response_type=code ">Разрешить приложению Moguta работать с моими данными из VK</a>';
}
require 'vkapi.class.php';
$VK = new vkapi($api_id, $secret_key);
//получить битовую маску приложения для конкретного пользователя
$resp = $VK->api('getUserSettings', array('uid'=>'150317299'));
echo verRoles($resp['response']); |
Результат работы скрипта должен вывести информацию о правах приложения по отношению к пользователю с id=’150317299′. Получить битовую маску прав приложения можно командой getUserSettings.
Как видите скрипт вывел перечень доступных прав исходя из значения
битовой маски. По умолчанию для каждого нового пользователя битовая
маска будет равна 0, пока посетитель сайта не перейдет по указанной
ссылке "Разрешить приложению Moguta работать с моими данными из VK".
Подтвердив разрешение, пользователь даст нам возможность работать с
его данными и мы сможем, выполнить несколько полезных в разных задачах
методов, например.
Получить список друзей пользователя:
1 2
| //получить друзей
$resp = $VK->api('friends.get', array('uid'=>'150317299')); |
Получить список последних сообщений на стене пользователя
1
| $resp = $VK->api('wall.get', array('owner_id'=>'150317299')); |
Получение лайков с указанной страницы.
1 2 3 4 5
| // owner_id — это id сайта, к которому прикручен лайк
//vkontakte.ru/developers.php?oid=-1&p=Like - в коде видны цифирки, это owner_id
$resp = $VK->api('likes.getList', array(
'type'=>'sitepage', 'owner_id'=>'2633539', 'page_url' => 'http://lifeexample.ru/php-primeryi-skriptov/mvc-fundament-internet-magazina.html'
)); |
Весь перечень доступных для vk Api методов перечислен в этом разделе документации
И в конце статьи хочу указать на одну огромную неприятность, о которой сказано в описании права wall отвечающего за работу со стеной.
Внимание, данное право доступа недоступно для сайтов (игнорируется при попытке авторизации).
Это значит, что автоматический репост сообщений на стену из
веб-приложений запрещен и можно даже не пытаться делать авторепост
новостей в группу средствами API вконтаке. Данный факт
несколько огорчил меня, поскольку все, что мне было надо от vk api это
отправлять новость с сайта moguta.ru в группу автоматически.
Тем не менее, нет ничего невозможного, если контакт не разрешает делать это своими инструментами, пойдем в обход.
Автопостинг на стену вконтакте без vk api
В сети я нашел полезный в данной задаче класс vk_poster.class.php:
Данный класс позволяет репостить на стену контакта, с помощью php библиотеки CURL. Получив необходимые для авторизации данные этот класс эмитирует действия пользователя, как будто тот авторизуется в vk.com переходит на указанную стену, и отправляет сообщение от своего имени.
Т.е. весь репост сводится к использованию CURL без API vk.
Из минусов данного подхода, только не высокая скорость работы
приложения, поскольку нужно в несколько этапов отправлять
последовательность HTTP запросов, чтобы осуществить публикацию
информации на стене сообщества, либо конкретного пользователя.
Кроме этого способа можно воспользоваться замечательной программой imacros, которая может повторить любое действие человека, но выбирать ее или нет , это зависит от конкретной задачи.
|