Mediathek-Inhalte, Alben und Medienelemente auflisten

Erforderliche Autorisierungsbereiche

Die Google Photos Library API umfasst mehrere Bereiche für den Zugriff auf Medienelemente und Alben. Die von verschiedenen Aufrufen zurückgegebenen Medienelemente unterscheiden sich je nach Umfang vom Entwickler angefordert wurden.

Der Bereich photoslibrary.readonly ermöglicht den Zugriff auf alle Medienelemente im in der Bibliothek des Nutzers. Der Bereich photoslibrary.readonly.appcreateddata ermöglicht Zugriff die von der App erstellt wurden. Weitere Informationen finden Sie unter Autorisierungsbereiche.

Übersicht

Eine wichtige Verwendung der API besteht darin, Medienelemente aufzulisten, die der Nutzer gesichert hat in Google Fotos hochladen. Elemente in einem bestimmten Album oder aus dem gesamten Fotogalerie (Standardansicht in der Google Fotos App) aufgelistet werden.

Sie können Fotos mithilfe von Filtern auswählen. die einem bestimmten Datum, einer bestimmten Inhaltskategorie oder einem Medientyp entsprechen. aus der Bibliothek des Nutzers. Diese Funktion wird nicht unterstützt, wenn Sie Artikel auflisten aus Alben.

Wenn Sie die Bibliotheks- und Albuminhalte auflisten, wird eine Liste der Medienelemente zurückgegeben. Anreicherungen, die Teil eines Albums sind enthalten sind. Medienelemente beschreiben ein Foto, ein Video oder andere Medien. A mediaItem enthält einen direkten Link zum Element, einen Link zum Element in Google Fotos und andere relevante Metadaten. Weitere Informationen finden Sie unter Auf Medienelemente zugreifen und mediaItems

Alben auflisten

Sie können eine Liste der Alben des Nutzers mithilfe von albums.list.

REST

Ein Beispiel für eine Anfrage:

GET https://photoslibrary.googleapis.com/v1/albums

Die Anfrage gibt das folgende Ergebnis zurück:

{
  "albums": [
    {
      "id": "album-id",
      "title": "album-title",
      "productUrl": "album-product-url",
      "coverPhotoBaseUrl": "album-cover-base-url_do-not-use-directly",
      "coverPhotoMediaItemId": "album-cover-media-item-id",
      "isWriteable": "whether-you-can-write-to-this-album",
      "mediaItemsCount": "number-of-media-items-in-album"
    },
    ...
  ],
  "nextPageToken": "token-for-pagination"
}

Java

try {
  // Make a request to list all albums in the user's library
  // Iterate over all the albums in this list
  // Pagination is handled automatically
  ListAlbumsPagedResponse response = photosLibraryClient.listAlbums();

  for (Album album : response.iterateAll()) {
    // Get some properties of an album
    String id = album.getId();
    String title = album.getTitle();
    String productUrl = album.getProductUrl();
    String coverPhotoBaseUrl = album.getCoverPhotoBaseUrl();
    // The cover photo media item id field may be empty
    String coverPhotoMediaItemId = album.getCoverPhotoMediaItemId();
    boolean isWritable = album.getIsWriteable();
    long mediaItemsCount = album.getMediaItemsCount();
  }

} catch (ApiException e) {
  // Handle error
}

PHP

try {
    // Make a request to list all albums in the user's library
    // Iterate over all the albums in this list
    // Pagination is handled automatically
    $response = $photosLibraryClient->listAlbums();
    foreach ($response->iterateAllElements() as $album) {
        // Get some properties of an album
        $albumId = $album->getId();
        $title = $album->getTitle();
        $productUrl = $album->getProductUrl();
        $coverPhotoBaseUrl = $album->getCoverPhotoBaseUrl();
        // The cover photo media item id field may be empty
        $coverPhotoMediaItemId = $album->getCoverPhotoMediaItemId();
        $isWriteable = $album->getIsWriteable();
        $totalMediaItems = $album->getTotalMediaItems();
    }
} catch (\Google\ApiCore\ApiException $e) {
    // Handle error
}

Jedes zurückgegebene Album verfügt über eine ID, die zum Abrufen des Inhalts der wie unter Albuminhalte auflisten dargestellt. Außerdem den Titel und die Anzahl der darin enthaltenen Medienelemente enthält.

