Penyulitan Web JSON (JWE) ialah standard yang ditakrifkan oleh RFC 7516 yang mewakili kandungan yang disulitkan menggunakan struktur data berasaskan JSON. Ia membolehkan anda menyulitkan muatan sewenang-wenangnya untuk memastikan kerahsiaan dan, jika perlu, integriti. Kandungan yang disulitkan ini boleh termasuk apa-apa jenis data, seperti maklumat pengguna sensitif, token keselamatan, atau bahkan fail.
JWE digunakan secara meluas dalam aplikasi web dan API untuk menghantar data sensitif seperti token, maklumat pengguna dan butiran kewangan dengan selamat. Ia memastikan bahawa maklumat itu tidak boleh dibaca oleh entiti yang tidak dibenarkan, walaupun dipintas. Muatan yang disulitkan hanya boleh dinyahsulit dan digunakan oleh penerima yang dimaksudkan yang memiliki kunci penyahsulitan yang betul.
Penyulitan Web JSON (JWE) ialah standard untuk menghantar maklumat dengan selamat antara pihak sebagai objek JSON. JWE menggunakan penyulitan untuk memastikan kerahsiaan dan integriti data yang dilindunginya. Struktur JWE biasa terdiri daripada lima bahagian yang digabungkan bersama dan dipisahkan oleh noktah (.). Lima bahagian tersebut ialah:
Setiap bahagian JWE memainkan peranan tertentu dalam proses penyulitan dan penyahsulitan. Mari kita mendalami setiap bahagian secara terperinci.
Tajuk JOSE (JSON Object Signing and Encryption) ialah bahagian pertama JWE dan mengandungi metadata tentang proses penyulitan. Ia ialah objek JSON berkod base64url yang merangkumi:
Contoh:
{ "alg": "RSA-OAEP", "enc": "A256GCM" }
Pengepala ini menentukan bahawa kunci penyulitan kandungan disulitkan menggunakan algoritma RSA-OAEP dan muatan disulitkan menggunakan AES GCM dengan kunci 256-bit.
Bahagian kedua JWE ialah Kunci Disulitkan, iaitu kunci yang digunakan untuk menyulitkan data sebenar (muatan). Kunci ini disulitkan menggunakan algoritma yang dinyatakan dalam parameter alg Pengepala JOSE.
Kunci Disulitkan adalah dikodkan base64url.
Vektor Permulaan (IV) ialah komponen ketiga dalam struktur JWE. Ia adalah nilai rawak berkod base64url yang digunakan bersama-sama dengan algoritma penyulitan untuk memastikan bahawa teks biasa yang sama akan menyulitkan secara berbeza setiap kali. IV menghalang corak dalam data yang disulitkan, meningkatkan keselamatan.
Untuk mod AES GCM, IV biasanya 96 bit (12 bait) panjang.
Ciphertext ialah hasil daripada menyulitkan plaintext (data muatan) dengan kunci penyulitan kandungan (CEK) dan algoritma penyulitan (parameter enc). Ciphertext adalah dikodkan base64url dan merupakan bahagian teras JWE, kerana ia memegang kandungan yang dilindungi.
Tag Pengesahan (juga dikenali sebagai Tag ) ialah nilai berkod base64url yang memberikan integriti dan ketulenan kepada Ciphertext, Initialization Vector (IV) dan Data Authenticated Tambahan (AAD). Ia dijana semasa proses penyulitan menggunakan algoritma seperti AES GCM.
Jika mana-mana bahagian struktur JWE diubah selepas penyulitan, proses penyahsulitan akan gagal kerana Tag Pengesahan tidak akan sepadan.
Pertimbangkan senario di mana kami ingin menyulitkan mesej "Hello, World!" menggunakan JWE. Berikut ialah pecahan ringkas:
JWE akhir mungkin kelihatan seperti ini:
{ "alg": "RSA-OAEP", "enc": "A256GCM" }
JWE berfungsi dengan menggunakan gabungan kriptografi kunci awam (untuk menyulitkan kunci simetri) dan penyulitan simetri (untuk menyulitkan muatan sebenar). Begini cara proses itu berfungsi:
Penjanaan dan Pengurusan Utama
Proses Penyulitan
Proses Penyahsulitan
Mencipta JWE melibatkan pemilihan perpustakaan yang menyokong piawaian JWE. Salah satu perpustakaan paling popular di Jawa ialah Nimbus JOSE JWT. Di bawah ialah contoh mudah yang menunjukkan cara membuat JWE:
Menyediakan Ketergantungan
Tambah kebergantungan berikut pada pom.xml anda jika anda menggunakan Maven:
{ "alg": "RSA-OAEP", "enc": "A256GCM" }
Mencipta dan Menyulitkan JWE
Berikut ialah coretan kod Java yang menunjukkan penciptaan JWE:
eyJhbGciOiJSU0EtT0FFUCIsImVuYyI6IkEyNTZHQ00ifQ. g_hE3pPLiSs9C60_WFQ-VP_mQ1BU00Z7Xg. 48V1_ALb6US04U3b. 5eym8mytxoXCBlYkhjBtkmmI. XFBoMYUZodetZdvTiFvSkQ
Penjelasan Kod
Keputusan
Menjalankan kod di atas akan menghasilkan rentetan JWE yang disulitkan dan kemudian menyahsulitnya kembali kepada mesej asal:
<dependency> <groupId>com.nimbusds</groupId> <artifactId>nimbus-jose-jwt</artifactId> <version>9.22</version> </dependency>
JSON Web Encryption (JWE) ialah alat penting untuk penghantaran data selamat dalam aplikasi web moden. Memahami strukturnya, cara ia berfungsi, serta kebaikan dan keburukannya akan membantu anda membuat keputusan termaklum tentang masa dan cara menggunakannya dalam aplikasi anda. Jika anda mempunyai sebarang pertanyaan atau memerlukan penjelasan lanjut, sila tinggalkan komen di bawah!
Baca siaran lebih lanjut di : Memahami JWE: Struktur, Operasi, Kelebihan, Kelemahan dan Cara Menciptanya
Atas ialah kandungan terperinci Memahami JWE: Struktur, Operasi, Kelebihan, Kelemahan, dan Cara Menciptanya. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!