2017-07-30 15 views
0

私はjwtトークンを作成しようとする次のコードを持っています。 SignatureAlgorithm signatureAlgorithm = SignatureAlgorithm.HS256を実行しようとするたびに、以下に示すようなエラーが常に発生します。java.lang.NoClassDefFoundError:io/jsonwebtoken/SignatureAlgorithm

私は手動でjwt jarファイルを削除し、mavenを再度更新してjarファイルを再インストールしましたが、それでも問題は解決しません。

ご協力いただきますようお願い申し上げます。

//Sample method to construct a JWT 
public static String createJWT(String id, String issuer, String subject, 
     String payload, String role, String name, long ttlMillis) { 
    String jwt = ""; 

    try { 
     //The JWT signature algorithm we will be using to sign the token 
     SignatureAlgorithm signatureAlgorithm = SignatureAlgorithm.HS256; 

     long nowMillis = System.currentTimeMillis(); 
     Date now = new Date(nowMillis); 

     //We will sign our JWT with our ApiKey secret 
     byte[] apiKeySecretBytes = DatatypeConverter.parseBase64Binary(apiKey.getSecret()); 
     Key signingKey = new SecretKeySpec(apiKeySecretBytes, signatureAlgorithm.getJcaName()); 

     //Let's set the JWT Claims 
     JwtBuilder builder = Jwts.builder() 
            .setIssuedAt(now) 
            .setSubject("test") 
            .claim("role", role) 
            .claim("name", name) 
            .setIssuer("tester") 
            .signWith(io.jsonwebtoken.SignatureAlgorithm.HS256, signingKey); 
            //.signWith(signatureAlgorithm, apiKey.getSecret().getBytes("UTF-8")); 
            // 

     //if it has been specified, let's add the expiration 
     if (ttlMillis >= 0) { 
     long expMillis = nowMillis + ttlMillis; 
      Date exp = new Date(expMillis); 
      builder.setExpiration(exp); 
     } 

     //Builds the JWT and serializes it to a compact, URL-safe string 
     jwt = builder.compact(); 

    } catch (Exception ex) { 

    } 
    return jwt; 
} 

エラーログ

ます。java.lang.NoClassDefFoundError:IO/jsonwebtoken /のsignatureAlgorithm com.test.service.JWTToken.createJWT(JWTToken.java:21) でcom.testで。 sun.reflect.DelegatingMethodAccessorImpl.invokeでsun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) でsun.reflect.NativeMethodAccessorImpl.invoke0(ネイティブメソッド) でcontroller.AccountController.authenticateUser(AccountController.java:82) (DelegatingMethodAccessorIm (SubResourceLocatorRouter.java:158) で、 をjava.lang.reflect.Method.invoke(Method.java:498) で、org.glassfish.jersey.server.internal.routing.SubResourceLocatorRouter $ 1.run org.glassfish.jersey.server.internal.routing.SubResourceLocatorRouter.apply(SubResourceLocatorRouter.java:109) でorg.glassfish.jersey.server.internal.routing.SubResourceLocatorRouter.getResource(SubResourceLocatorRouter.java:178) の組織で.glassfish.jersey.server.internal.routing.RoutingStage._apply(RoutingStage.java:109) at org.glassfish.jersey.server.internal.routing.RoutingStage._apply(RoutingStage.java:112) at org.glassfish .jersey.server.internal.routing.RoutingStage._apply(RoutingStage.java:112) at org.glassfish.jersey.server.internal.routing.Rou tingStage._apply(RoutingStage.java:112) at org.glassfish.jersey.server.internal.routing.RoutingStage._apply(RoutingStage.java:112) at org.glassfish.jersey.server.internal.routing.RoutingStage。 apply(RoutingStage.java:92) at org.glassfish.jersey.server.internal.routing.RoutingStage.apply(RoutingStage.java:61) at org.glassfish.jersey.process.internal.Stages.process(ステージ。 java:197) at org.glassfish.jersey.server.ServerRuntime $ 2.run(ServerRuntime.java:301) at org.glassfish.jersey.internal.Errors $ 1.call(Errors.java:271) at org。 glassfish.jersey.internal.Errors $ 1.call(Errors.java:267) at org.glassfish.jersey.internal.Errors.process(Errors.java:315) at org.glassfish.jersey.internal.Errors.process (エラーs.java:297) at org.glassfish.jersey.internal.Errors.process(Errors.java:267) at org.glassfish.jersey.process.internal.RequestScope.runInScope(RequestScope.java:317) at org.glassfish.jersey.server.Server.WebComponentの のorg.glassfish.jersey.server.ServerRuntime.process(ServerRuntime.java:292) (org.glassfish.jersey.server.ApplicationHandler.handle(ApplicationHandler.java:1139)) のorg.glassfish.jersey.servlet.WebComponent。サービス(WebComponent.java:460) at org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:386) at org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:334) at org.glassfish.jersey.servlet.ServletContainer.service(ServletContainer.java:221) at org.apache.catalina.core.StandardWrapper.se rvice(StandardWrapper.java:1682) at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:318) at org.apache.catalina.core.StandardContextValve。org.apache.catalina.core.StandardPipeline.doInvoke(StandardPipeline.java:734)で を呼び出します。 at org.apache.catalina.core.StandardPipeline.invoke(StandardPipeline.java:673) at com.sun.enterprise.web.WebPipeline.invoke(WebPipeline.java:99) at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:174) at org.apache.catalina.connector.CoyoteAdapter。 doService(CoyoteAdapter.java:416) at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:283) (com.sun.enterprise.v3.services.impl.ContainerMapper)$ HttpHandlerCallable.call(ContainerMapper。 java:459) com.sun.enterprise.v3.services.impl.ContainerMapper.service(ContainerMapper.java:167) at org.glassfish.grizzly.http.server.HttpHandler.runService(HttpHandler.java:206) at org.glassfish.grizzly.http.server.HttpHandler.doHandle(HttpHandler.java:180) at org.glassfish.grizzly。 http.server.HttpServerFilter.handleRead(HttpServerFilter.java:235) at org.glassfish.grizzly.filterchain.ExecutorResolver $ 9.execute(ExecutorResolver.java:119) at org.glassfish.grizzly.filterchain.DefaultFilterChain.executeFilter(DefaultFilterChain .java:org.glassfish.grizzly.filterchain.DefaultFilterChain.execute(DefaultFilterChain.java:132) でorg.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart(DefaultFilterChain.java:200) における283) org.glassfishで.grizzly.filterchain.DefaultFilterChain.process(DefaultFilterChain.java:111) at org。 org.glassfish.grizzly.strategies.AbstractIOStrategy.fireIOEventでorg.glassfish.grizzly.nio.transport.TCPNIOTransport.fireIOEvent(TCPNIOTransport.java:536) でglassfish.grizzly.ProcessorExecutor.execute(ProcessorExecutor.java:77) (組織でorg.glassfish.grizzly.strategies.WorkerThreadIOStrategy.access $ 100(WorkerThreadIOStrategy.java:56) でorg.glassfish.grizzly.strategies.WorkerThreadIOStrategy.run0(WorkerThreadIOStrategy.java:117) でAbstractIOStrategy.java:112) .glassfish.grizzly.strategies.WorkerThreadIOStrategy $ WorkerThreadRunnable.run(WorkerThreadIOStrategy.java:137) at org.glassfish.grizzly.threadpool.AbstractThreadPool $ Worker.doWork(AbstractThreadPool.java:591) at org.glassfish.grizzly.threadpool .AbstractThreadPool $ Worker.run(AbstractThreadPool.java:571)