Das productUrl verweist auf das Album in Google Fotos, das ein die der Nutzer öffnet.

coverPhotoMediaItemId enthält das Medienelement ID, die steht für das Titelbild dieses Albums. Um auf dieses Titelbild zuzugreifen, verwende coverPhotoBaseUrl Sie sollten die coverPhotoBaseUrl nicht direkt verwenden, ohne unter Angabe zusätzlicher zusätzlicher Parameter.

Alben, die im Konto des Nutzers erstellt oder zum Konto des Nutzers hinzugefügt wurden Konto und die deine App freigegeben hat, füge eine zusätzliche shareInfo-Property hinzu. Weitere Informationen

Alben können auch mit einem isWriteable-Flag versehen sein, um anzugeben, ob Sie Medien erstellen können. Elemente im Album. Dieses Flag ist standardmäßig auf false gesetzt, wenn es nicht zurückgegeben wird. Es ist abhängig von den Zugriffsrechten, die Ihrer Anwendung gewährt wurden, darunter:

  • Wer hat das Album erstellt?
  • Ob es freigegeben ist oder nicht
  • Was umfasst der Nutzer? genehmigt wurde.

Diese Markierung kann sich ändern, wenn sich eines dieser Kriterien ändert. Weitere Informationen finden Sie unter Alben erstellen Die Antwort enthält auch ein nextPageToken. Weitere Informationen finden Sie unter Paginierung:

Die Antwort für leere Alben variiert in dieser Hinsicht: mediaItemsCount und coverPhotoMediaItemId sind standardmäßig auf 0 gesetzt und werden in der REST weggelassen. Antwort. Beachten Sie außerdem, dass coverPhotoBaseUrl auf einen Standardplatzhalter verweist Bild.

Bibliotheksinhalte auflisten

Sie können alle Medienelemente aus der Google Fotos-Galerie des Nutzers auflisten. Archivierte und gelöschte Elemente sind nicht enthalten. Sie können Medienelemente anhand ihrer Inhalte, Datum und andere Eigenschaften zu erstellen, Filter. Wenn der Nutzer kein das auf dem Tab Teilen ihrer Google Fotos verfügbar ist, Bibliothek befindet, ist dieser Artikel nicht in dieser Liste enthalten.

Rufen Sie zum Abrufen eines Medienelements mediaItems.list.

REST

Ein Beispiel für eine Anfrage:

GET https://photoslibrary.googleapis.com/v1/mediaItems
Content-type: application/json
Authorization: Bearer oauth2-token
{
  "pageSize": "100",
}

Die GET-Anfrage gibt die folgende Antwort zurück:

{
  "mediaItems": [
    ...
  ],
  "nextPageToken": "token-for-pagination"
}

Java

try {
  // Make a request to list all media items in the user's library
  // Iterate over all the retrieved media items
  // Pagination is handled automatically
  ListMediaItemsPagedResponse response = photosLibraryClient.listMediaItems();
  for (MediaItem item : response.iterateAll()) {
    // Get some properties of a media item
    String id = item.getId();
    String description = item.getDescription();
    String mimeType = item.getMimeType();
    String productUrl = item.getProductUrl();
    String filename = item.getFilename();
  }
} catch (ApiException e) {
  // Handle error
}

PHP

try {
    // Make a request to list all media items in the user's library
    // Iterate over all the retrieved media items
    // Pagination is handled automatically
    $response = $photosLibraryClient->listMediaItems();
    foreach ($response->iterateAllElements() as $item) {
        // Get some properties of a media item
        /* @var $item \Google\Photos\Library\V1\MediaItem */
        $id = $item->getId();
        $description = $item->getDescription();
        $mimeType = $item->getMimeType();
        $productUrl = $item->getProductUrl();
        $filename = $item->getFilename();
    }
} catch (\Google\ApiCore\ApiException $e) {
    // Handle error
}

Die Antwort enthält eine Liste von Medienelementen, sortiert vom neuesten zum aktuellsten. Weitere Informationen finden Sie unter mediaItems. Außerdem enthält ein nextPageToken, das ausführlicher beschrieben wird unter Paginierung:

Albuminhalte auflisten

