Menyahkod Token JWT dengan JwtSecurityTokenHandler
Menyahkod token JWT boleh menjadi tugas yang mudah menggunakan kelas JwtSecurityTokenHandler. Walau bagaimanapun, jika anda menghadapi masalah seperti ralat "rentetan perlu dalam format JSON padat", berikut ialah cara untuk menyelesaikannya.
Seperti yang dinyatakan dalam soalan, JwtSecurityTokenHandler memerlukan rentetan itu dalam format tertentu: Base64UrlEncodedHeader.Base64UrlEndcodedPayload.OPTIONAL,Base64UrlEncodedSignature.
Untuk menyelesaikan isu ini, penyelesaiannya melibatkan penghantaran hasil ReadToken atau menggunakan kaedah ReadJwtToken sebaliknya. Begini cara ia berfungsi:
Menggunakan Kaedah Hantar:
var stream = "[encoded jwt]"; var handler = new JwtSecurityTokenHandler(); var jsonToken = handler.ReadToken(stream); var tokenS = jsonToken as JwtSecurityToken;
Pembolehubah tokenS kini daripada jenis JwtSecurityToken, membenarkan akses kepada tuntutan menggunakan tokenS.Claims.
Menggunakan ReadJwtToken Kaedah:
var token = "[encoded jwt]"; var handler = new JwtSecurityTokenHandler(); var jwtSecurityToken = handler.ReadJwtToken(token);
Sebagai alternatif, anda boleh terus membaca token menggunakan kaedah ReadJwtToken. Kaedah ini juga mengembalikan objek JwtSecurityToken.
Setelah token dinyahkodkan dengan betul, anda boleh mendapatkan semula tuntutan menggunakan:
var jti = tokenS.Claims.First(claim => claim.Type == "jti").Value;
Ini akan mendapatkan semula nilai tuntutan jti daripada token.
Ingat, adalah penting untuk menggunakan format yang betul semasa menyahkod token JWT dengan JwtSecurityTokenHandler untuk mengelakkan ralat dan memastikan akses yang betul kepada tuntutan.
Atas ialah kandungan terperinci Bagaimana untuk Menyahkod Token JWT menggunakan JwtSecurityTokenHandler dan Selesaikan Ralat 'rentetan perlu dalam format JSON padat'?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!