1. Go to this page and download the library: Download yandex/fotki library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
yandex / fotki example snippets
$api = new \Yandex\Fotki\Api($login);
// Загрузка сервисного документа, в котором ссылки на коллекции
// пункт необязательный, но в Яндексе написано, что ссылки могут
// когда-нибудь измениться
$api->loadServiceDocument()
// Аутентификация
// Принимает пароль от аккаунта или fimp-token
// Внимание! При получении Fimp-токена - Яндекс часто отвечает 502 ошибкой
try {
$api->auth($passwordOrToken);
} catch(\Yandex\Fotki\Exception\ServerError $ex) {
// Яндекс ответил 502. Повторите попытку снова. Как правило, раза с 5 удается получить токен
} catch(\Yandex\Fotki\Exception\Api\Auth $ex) {
// Что-то с самой авторизацией (см. $ex->getMessage())
}
// Сохраните токен куда-нибудь. По документации - время жизни токена неограничено
$token = $api->getAuth()->getToken();
// Получение коллекции альбомов
$collection = $api->getAlbumsCollection()
->setLimit(5) // лимит на загрузку 5 альбомов
->load();
$collection->getList();
// Загрузка всей коллекции
$collection = $api->getAlbumsCollection()->loadAll();
// Постраничная загрузка коллекции
try {
$collection = $api->getAlbumsCollection()->load()->next()->next()->next();
} catch(\Yandex\Fotki\Exception\Api\StopIteration $ex) {
// Окончание постраничной навигации
}
// Список альбомов в коллекции
$albums = $collection->getList();
$album = null;
// Проходимся по альбомам коллекции (берем первый попавшийся)
foreach($albums as $id => $item) {
$album = $item;
break;
}
// Работа с альбомом - это работа с коллекцией фотографий
// и мета-информацией об альбоме.
// Загружаем все фотки альбома
$photos = $album->loadAll()->getList();
$api = new \Yandex\Fotki\Api($login);
$api->auth($token);
// Загружаем все альбомы в коллекцию
$collection = $api->getAlbumsCollection()->loadAll();
// Сериализуем коллекцию (и можем сохранить в кэш, например)
echo serialize($collection);
$api = new \Yandex\Fotki\Api($login);
$api->oauth($token);
// Получаем путь к картинке на сервере.
$imgPath = 'path_to_photo.png';
try {
// Попробуем загрузить картинку на Яндекс.Фотки
// Вторым параметром можно (не обязательно) указать id фотоальбома, в который должна попасть фотка
$arPhoto = $api->sendPhoto(array('image'=> '@'. $imgPath,'access' => 'public'), 479011);
} catch (\Yandex\Fotki\Exception\Api $ex) {
}
// Посмотрим что получилось.
print_r($arPhoto);
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.