Java를 사용하여 Next-Auth 생성 JWT 토큰을 해독하고 정보를 얻습니다.
Next-Auth를 사용하여 JWT 토큰을 생성 할 때 문제가 발생합니다. Java 에서이 토큰을 구문 분석하고 정보를 얻는 방법은 무엇입니까? 이는 특히 교차 플랫폼 검증 및 데이터 추출이 필요할 때 매우 실용적인 요구 사항입니다.
다음과 같이 Next-Auth를 사용하여 JWT 토큰을 생성했습니다.
콜백 : { // ref : https://authjs.dev/guides/basics/role 기반-access-control#persisting-the-role Async JWT ({Token, User}) { 돌아 오십시오 }, // 클라이언트 구성 요소에서 역할을 사용하려는 경우 비동기 세션 ({세션, 사용자, 토큰}) { 반환 세션 }, }
생성 된 JWT 토큰은 다음과 같습니다.
eyjhbgcioijkaxiilcjlbmmioiijbmju2q0jdluhtntiteyiiwia2lkijoib0y4su1ycv9szuxr YXHSEVZNZVNSUXC4VFNABNRRD1R0NMZ1BNZ1ZZHBT2GTR2J1WKP4DNHHRLLQB3FUAVYTRL92YZ atwgxqujdarlrldkvon181vhcifq..dixteiywelvgcf5muhylqq.tscvrh0uxewydfj5g2sn _81IVSFSXPA5FFYDYCFWW8W_N-QMYH3NBKLP1COG1VBO2VBOPSNORMSFDI6NXZZYO264RVQSCA zdmrzl1lf-hldtuxupy8kugig828p1tpeipx8huemr_h6yk7mwgmfdqw7dtzbreyvfa-mtsmy KQ_10GIGJGLHFD-YZR7EN_-77GQXOARYLUOOAIZXGE8IA3TMBYTDS9SGN55CVVNRDYCAK6GY4 ptlmikw0pindsicgyzhyhjyrfb1vchzvmjwzelxpwrwbjgn52twmfc3xiowbvsfyfvr0znt6 MVDQW5LNYTDQ-TVUCDWWM-XDRRA5GW.BWAF05T99YVB1QYBGBFVPIK9T_ZUP2YQ5XUG26H7QNG
그러나이 토큰을 Java로 구문 분석하려고 할 때 오류는 다음과 같습니다.
정적 무효 나 () { 문자열 jwt = "eyjhbgcioiijkaxiilcjlbmmioijbmju2q0jdluhtnteyiiwia2lkijoib0y4su1ycv9szuxr YXHSEVZNZVNSUXC4VFNABNRRD1R0NMZ1BNZ1ZZHBT2GTR2J1WKP4DNHHRLLQB3FUAVYTRL92YZ atwgxqujdarlrldkvon181vhcifq..dixteiywelvgcf5muhylqq.tscvrh0uxewydfj5g2sn _81IVSFSXPA5FFYDYCFW8W_N-QMYH3NBKLP1COG1VBO2VBYPSNORMSFDI6NXZZYO264RVQSCAZ dmrzl1lf-hldtuxupy8kugig828p1tpeipx8huemr_h6yk7mwgmfdqw7dtzbreyvfa-mtsmyk Q_10GIGJGLHFD-YZR7EN_-77GQXOARYLUOOIZXGE8IA3TMBYTDS9SGN5CVVNRDYCAK6GY4PT lmikw0pindsicgyzhyhjyrfb1vchzvmjwzelxpwrwbjgn52twmfc3xiowbvssyfvr0znt6mv DQW5LNYTDQ-TVUCDWWM-XDRRA5GW.BWAF05T99YVB1QYBGBFVPIK9T_ZUP2YQ5XUG26H7QNG "; 노력하다 { // JWT 파서를 구성하고, 서명 키 및 허용 알고리즘 클레임 주장 = jwts.parserBuilder ()를 설정합니다. .SetSigningKey ( "123456") // 서명 키를 설정합니다. .짓다() .parseclaimsjws (jwt) // 토큰을 구문 분석하고 Signature.getBody ()를 자동으로 확인합니다. // 클레임 객체 가져 오기 // 클레임에서 필요한 정보를 가져옵니다. // ... 기타 클레임 정보 시스템을 얻습니다. // ... 기타 정보 인쇄} catch (예외 e) { // 유효하지 않은 서명, 만료 된 토큰 또는 기타 문제를 처리 할 수있는 예외를 처리합니다. e.printstacktrace (); } }
오류 메시지 :
io.jsonwebtoken.malformedjwtexception : jwt 문자열에는 정확히 2 개의 기간 문자가 포함되어야합니다. 발견 : 4 at io.jsonwebtoken.impl.defaultjwtparser.parse (defaultjwtparser.java:296) at io.jsonwebtoken.impl.defaultjwtparser.parse (defaultjwtparser.java:550) at io.jsonwebtoken.impl.defaultjwtparser.parseclaimsjws (defaultjwtparser.java:610) at io.jsonwebtoken.impl.immutablejwtparser.parseclaimsjws (Embutablejwtparser.java:173) at com.seaurl.gatewaysvr.gatewayserverapplication.me (GatewayserVerapplication.java:32) at com.seaurl.gatewaysvr.gatewayserverapplication.main (GatewayserVerapplication.java:49)
문제는 Next-Auth에 의해 생성 된 토큰이 암호화되어 있으며 현재 응용 프로그램에만 해당된다는 것입니다. 타사 응용 프로그램에서 토큰을 사용하려면 로그인 한 후 세션에서 사용자 정의 토큰을 설정할 수 있습니다.
Session.AccessToken = Your_token
이런 식으로, 우리는 이러한 토큰을 Java로 처리하고 정보를 얻을 수 있습니다.
위 내용은 Java에서 JWT 토큰을 생성하고 정보를 얻는 방법은 다음과 같은 정보를 얻는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

javaachievesplatformincendenceThoughthehoughthejavavirtualmachine (JVM), hittoutModification.thejvmcompileSjavacodeIntOplatform-independentByTecode, whatitTengretsAndexeSontheSpecoS, toplacetSonthecificos, toacketSecificos

javaispowerfuldueToitsplatformincendence, 객체 지향적, RichandardLibrary, PerformanceCapabilities 및 StrongSecurityFeatures.1) Platform IndependenceAllowsApplicationStorunannyDevicesUpportingjava.2) 대상 지향적 프로그래밍 프로모션 Modulara

최고 Java 기능에는 다음이 포함됩니다. 1) 객체 지향 프로그래밍, 다형성 지원, 코드 유연성 및 유지 관리 가능성 향상; 2) 예외 처리 메커니즘, 시도 캐치-패치 블록을 통한 코드 견고성 향상; 3) 쓰레기 수집, 메모리 관리 단순화; 4) 제네릭, 유형 안전 강화; 5) 코드를보다 간결하고 표현력있게 만들기위한 AMBDA 표현 및 기능 프로그래밍; 6) 최적화 된 데이터 구조 및 알고리즘을 제공하는 풍부한 표준 라이브러리.

