Mengamankan Gambar Pribadi

Latar belakang

Fitur gambar pribadi yang aman memungkinkan Anda menentukan gambar pada kartu yang tidak perlu dapat diakses dari URL yang menghadap publik (persyaratan agar gambar biasa dapat dirender dengan benar pada kartu). Anda menggunakan Wallet API untuk mengupload gambar dan menerima ID yang dapat digunakan untuk merujuk gambar tersebut pada objek kartu Wallet.

Jenis kartu berikut didukung:

  • Tiket Acara
  • Boarding pass
  • Tiket transportasi umum
  • Kartu Penawaran
  • Kartu Voucher
  • Kartu loyalitas
  • Kartu generik

Contoh fitur

Contoh Gambar Pribadi yang Aman
Kartu keanggotaan menggunakan gambar pribadi yang aman

Kasus Penggunaan

Gambar pribadi yang aman memungkinkan penggunaan gambar yang tidak perlu dapat diakses secara publik dan oleh karena itu dapat digunakan untuk hal-hal seperti foto profil. Hal ini memungkinkan kasus penggunaan seperti, tetapi tidak terbatas pada, berikut ini:

  • Kartu keanggotaan tahunan
  • Kartu Nama
  • Tiket Transportasi Umum

Catatan: Gambar pribadi yang aman tidak dimaksudkan untuk digunakan sebagai tanda pengenal yang dikeluarkan pemerintah bersama dengan pedoman tambahan yang ditentukan dalam kebijakan penggunaan yang dapat diterima

Beberapa pertimbangan saat menggunakan Fitur Wallet

  • Tidak dapat digunakan dengan Kartu Pribadi Umum
  • Hanya dapat ditambahkan ke Objek kartu (bukan Kelas)
  • Hanya dapat digunakan dengan satu Objek
  • Hanya dapat digunakan dengan ImageModuleData (bukan gambar lain, misalnya logo dan logo header lebar)

Fitur Dalam Pengembangan

  • Dukungan Web
  • Gambar pribadi di gambar utama

Langkah-Langkah Integrasi

  1. Upload gambar pribadi Anda menggunakan Google Wallet API untuk menerima privateImageId.
  2. Tambahkan gambar ke objek kartu (misalnya, ImageModuleData). Daripada menyetel kolom sourceUri pada gambar, Anda akan menyetel kolom privateImageId dengan nilai yang diperoleh dari langkah sebelumnya.

Diagram Urutan

Diagram Urutan Gambar yang Aman
Mengamankan urutan gambar pribadi

Kode Contoh

Upload gambar

String issuerId = "12345";
String keyFilePath = "/path/to/key.json";
GoogleCredential credential =
    GoogleCredential.fromStream(new FileInputStream(keyFilePath))
        .createScoped(Arrays.asList("https://www.googleapis.com/auth/wallet_object.issuer"));
HttpTransport httpTransport = GoogleNetHttpTransport.newTrustedTransport();

// Prepare request to upload image
String contentType = "image/jpeg";  // MIME type of image
String imageFilePath = "/path/to/image.jpg";
HttpContent content =
    new ByteArrayContent(
        contentType, ByteStreams.toByteArray(new FileInputStream(imageFilePath)));

String url =
    String.format(
        "https://walletobjects.googleapis.com/upload/walletobjects/v1/privateContent/%s/uploadPrivateImage",
        issuerId);

// Make request to upload image
HttpResponse response =
    httpTransport
        .createRequestFactory(credential)
        .buildPostRequest(new GenericUrl(url), content)
        .execute();

// Get privateImageId from response
Gson gson = new Gson();
JsonObject jsonObject = gson.fromJson(response.parseAsString(), JsonObject.class);
String privateImageId = jsonObject.get("privateImageId").getAsString();

Menggunakan Gambar Pribadi pada objek kartu

// Build GenericObject with privateImageId in ImageModuleData (also adding an optional TextModuleData)
Image image = new Image().setPrivateImageId(privateImageId);
ImageModuleData imageModuleData = new ImageModuleData().setId("imageId").setMainImage(image);
TextModuleData textModuleData =
    new TextModuleData().setId("textId").setHeader("Card holder").setBody("John Doe");
GenericObject genericObject =
    new GenericObject()
        .setId(issuerId + ".objectId")
        // class must be inserted before inserting object
        .setClassId(issuerId + ".classId")
        .setCardTitle("Business name")
        .setHeader("My membership card")
        .setImageModulesData(Arrays.asList(imageModuleData))
        .setTextModulesData(Arrays.asList(textModuleData));

// Insert GenericObject (or can use in JWT without inserting ahead of time)
Walletobjects service =
    new Walletobjects.Builder(httpTransport, GsonFactory.getDefaultInstance(), credential)
        .setApplicationName("My Application")
        .build();

service.genericobject().insert(genericObject).execute();

Perbarui Kartu untuk menampilkan gambar di bagian depan

Anda dapat menggunakan image pribadi yang aman di kolom data imageModulesData. Berikut adalah contoh cara menggunakan kolom imageModulesData untuk memosisikan gambar di bagian depan kartu menggunakan penggantian template. Berikut contoh penyisipan class dengan penggantian template:

CardTemplateOverride cardTemplateOverride =
    new CardTemplateOverride()
        .setCardRowTemplateInfos(
            Arrays.asList(
                new CardRowTemplateInfo()
                    .setTwoItems(
                        new CardRowTwoItems()
                            // The ids chosen here must be set on the object's TextModuleData and ImageModuleData
                            .setStartItem(
                                createTemplateItem("object.textModulesData['textId']"))
                            .setEndItem(
                                createTemplateItem("object.imageModulesData['imageId']")))));
GenericClass genericClass =
    new GenericClass()
        .setId(issuerId + ".classId")
        .setClassTemplateInfo(
            new ClassTemplateInfo().setCardTemplateOverride(cardTemplateOverride));

service.genericclass().insert(genericClass);


...


private static TemplateItem createTemplateItem(String fieldPath) {
  return new TemplateItem()
      .setFirstValue(
          new FieldSelector()
              .setFields(Arrays.asList(new FieldReference().setFieldPath(fieldPath))));
}

Penanganan pengecualian

Potensi error dapat terjadi karena penggunaan Wallet FeatureAPI yang salah, yang dapat mencakup;

Kirim pesan Alasan
Gambar tidak dapat memiliki source_uri dan private_image_id Penerbit mencoba menyetel source_uri dan private_image_id pada satu gambar, yang tidak diizinkan
Tidak dapat menemukan gambar pribadi dengan ID %s untuk penerbit %s Menetapkan ID gambar pribadi yang tidak ada pada objek
Tidak dapat menambahkan gambar pribadi dengan ID %s untuk penerbit %s ke objek %s karena sudah digunakan dengan objek %s. Gambar pribadi hanya dapat digunakan dengan satu objek. Mencoba menggunakan gambar pribadi yang sama pada lebih dari satu objek. Untuk menggunakan gambar pribadi yang sama dengan lebih dari satu objek, gambar tersebut harus diupload ulang dan Anda akan mendapatkan ID gambar pribadi baru, yang dapat digunakan dengan objek kedua