Topik ini menunjukkan cara mengimpor kunci kriptografis ke Cloud HSM atau Cloud Key Management Service sebagai versi kunci baru.
Untuk mengetahui detail selengkapnya tentang cara mengimpor kunci, termasuk batasan dan pembatasan, lihat impor kunci.
Anda dapat menyelesaikan langkah-langkah dalam topik ini dalam waktu 5 hingga 10 menit, tidak termasuk langkah-langkah Sebelum memulai. Menggabungkan kunci secara manual akan menambahkan kompleksitas pada tugas.
Sebelum memulai
Sebaiknya buat project baru untuk menguji fitur ini, guna memudahkan pembersihan setelah pengujian dan memastikan bahwa Anda memiliki izin Identity and Access Management (IAM) yang memadai untuk mengimpor kunci.
Sebelum dapat mengimpor kunci, Anda harus menyiapkan project, sistem lokal, dan kunci itu sendiri.
Menyiapkan project
- Sign in to your Google Cloud account. If you're new to Google Cloud, create an account to evaluate how our products perform in real-world scenarios. New customers also get $300 in free credits to run, test, and deploy workloads.
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the required API.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
In the Google Cloud console, on the project selector page, select or create a Google Cloud project.
-
Make sure that billing is enabled for your Google Cloud project.
-
Enable the required API.
- Install the Google Cloud CLI.
-
To initialize the gcloud CLI, run the following command:
gcloud init
-
Pengguna yang melakukan impor memerlukan izin IAM berikut untuk membuat key ring, kunci, dan tugas impor. Jika pengguna bukan pemilik project, Anda dapat menetapkan kedua dari dua peran standar berikut kepada pengguna:
roles/editor
roles/cloudkms.importer
Untuk informasi selengkapnya tentang peran dan izin IAM yang tersedia untuk Cloud KMS, lihat Izin dan peran.
Menyiapkan sistem lokal
Siapkan sistem lokal dengan memilih salah satu opsi berikut. Wrapper kunci otomatis direkomendasikan untuk sebagian besar pengguna.
- Jika ingin mengizinkan Google Cloud CLI menggabungkan kunci secara otomatis sebelum mengirimkannya ke Google Cloud, Anda harus menginstal library kriptografi Pyca di sistem lokal. Library Pyca digunakan oleh tugas impor yang menggabungkan dan melindungi kunci secara lokal sebelum mengirimkannya ke Google Cloud.
- Jika ingin menggabungkan kunci secara manual, Anda harus mengonfigurasi OpenSSL untuk penggabungan kunci manual.
Menyiapkan kunci
Verifikasi bahwa algoritma dan panjang kunci Anda didukung. Algoritma yang diizinkan untuk kunci bergantung pada apakah kunci tersebut digunakan untuk enkripsi simetris, enkripsi asimetris, atau penandatanganan asimetris, serta apakah kunci disimpan dalam software atau HSM. Anda menentukan algoritma kunci sebagai bagian dari permintaan impor.
Secara terpisah, Anda juga harus memverifikasi cara kunci dienkode, dan melakukan penyesuaian jika diperlukan.
Hal berikut tidak dapat diubah untuk versi kunci setelah dibuat atau diimpor:
Tingkat perlindungan menunjukkan apakah kunci tetap ada di software, di HSM, atau di sistem pengelolaan kunci eksternal. Materi kunci tidak dapat dipindahkan dari salah satu lingkungan penyimpanan ini ke lingkungan penyimpanan lainnya. Semua versi kunci memiliki tingkat perlindungan yang sama.
Tujuan menunjukkan apakah versi kunci digunakan untuk enkripsi simetris, enkripsi asimetris, atau penandatanganan asimetris. Tujuan kunci membatasi kemungkinan algoritma yang dapat digunakan untuk membuat versi kunci tersebut. Semua versi kunci memiliki tujuan yang sama.
Jika tidak memiliki kunci untuk diimpor, tetapi ingin memvalidasi prosedur untuk mengimpor kunci, Anda dapat membuat kunci simetris di sistem lokal, menggunakan perintah berikut:
openssl rand 32 > ${HOME}/test.bin
Gunakan kunci ini hanya untuk pengujian. Kunci yang dibuat dengan cara ini mungkin tidak sesuai untuk penggunaan produksi.
Jika Anda perlu menggabungkan kunci secara manual, lakukan hal itu sebelum melanjutkan prosedur dalam topik ini.
Membuat kunci target dan key ring
Kunci Cloud KMS adalah objek penampung yang berisi satu atau beberapa versi kunci. Setiap versi kunci berisi kunci kriptografis.
Saat Anda mengimpor kunci ke Cloud KMS atau Cloud HSM, kunci yang diimpor akan menjadi versi kunci baru pada kunci Cloud KMS atau Cloud HSM yang ada. Di bagian lain topik ini, kunci ini disebut kunci target. Kunci target harus ada sebelum Anda dapat mengimpor materi kunci ke dalam kunci tersebut.
Mengimpor versi kunci tidak akan memengaruhi versi kunci yang ada. Namun, Sebaiknya buat kunci kosong saat menguji impor kunci. Kunci kosong tidak memiliki versi, tidak aktif, dan tidak dapat digunakan.
Secara opsional, Anda dapat menentukan bahwa kunci yang baru dibuat hanya boleh berisi versi yang diimpor, yang mencegah pembuatan versi baru secara tidak sengaja di Cloud KMS.
Kunci ada di key ring; dalam topik ini, key ring ini disebut target key ring. Lokasi key ring target menentukan lokasi tempat materi kunci tersedia setelah impor. Kunci Cloud HSM tidak dapat dibuat atau diimpor di beberapa lokasi. Setelah dibuat, kunci tidak dapat dipindahkan ke lokasi atau lingkaran kunci lain.
Ikuti langkah-langkah berikut untuk membuat kunci kosong di ring kunci baru menggunakan Google Cloud CLI atau konsol Google Cloud.
Konsol
Di konsol Google Cloud, buka halaman Key Management.
Klik Create key ring.
Di kolom Key ring name, masukkan nama untuk key ring.
Di bagian Jenis lokasi, pilih jenis lokasi dan lokasi.
Klik Create. Halaman Buat kunci akan terbuka.
Di kolom Key name, masukkan nama untuk kunci Anda.
Untuk Tingkat perlindungan, pilih Software atau HSM, lalu klik Lanjutkan.
Untuk Materi kunci, pilih Kunci yang diimpor, lalu klik Lanjutkan. Tindakan ini mencegah pembuatan versi kunci awal.
Tetapkan Tujuan dan Algoritma untuk kunci, lalu klik Lanjutkan.
Opsional: Jika Anda ingin kunci ini hanya berisi versi kunci yang diimpor, pilih Restrict key versions to import only. Hal ini mencegah Anda membuat versi kunci baru secara tidak sengaja di Cloud KMS.
Opsional: Untuk kunci yang diimpor, rotasi otomatis dinonaktifkan secara default. Untuk mengaktifkan rotasi otomatis, pilih nilai dari kolom Periode rotasi kunci.
Jika Anda mengaktifkan rotasi otomatis, versi kunci baru akan dibuat di Cloud KMS, dan versi kunci yang diimpor tidak akan lagi menjadi versi kunci default setelah rotasi.
Klik Create.
gcloud
Untuk menggunakan Cloud KMS di command line, pertama-tama Instal atau upgrade ke Google Cloud CLI versi terbaru.
Buat key ring target. Jika Anda ingin mengimpor ke kunci Cloud HSM, pilih lokasi dengan dukungan untuk Cloud HSM.
gcloud kms keyrings create KEY_RING \ --location LOCATION
Anda dapat mempelajari lebih lanjut cara membuat key ring.
Buat kunci target.
- Tentukan tujuan kunci.
- Cegah versi awal dibuat menggunakan flag
--skip-initial-version-creation
. - Opsional: Cegah versi baru dibuat di
Cloud KMS menggunakan flag
--import-only
. - Opsional: Jangan tentukan kebijakan rotasi. Jika Anda mengaktifkan
rotasi otomatis, versi kunci baru akan dibuat di
Cloud KMS, dan versi kunci yang diimpor tidak akan lagi
menjadi versi kunci default setelah rotasi. Anda tidak boleh menentukan
kebijakan rotasi jika menentukan flag
--import-only
.
gcloud kms keys create KEY_NAME \ --location LOCATION \ --keyring KEY_RING \ --purpose PURPOSE \ --skip-initial-version-creation \ --import-only
Anda dapat mempelajari lebih lanjut cara membuat kunci Cloud KMS atau kunci Cloud HSM.
Go
Untuk menjalankan kode ini, siapkan lingkungan pengembangan Go terlebih dahulu, lalu instal Cloud KMS Go SDK.
Java
Untuk menjalankan kode ini, siapkan lingkungan pengembangan Java terlebih dahulu dan instal Cloud KMS Java SDK.
Node.js
Untuk menjalankan kode ini, siapkan lingkungan pengembangan Node.js terlebih dahulu dan instal Cloud KMS Node.js SDK.
Python
Untuk menjalankan kode ini, pertama-tama siapkan lingkungan pengembangan Python dan instal Cloud KMS Python SDK.
API
Contoh ini menggunakan curl sebagai klien HTTP untuk menunjukkan penggunaan API. Untuk informasi selengkapnya tentang kontrol akses, lihat Mengakses Cloud KMS API.
Buat key ring baru:
curl "https://cloudkms.googleapis.com/v1/projects/PROJECT_ID/locations/LOCATION/keyRings?keyRingId=KEY_RING" \ --request "POST" \ --header "authorization: Bearer TOKEN" \ --header "content-type: application/json" \ --header "x-goog-user-project: PROJECT_ID" \ --data "{}"
Lihat dokumentasi
KeyRing.create
API untuk mengetahui informasi selengkapnya.Buat kunci kosong khusus impor:
curl "https://cloudkms.googleapis.com/v1/projects/PROJECT_ID/locations/LOCATION/keyRings/KEY_RING/cryptoKeys?cryptoKeyId=KEY_NAME&skipInitialVersionCreation=true&importOnly=true" \ --request "POST" \ --header "authorization: Bearer TOKEN" \ --header "content-type: application/json" \ --header "x-goog-user-project: PROJECT_ID" \ --data "{"purpose":"PURPOSE", "versionTemplate":{"protectionLevel":"PROTECTION_LEVEL","algorithm":"ALGORITHM"}}"
Lihat dokumentasi
CryptoKey.create
API untuk mengetahui informasi selengkapnya.
Key ring dan kunci kini ada, tetapi kunci tidak berisi materi kunci, tidak memiliki versi, dan tidak aktif. Selanjutnya, Anda membuat tugas impor.
Membuat tugas impor
Tugas impor menentukan karakteristik kunci yang diimpor, termasuk properti yang tidak dapat diubah setelah kunci diimpor.
Tingkat perlindungan menentukan apakah kunci yang diimpor oleh tugas impor ini akan berada di software, di HSM, atau di sistem pengelolaan kunci eksternal. Tingkat perlindungan tidak dapat diubah setelah kunci akhirnya diimpor.
Metode impor menentukan algoritma yang digunakan untuk membuat kunci wrapper yang melindungi kunci yang diimpor selama transit dari sistem lokal Anda ke project Google Cloud target. Anda dapat memilih kunci RSA 3072 bit atau 4096 bit. Kecuali jika Anda memiliki persyaratan tertentu, sebaiknya gunakan kunci penggabungan 3072-bit.
Anda dapat membuat tugas impor menggunakan gcloud CLI, konsol Google Cloud, atau Cloud Key Management Service API.
Konsol
Buka halaman Key Management di konsol Google Cloud.
Klik nama key ring target.
Tetapkan Tingkat perlindungan ke Software atau HSM. Gunakan tingkat perlindungan yang sama seperti yang Anda tetapkan untuk kunci target.
Klik Buat tugas impor.
Di kolom Nama, masukkan nama untuk tugas impor Anda.
Dari dropdown Import method, tetapkan metode impor ke RSA 3072 bit atau RSA 4096 bit.
Klik Create.
gcloud
Untuk menggunakan Cloud KMS di command line, pertama-tama Instal atau upgrade ke Google Cloud CLI versi terbaru.
Gunakan perintah seperti berikut untuk membuat tugas impor.
gcloud kms import-jobs create IMPORT_JOB \ --location LOCATION \ --keyring KEY_RING \ --import-method IMPORT_METHOD \ --protection-level PROTECTION_LEVEL
- Gunakan key ring dan lokasi yang sama dengan kunci target.
- Tetapkan tingkat perlindungan ke
software
atauhsm
. - Tetapkan metode impor ke
rsa-oaep-3072-sha1-aes-256
rsa-oaep-4096-sha1-aes-256
,rsa-oaep-3072-sha256-aes-256
,rsa-oaep-4096-sha256-aes-256
,rsa-oaep-3072-sha256
, ataursa-oaep-4096-sha256
.
Go
Untuk menjalankan kode ini, siapkan lingkungan pengembangan Go terlebih dahulu, lalu instal Cloud KMS Go SDK.
Java
Untuk menjalankan kode ini, siapkan lingkungan pengembangan Java terlebih dahulu dan instal Cloud KMS Java SDK.
Node.js
Untuk menjalankan kode ini, siapkan lingkungan pengembangan Node.js terlebih dahulu dan instal Cloud KMS Node.js SDK.
Python
Untuk menjalankan kode ini, pertama-tama siapkan lingkungan pengembangan Python dan instal Cloud KMS Python SDK.
API
Contoh ini menggunakan curl sebagai klien HTTP untuk menunjukkan penggunaan API. Untuk informasi selengkapnya tentang kontrol akses, lihat Mengakses Cloud KMS API.
Untuk membuat tugas impor, gunakan metode
ImportJobs.create
:
curl "https://cloudkms.googleapis.com/v1/projects/PROJECT_ID/locations/LOCATION/keyRings/KEY_RING/importJobs?import_job_id=IMPORT_JOB_ID" \ --request "POST" \ --header "authorization: Bearer TOKEN" \ --header "content-type: application/json" \ --data '{"import_method": "IMPORT_METHOD", "protection_level": "PROTECTION_LEVEL"}'
Ganti kode berikut:
- IMPORT_METHOD: Metode penggabungan kunci yang didukung.
- PROTECTION_LEVEL: tingkat perlindungan versi kunci yang diimpor oleh tugas impor ini.
Memeriksa status tugas impor
Status awal untuk tugas impor adalah PENDING_GENERATION
. Jika statusnya
ACTIVE
, Anda dapat menggunakannya untuk mengimpor kunci.
Tugas impor akan berakhir setelah tiga hari. Jika tugas impor sudah tidak berlaku, Anda harus membuat tugas baru.
Anda dapat memeriksa status tugas impor menggunakan Google Cloud CLI, konsol Google Cloud, atau Cloud Key Management Service API.
Konsol
Buka halaman Key Management di konsol Google Cloud.
Klik nama key ring yang berisi tugas impor Anda.
Klik tab Impor Tugas di bagian atas halaman.
Status akan terlihat di bagian Status di samping nama tugas impor Anda.
gcloud
Untuk menggunakan Cloud KMS di command line, pertama-tama Instal atau upgrade ke Google Cloud CLI versi terbaru.
Saat tugas impor aktif, Anda dapat menggunakannya untuk mengimpor kunci. Proses ini mungkin memerlukan waktu beberapa menit. Gunakan perintah ini untuk memverifikasi bahwa tugas impor aktif. Gunakan lokasi dan ring kunci tempat Anda membuat tugas impor.
gcloud kms import-jobs describe IMPORT_JOB \ --location LOCATION \ --keyring KEY_RING \ --format="value(state)"
Outputnya mirip dengan hal berikut ini:
state: ACTIVE
Go
Untuk menjalankan kode ini, siapkan lingkungan pengembangan Go terlebih dahulu, lalu instal Cloud KMS Go SDK.
Java
Untuk menjalankan kode ini, siapkan lingkungan pengembangan Java terlebih dahulu dan instal Cloud KMS Java SDK.
Node.js
Untuk menjalankan kode ini, siapkan lingkungan pengembangan Node.js terlebih dahulu dan instal Cloud KMS Node.js SDK.
Python
Untuk menjalankan kode ini, pertama-tama siapkan lingkungan pengembangan Python dan instal Cloud KMS Python SDK.
API
Contoh ini menggunakan curl sebagai klien HTTP untuk menunjukkan penggunaan API. Untuk informasi selengkapnya tentang kontrol akses, lihat Mengakses Cloud KMS API.
Untuk memeriksa status tugas impor, gunakan metode
ImportJobs.get
:
curl "https://cloudkms.googleapis.com/v1/projects/PROJECT_ID/locations/LOCATION/keyRings/KEY_RING/importJobs/IMPORT_JOB_ID" \ --request "GET" \ --header "authorization: Bearer TOKEN"
Segera setelah tugas impor aktif, Anda dapat membuat permintaan untuk mengimpor kunci.
Mencegah modifikasi tugas impor
Tugas impor menentukan banyak karakteristik kunci yang diimpor, termasuk algoritma kunci dan apakah kunci yang diimpor adalah kunci HSM atau kunci software. Anda dapat mengonfigurasi izin IAM untuk mencegah pengguna membuat tugas impor, sekaligus mengizinkan mereka menggunakan tugas impor untuk mengimpor kunci.
- Berikan izin
importjobs.create
hanya kepada administrator utama. - Berikan izin
importjobs.useToImport
untuk tugas impor tertentu kepada operator yang akan menggunakan tugas tersebut untuk mengimpor kunci. - Saat membuat tugas impor, tentukan tingkat perlindungan dan algoritma untuk versi kunci yang diimpor menggunakan algoritma tersebut.
Hingga tugas impor berakhir, pengguna yang memiliki importjobs.useToImport
dan
tidak memiliki izin importjobs.create
untuk tugas impor tertentu dapat mengimpor
kunci, tetapi tidak dapat mengubah karakteristik tugas impor.
Mengimpor kunci
Setelah memeriksa status tugas impor, Anda dapat membuat permintaan impor.
Anda menggunakan flag yang berbeda untuk membuat permintaan impor, bergantung pada apakah Anda ingin Google Cloud CLI menggabungkan kunci secara otomatis atau jika Anda telah menggabungkan kunci secara manual.
Terlepas dari apakah Anda menggabungkan kunci secara manual atau otomatis, Anda harus menetapkan algoritma ke algoritma yang didukung yang cocok dengan panjang kunci sebenarnya yang akan diimpor, dan menentukan tujuan kunci.
Kunci dengan tujuan
ENCRYPT_DECRYPT
menggunakan algoritmagoogle-symmetric-encryption
, dan memiliki panjang 32.Kunci dengan tujuan
ASYMMETRIC_DECRYPT
atauASYMMETRIC_SIGN
mendukung berbagai algoritma dan panjang.Tujuan kunci tidak dapat diubah setelah kunci dibuat, tetapi versi kunci berikutnya dapat dibuat dengan panjang yang berbeda dari versi kunci awal.
Menggabungkan dan mengimpor kunci secara otomatis
Jika ingin menggunakan penggabungan otomatis, Anda harus menggunakan Google Cloud CLI.
Gunakan perintah seperti berikut. Tetapkan --target-key-file
ke lokasi
kunci yang di-unwrapping untuk digabungkan dan diimpor. Jangan tetapkan --wrapped-key-file
.
Secara opsional, Anda dapat menetapkan
tanda --public-key-file
ke lokasi tempat kunci publik telah
didownload. Saat mengimpor kunci dalam jumlah besar, tindakan ini akan mencegah kunci publik
didownload selama setiap impor. Misalnya, Anda dapat menulis skrip
yang mendownload kunci publik sekali, lalu memberikan lokasinya saat mengimpor
setiap kunci.
gcloud kms keys versions import \ --import-job IMPORT_JOB \ --location LOCATION \ --keyring KEY_RING \ --key KEY_NAME \ --algorithm ALGORITHM \ --target-key-file PATH_TO_UNWRAPPED_KEY
Kunci digabungkan oleh kunci gabungan yang terkait dengan tugas impor, dikirim ke Google Cloud, dan diimpor sebagai versi kunci baru di kunci target.
Mengimpor kunci yang digabungkan secara manual
Gunakan petunjuk di bagian ini untuk mengimpor kunci yang
telah Anda gabungkan secara manual. Tetapkan
--wrapped-key-file
ke lokasi kunci yang Anda gabungkan secara manual.
Jangan tetapkan --target-key-file
.
Secara opsional, Anda dapat menetapkan
tanda --public-key-file
ke lokasi tempat kunci publik telah
didownload. Saat mengimpor kunci dalam jumlah besar, tindakan ini akan mencegah kunci publik
didownload selama setiap impor. Misalnya, Anda dapat menulis skrip
yang mendownload kunci publik sekali, lalu memberikan lokasinya saat mengimpor
setiap kunci.
Konsol
Buka halaman Key Management di Konsol Google Cloud.
Klik nama key ring yang berisi tugas impor Anda. Kunci target ditampilkan, bersama dengan kunci lain di gantungan kunci.
Klik nama kunci target, lalu klik Impor versi kunci.
Pilih tugas impor Anda dari dropdown Select import job.
Di pemilih Upload kunci gabungan, pilih kunci yang telah digabungkan.
Jika Anda mengimpor kunci asimetris, pilih algoritma dari dropdown Algorithm. Halaman Impor versi kunci akan terlihat seperti:
Klik Import.
gcloud
Untuk menggunakan Cloud KMS di command line, pertama-tama Instal atau upgrade ke Google Cloud CLI versi terbaru.
Gunakan perintah seperti berikut.
gcloud kms keys versions import \ --import-job IMPORT_JOB \ --location LOCATION \ --keyring KEY_RING \ --key KEY_NAME \ --algorithm ALGORITHM \ --wrapped-key-file PATH_TO_WRAPPED_KEY
Untuk informasi selengkapnya, lihat output
perintah gcloud kms keys versions import --help
.
Go
Untuk menjalankan kode ini, siapkan lingkungan pengembangan Go terlebih dahulu, lalu instal Cloud KMS Go SDK.
Java
Untuk menjalankan kode ini, siapkan lingkungan pengembangan Java terlebih dahulu dan instal Cloud KMS Java SDK.
Node.js
Untuk menjalankan kode ini, siapkan lingkungan pengembangan Node.js terlebih dahulu dan instal Cloud KMS Node.js SDK.
Python
Untuk menjalankan kode ini, pertama-tama siapkan lingkungan pengembangan Python dan instal Cloud KMS Python SDK.
API
Contoh ini menggunakan curl sebagai klien HTTP untuk menunjukkan penggunaan API. Untuk informasi selengkapnya tentang kontrol akses, lihat Mengakses Cloud KMS API.
Gunakan metode cryptoKeyVersions.import
untuk
mengimpor kunci.
curl "https://cloudkms.googleapis.com/v1/projects/PROJECT_ID/locations/LOCATION/keyRings/KEY_RING/cryptoKeys/KEY_NAME/cryptoKeyVersions:import" \ --request "POST" \ --header "authorization: Bearer TOKEN" \ --header "content-type: application/json" \ --data '{"importJob": "IMPORT_JOB_ID", "algorithm": "ALGORITHM", "wrappedKey": "WRAPPED_KEY"}'
Ganti kode berikut:
IMPORT_JOB_ID: nama resource lengkap dari tugas impor yang sesuai.
ALGORITHM:
algorithm
dari kunci yang diimpor, yang berjenisCryptoKeyVersionAlgorithm
.WRAPPED_KEY: kunci yang digabungkan secara manual dalam format base64.
Permintaan impor kunci dimulai. Anda dapat memantau statusnya.
Memeriksa status versi kunci yang diimpor
Status awal untuk versi kunci yang diimpor adalah PENDING_IMPORT
. Jika
statusnya ENABLED
, versi kunci telah berhasil diimpor. Jika
impor gagal, statusnya adalah IMPORT_FAILED
.
Anda dapat memeriksa status permintaan impor menggunakan Google Cloud CLI, Konsol Google Cloud, atau Cloud Key Management Service API.
Konsol
Buka halaman Key Management di Konsol Google Cloud.
Klik nama key ring yang berisi tugas impor Anda.
Klik tab Impor Tugas di bagian atas halaman.
Status akan terlihat di bagian Status di samping nama tugas impor Anda.
gcloud
Untuk menggunakan Cloud KMS di command line, pertama-tama Instal atau upgrade ke Google Cloud CLI versi terbaru.
Gunakan perintah versions list
untuk memeriksa status. Gunakan lokasi, key ring target, dan kunci target yang sama dengan yang Anda buat sebelumnya dalam
topik ini.
gcloud kms keys versions list \ --keyring KEY_RING \ --location LOCATION \ --key KEY_NAME
Go
Untuk menjalankan kode ini, siapkan lingkungan pengembangan Go terlebih dahulu, lalu instal Cloud KMS Go SDK.
Java
Untuk menjalankan kode ini, siapkan lingkungan pengembangan Java terlebih dahulu dan instal Cloud KMS Java SDK.
Node.js
Untuk menjalankan kode ini, siapkan lingkungan pengembangan Node.js terlebih dahulu dan instal Cloud KMS Node.js SDK.
Python
Untuk menjalankan kode ini, pertama-tama siapkan lingkungan pengembangan Python dan instal Cloud KMS Python SDK.
API
Contoh ini menggunakan curl sebagai klien HTTP untuk menunjukkan penggunaan API. Untuk informasi selengkapnya tentang kontrol akses, lihat Mengakses Cloud KMS API.
Panggil metode ImportJob.get
dan periksa
kolom state
. Jika
state
adalah PENDING_GENERATION
, tugas impor masih dibuat.
Periksa kembali status secara berkala hingga menjadi ACTIVE
.
Setelah versi kunci awal diimpor, status kunci akan berubah menjadi Aktif. Untuk kunci simetris, Anda harus menetapkan versi kunci yang diimpor sebagai versi utama sebelum dapat menggunakan kunci tersebut.
Kunci simetris: Menetapkan versi utama
Langkah ini diperlukan saat mengimpor kunci simetris, dan tidak relevan untuk kunci asimetris. Kunci asimetris tidak memiliki versi utama. Anda harus menggunakan Google Cloud CLI untuk menetapkan versi utama.
gcloud kms keys set-primary-version KEY_NAME\ --location=LOCATION\ --keyring=KEY_RING\ --version=KEY_VERSION
Mengimpor ulang kunci yang sebelumnya dihancurkan
Cloud Key Management Service mendukung impor ulang kunci, yang memungkinkan Anda memulihkan
versi kunci yang diimpor sebelumnya dalam status DESTROYED
atau IMPORT_FAILED
ke
status ENABLED
dengan memberikan materi kunci asli. Jika tidak ada materi kunci
asli yang pernah diimpor karena kegagalan impor awal, materi kunci apa pun
dapat disediakan.
Pembatasan
- Hanya
CryptoKeyVersions
yang sebelumnya diimpor yang dapat diimpor ulang. - Materi kunci yang diimpor ulang harus sama persis dengan materi kunci asli jika versi sebelumnya berhasil diimpor.
CryptoKeyVersions
yang dihancurkan sebelum rilis fitur ini tidak dapat diimpor ulang. Kolomreimport_eligible
dariCryptoKeyVersion
adalahtrue
jika versi memenuhi syarat untuk impor ulang danfalse
jika tidak.
Kunci software dan Cloud HSM dapat diimpor ulang, tetapi kunci eksternal tidak dapat diimpor ulang.
Mengimpor ulang kunci yang dihancurkan
Buat ImportJob
untuk impor ulang dengan mengikuti langkah-langkah di
Membuat tugas impor. Anda dapat menggunakan
ImportJob
yang ada atau ImportJob
baru selama tingkat perlindungan cocok dengan
tingkat perlindungan asli.
Konsol
Buka halaman Key Management di konsol Google Cloud.
Klik nama key ring yang berisi kunci yang versi kuncinya akan Anda impor ulang.
Klik kunci yang versi kuncinya ingin Anda impor ulang.
Klik tiga titik di samping versi kunci yang ingin Anda impor ulang.
Pilih Impor ulang versi kunci
Pilih tugas impor Anda dari dropdown Select import job.
Di pemilih Upload kunci gabungan, pilih kunci yang telah digabungkan. Kunci ini harus cocok dengan materi kunci asli.
Klik Impor Ulang.
gcloud
Untuk menggunakan Cloud KMS di command line, pertama-tama Instal atau upgrade ke Google Cloud CLI versi terbaru.
Impor ulang versi kunci menggunakan materi kunci asli.
gcloud kms keys versions import \ --location LOCATION \ --keyring KEY_RING \ --key KEY_NAME \ --version KEY_VERSION \ --algorithm ALGORITHM \ --import-job IMPORT_JOB \ --target-key-file PATH_TO_KEY \
API
Contoh ini menggunakan curl sebagai klien HTTP untuk menunjukkan penggunaan API. Untuk informasi selengkapnya tentang kontrol akses, lihat Mengakses Cloud KMS API.
Dalam isi permintaan metode
cryptoKeyVersions.import
, tetapkan kolomcryptoKeyVersion
ke nama versi kunci dari versi yang diimpor. Elemen ini harus merupakan turunan dari kunci kripto.Dalam isi permintaan, tetapkan kolom
algorithm
ke algoritma kunci yang diimpor. Nilai ini harus cocok dengan algoritma versi kunci asli. Kolomalgorithm
berjenisCryptoKeyVersionAlgorithm
.Dalam isi permintaan, tetapkan kolom
wrappedKeyMaterial
ke materi kunci yang telah Anda gabungkan.Panggil metode
cryptoKeyVersions.import
. ResponscryptoKeyVersions.import
adalah jenisCryptoKeyVersion
. Jika kunci berhasil diimpor, statusnya adalahENABLED
dan Anda dapat menggunakannya di Cloud KMS.
Langkah selanjutnya
- Memverifikasi kunci yang diimpor. Setelah mengonfirmasi bahwa materi kunci yang diimpor identik dengan kunci asli, Anda dapat menggunakan kunci untuk menandatangani atau melindungi data.
- Memecahkan masalah impor kunci yang gagal.