javaisnotentirelyplatformindent의 의존적 duetojvmvariationsandnativecodeintegration

TheJavavirtualMachine (JVM) isanabstractcomputingmachinecrucialforjavaexecutionasitsjavabytecode, "writeonce, runanywhere"기능을 가능하게합니다

javaremainsagoodlugageedueToitscontinuousevolutionandrobustecosystem.1) lambdaexpressionsenhancececeadeabilitys.2) Streamsallowforefficileddataprocessing, 특히 플레어로드 라트 웨이션

javaisgreatduetoitsplatform incendence, robustoopsupport, extensibraries 및 strongcommunity.1) platforminceptenceviajvmallowscodetorunonvariousplatforms.2) oopeatures inncapsulation, Nheritance, and Polymorphismenblularandscode.3)

Java의 5 가지 주요 특징은 다형성, Lambda Expressions, Streamsapi, 제네릭 및 예외 처리입니다. 1. 다형성을 사용하면 다른 클래스의 물체가 공통 기본 클래스의 물체로 사용될 수 있습니다. 2. Lambda 표현식은 코드를보다 간결하게 만듭니다. 특히 컬렉션 및 스트림을 처리하는 데 적합합니다. 3.StreamSapi는 대규모 데이터 세트를 효율적으로 처리하고 선언적 작업을 지원합니다. 4. 제네릭은 유형 안전 및 재사용 성을 제공하며 편집 중에 유형 오류가 잡히립니다. 5. 예외 처리는 오류를 우아하게 처리하고 신뢰할 수있는 소프트웨어를 작성하는 데 도움이됩니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

Dreamweaver Mac版
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

MinGW - Windows용 미니멀리스트 GNU
이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.