Ответ 1
Используя идентификатор пользователя вместо <id> , вы можете получить изображение с большим разрешением по адресу:
http://graph.facebook.com/<id>/picture?type=large
Я использую facebook graph api, и я выдаю эту команду
/V2.0/me/home
он возвращает что-то вроде:
"id": "xxxxxxxxxxxxxxxxxxxxxx",
"from": {
"id": "xxxxxxxxxxxxxxxxx",
"name": "Roger"
},
"story": "Roger shared a link.",
"picture": "https://fbexternal-a.akamaihd.net/safe_image.php?d=AQB2VeutsxS6ht3i&w=154&h=154&url=https%3A%2F%2Fwww.facebook.com%2Fads%2Fimage%2F%3Fd%3DAQIuWnred6mG7Ti280buWL8uhE00-W2H0Eom1PzNa3Av0x3y7JieMPqLmxAFYsCRKh0Zr8u_PyWO1lFbTknlj_DaksBoFiaD8d2yIWLOGNYKie1w9Kff6vyyElxnfrlHH7uSRhwycKNakg7szgWtBBwC",
"link": "http://xxxxxx.com",
проблема связана с тегом "картинка" выше, где после этого указывается URL-адрес изображения.
Если вы вставляете этот URL-адрес в свой браузер, вы получаете небольшое изображение уменьшенного размера, но на реальной странице facebook его изображение имеет гораздо более крупную версию с высоким разрешением того же изображения.
Это то же самое для всех URL-адресов, которые он отправляет обратно. Некоторые URL-адреса заканчиваются на _s.jpg, и я могу изменить это на _n.jpg, чтобы сделать его более крупным, но это не работает для URL-адресов, которые не имеют _s.jpg в конце, например, выше.
Кто-нибудь знает команду facebook-graph-api, чтобы facebook отправил URL-адрес, указывающий на изображение большего разрешения, вместо отправки обратных URL-адресов, указывающих на все миниатюры? Или как изменить URL-адрес, чтобы он указывал на большое изображение с высоким разрешением?
Спасибо
Используя идентификатор пользователя вместо <id> , вы можете получить изображение с большим разрешением по адресу:
http://graph.facebook.com/<id>/picture?type=large
После того, как вы получите "id" сообщения в вашем использовании ленты новостей (в JavaScript)
pic_url = 'http://graph.facebook.com/'+ post_id +'?fields=full_picture&access_token="+ response.authResponse.accessToken;
в вашем запросе.
Пример ответа:
{
"full_picture": "https://fbexternal-a.akamaihd.net/safe_image.php?d=AQBbJqpkt2Jhf0VF&url=http\u00253A\u00252F\u00252Fwww.mixofpix.eu\u00252Fwp-content\u00252Fuploads\u00252F2014\u00252F08\u00252Flampa-oblak.jpg",
"id": "1407721719477425_1467737580142505",
"created_time": "2014-08-07T20:00:51+0000"
}
Получите ObjectId из поля "object_id" для определенной записи из вашего канала новостей.
Используйте это значение object_id, чтобы сделать отдельный вызов API Графа следующим образом -
https://graph.facebook.com/10152199489086727?fields=images&access_token=
Это вернет список изображений разных размеров для этого сообщения.
Пример вывода:
{
"images": [
{
"height": 462,
"source": "https://fbcdn-sphotos-h-a.akamaihd.net/hphotos-ak-xpf1/t1.0-9/10302057_10152199489086727_707407897349696496_n.jpg",
"width": 616
},
{
"height": 320,
"source": "https://fbcdn-sphotos-h-a.akamaihd.net/hphotos-ak-xpf1/t1.0-9/p320x320/10302057_10152199489086727_707407897349696496_n.jpg",
"width": 426
},.... ..
],
"created_time": "2014-07-23T18:15:16+0000",
"id": "10152199489086727"
}
Попробуйте указать поле attachments
в запросе.
/v2.0/me/home?fields=attachments
Это даст вам поле "вложения" с некоторыми носителями внутри. Вы найдете там изображения с высоким разрешением.
Вы можете получить исходный URL-адрес изображения, захватив значение строковой переменной запроса url
в свойстве "picture" сообщения и декодировать его:
var origImgSrc = decodeURIComponent(picture.match(/(url=)([^&]+)/)[2]);
Другим (более тщательным/более тяжелым) вариантом было бы отправить пакетный запрос в API-интерфейс Facebook, с первым запросом, получающим фид от меня/дома/, а затем второй с помощью? ids = для поиска любых возвращенных object_id (для фото/видео на Facebook).
Вы сделали бы это, отправив запрос POST на https://graph.facebook.com
со следующим в теле запроса:
access_token=VALID_ACCESS_TOKEN&batch=[{%20%22method%22:%22GET%22,%22name%22:%22me_home%22,%20%22relative_url%22:%22me/home?fields=object_id,full_picture%22,%20%22omit_response_on_success%22:false},%20{%20%22method%22:%22GET%22,%20%22depends_on%22:%22me_home%22,%20%22relative_url%22:%22?ids={result=me_home:$.posts.data.*.object_id}%22}]
Затем вы можете сделать какой-нибудь причудливый разбор JS, чтобы получить либо свойство full_picture, либо одно из свойств источника из массива изображений для объекта.