POM依存関係

<dependencies> 

     <dependency> 
      <groupId>com.fasterxml.jackson.core</groupId> 
      <artifactId>jackson-databind</artifactId> 
      <version>2.8.8</version> 
     </dependency> 

     <dependency> 
      <groupId>org.glassfish.jersey.core</groupId> 
      <artifactId>jersey-client</artifactId> 
      <version>2.25.1</version> 
     </dependency> 
     <dependency> 
      <groupId>org.glassfish.jersey.core</groupId> 
      <artifactId>jersey-server</artifactId> 
      <version>2.25</version> 
     </dependency> 

     <dependency> 
      <groupId>org.json</groupId> 
      <artifactId>json</artifactId> 
      <version>20160810</version> 
     </dependency> 
     <dependency> 
      <groupId>commons-beanutils</groupId> 
      <artifactId>commons-beanutils</artifactId> 
      <version>1.9.3</version> 
     </dependency> 
     <dependency> 
      <groupId>com.fasterxml.jackson.jaxrs</groupId> 
      <artifactId>jackson-jaxrs-json-provider</artifactId> 
      <version>2.8.6</version> 
     </dependency> 
     <dependency> 
      <groupId>com.fasterxml.jackson.core</groupId> 
      <artifactId>jackson-annotations</artifactId> 
      <version>2.8.9</version> 
     </dependency> 
     <dependency> 
      <groupId>org.glassfish.jersey.media</groupId> 
      <artifactId>jersey-media-json-jackson</artifactId> 
      <version>2.25.1</version> 
     </dependency> 
     <dependency> 
      <groupId>org.eclipse.persistence</groupId> 
      <artifactId>org.eclipse.persistence.moxy</artifactId> 
      <version>2.6.4</version> 
     </dependency> 

     <dependency> 
      <groupId>org.glassfish.jersey.containers</groupId> 
      <artifactId>jersey-container-servlet</artifactId> 
      <version>2.22.1</version> 
     </dependency> 

     <dependency> 
      <groupId>io.jsonwebtoken</groupId> 
      <artifactId>jjwt</artifactId> 
      <version>0.7.0</version> 
     </dependency> 

     <dependency> 
      <groupId>mysql</groupId> 
      <artifactId>mysql-connector-java</artifactId> 
      <version>5.1.42</version> 
     </dependency> 

    </dependencies> 

答えて

0

NoClassDefFoundError java.lang.Thread.run(Thread.java:745)で実行時間の問題です。 manifestファイルにjarというエントリを追加してください。これは問題を解決するのに役立ちます。

+0

ありがとうございます – pothios

+0

@pothiosこんにちは、私はちょうど同じ問題があります。マニフェストファイルに何を追加しましたか? – JollyRoger