Wenn Sie alle Medienelemente in einem Album auflisten möchten, fügen Sie das Feld albumId zu Ihrem Suchanfrage. Weitere Informationen zu albumId finden Sie unter Liste Alben und Geteilte Alben auflisten. Wenn wenn albumId ungültig ist, wird der Fehler Bad Request zurückgegeben. Wenn die ID gültig ist, aber das Album für den authentifizierten Nutzer nicht vorhanden ist, wird der Fehler Not Found angezeigt. zurückgegeben. Weitere Informationen zur Fehlerbehandlung finden Sie unter Leistung Tipps und Beste .

REST

Ein Beispiel für eine Anfrage:

POST https://photoslibrary.googleapis.com/v1/mediaItems:search
Content-type: application/json
Authorization: Bearer oauth2-token
{
  "pageSize": "100",
  "albumId": "album-id"
}

Die POST-Anfrage gibt die folgende Antwort zurück:

{
  "mediaItems": [
    ...
  ],
  "nextPageToken": "token-for-pagination"
}

Java

try {
  // Make a request to list all media items in an album
  // Provide the ID of the album as a parameter in the searchMediaItems call
  // Iterate over all the retrieved media items
  SearchMediaItemsPagedResponse response = photosLibraryClient.searchMediaItems(albumId);

  for (MediaItem item : response.iterateAll()) {
    // ...
  }

} catch (ApiException e) {
  // Handle error
}

PHP

try {
    // Make a request to list all media items in an album
    // Provide the ID of the album as a parameter in the searchMediaItems call
    // Iterate over all the retrieved media items
    $response = $photosLibraryClient->searchMediaItems(['albumId' => $albumId]);
    foreach ($response->iterateAllElements() as $item) {
        // ...
    }
} catch (\Google\ApiCore\ApiException $e) {
    // Handle error
}

Die Antwort enthält ein nextPageToken und die Liste der Medienelemente. Gefällt mir nicht, wenn Bibliotheksinhalte aufgelistet, werden die Medienelemente in ihrer Reihenfolge im Album. Weitere Informationen finden Sie unter mediaItems und Paginierung. Der Nutzer kann die Bestellung im Google Fotos-Benutzeroberfläche

Wenn albumId festgelegt ist, können Sie beim Auflisten von Albuminhalten keinen Filter anwenden. Dies führt zum Fehler Bad Request.

Geteilte Alben auflisten

Sie können eine Liste aller Alben abrufen, die der Nutzer freigegeben hat oder die die für einen Nutzer freigegeben wurden. Dies ähnelt dem Tab "Teilen" im Google Fotos App.

Geteilte Alben, die der Nutzer seiner Google Fotos-Galerie hinzugefügt hat werden auch im Aufruf listing album zurückgegeben. Machen Sie die folgenden Aufruf zum Auflisten freigegebener Alben über die Library API:

REST

Ein Beispiel für eine Anfrage:

GET https://photoslibrary.googleapis.com/v1/sharedAlbums

Die Anfrage gibt das folgende Ergebnis zurück:

{
  "sharedAlbums": [...]
  "nextPageToken": "token-for-pagination"
}

Java

try {
  // Make a request to list all albums that have been shared by the user
  // Iterate over all the albums in this list
  // Pagination is handled automatically
  ListSharedAlbumsPagedResponse response = photosLibraryClient.listSharedAlbums();

  for (Album album : response.iterateAll()) {
    // ..
  }

} catch (ApiException e) {
  // Handle error
}

PHP

try {
    // Make a request to list all albums that have been shared by the user
    // Iterate over all the albums in this list
    // Pagination is handled automatically
    $response = $photosLibraryClient->listSharedAlbums();
    foreach ($response->iterateAllElements() as $album) {
        // ...
    }
} catch (\Google\ApiCore\ApiException $e) {
    // Handle error
}

In sharedAlbums ist eine Liste mit Alben enthalten. Weitere Informationen finden Sie unter Alben auflisten Die Antwort enthält auch ein nextPageToken. Weitere Informationen finden Sie unter Paginierung.

Alben, die von deiner App erstellt und geteilt wurden, enthalten zusätzliche shareInfo Property. Weitere Informationen finden Sie unter Freigeben Medien.

Erstellte Alben der App auflisten

Sie können Alben auflisten, die von Ihrer App erstellt wurden. excludeNonAppCreatedData wurde in den folgenden Aufrufen auf true gesetzt:

REST

Hier ist eine GET-Anfrage zum Auflisten aller Alben aus dem Nur von Ihrer App erstellte Google Fotos-Galerie:

GET https://photoslibrary.googleapis.com/v1/albums?excludeNonAppCreatedData=true
Content-type: application/json
Authorization: Bearer oauth2-token

Hier ist eine GET-Anfrage zum Auflisten aller geteilten Alben aus dem Nur von Ihrer App erstellte Google Fotos-Galerie:

GET https://photoslibrary.googleapis.com/v1/sharedAlbums?excludeNonAppCreatedData=true
Content-type: application/json
Authorization: Bearer oauth2-token

Java

try {
  // Make a request to list all albums that have been created by your app
  boolean excludeNonAppCreatedData = true;

  // Iterate over all the albums in this list
  // Pagination is handled automatically
  ListAlbumsPagedResponse response = photosLibraryClient.listAlbums(excludeNonAppCreatedData);

  for (Album album : response.iterateAll()) {
    // ..
  }

} catch (ApiException e) {
  // Handle error
}

try {
  // Make a request to list all shared albums that have been created by your app
  boolean excludeNonAppCreatedData = true;

  // Iterate over all the albums in this list
  // Pagination is handled automatically
  ListSharedAlbumsPagedResponse response =
      photosLibraryClient.listSharedAlbums(excludeNonAppCreatedData);

  for (Album album : response.iterateAll()) {
    // ..
  }

} catch (ApiException e) {
  // Handle error
}

PHP

try {
    // Make a request to list all albums that have been created by your app
    $response = $photosLibraryClient->listAlbums(['excludeNonAppCreatedData' => true]);

    // Iterate over all the albums in this list
    // Pagination is handled automatically
    foreach ($response->iterateAllElements() as $album) {
        // ...
    }
} catch (\Google\ApiCore\ApiException $e) {
    // Handle error
}

try {
    // Make a request to list all shared albums that have been created by your app
    $response = $photosLibraryClient->listSharedAlbums(['excludeNonAppCreatedData' => true]);

    // Iterate over all the albums in this list
    // Pagination is handled automatically
    foreach ($response->iterateAllElements() as $album) {
        // ...
    }
} catch (\Google\ApiCore\ApiException $e) {
    // Handle error
}

Paginierung für REST

Zur Verbesserung der Leistung sollten Methoden, die eine große Anzahl von Ergebnissen zurückgeben (z. B. list-Methoden) können die Antwort paginieren. Die maximale Anzahl der Ergebnisse pro Seite wird durch den Parameter pageSize angegeben.

Für Aufrufe von mediaItems:search und mediaItems:list ist die Standardseitengröße 25 Elemente. Wir empfehlen diese Seitengröße, da sie ein Gleichgewicht zwischen der die Größe der Antwort und die Ausführungsrate. Die maximale Seitengröße für Medienelemente Such- und Listenanfragen 100 Elemente enthalten.

Die standardmäßige und empfohlene Seitengröße beim Auflisten von Alben beträgt 20 Alben, wobei Maximal 50 Alben.

Ist die Anzahl der verfügbaren Ergebnisse größer als die Seitengröße, wird die Antwort enthält ein nextPageToken, das Ihrer Anwendung anzeigt, dass zum Abrufen weiterer Ergebnisse vom Server.

Beispiel

Sie müssen den nextPageToken an nachfolgende Anfragen im Parameter anhängen. pageToken, wie im folgenden Beispiel gezeigt. pageToken zusammen angeben mit anderen für den Vorgang erforderlichen Parametern, entweder im Text des -Anforderung oder als Abfrageparameter verwendet werden.

Anfrage Nr. 1

{
  "pageSize": "5",
  "filters": { … }
}

Antwort 1

{
  "mediaItem": [  ],
  "nextPageToken": "next-page-token"
}

Anfrage Nr. 2

{
  "pageSize": "5",
  "filters": { … },
  "pageToken": "page-token"
}

Antwort 2

{
  "mediaItem": [  ],
  "nextPageToken": "next-page-token"
}

Fahren Sie mit diesem Muster fort, bis keine nextPageToken-Objekte mehr vorhanden sind.

Die nextPageToken ist nur für dieselbe Anfrage gültig. Wenn Parameter geändert wurde, sollte eine zuvor verwendete nextPageToken nicht im selben