2017-07-30 1 views
0

Ich habe den folgenden Code, der versucht, ein JWT-Token zu erstellen. Es wird immer einen Fehler geben, wie unten gezeigt, wenn er versucht, SignatureAlgorithm auszuführen signatureAlgorithm = SignatureAlgorithm.HS256;java.lang.NoClassDefFoundError: io/jsonwebtoken/Signaturalgorithmus

Ich habe die JWT-JAR-Datei manuell gelöscht und maven erneut aktualisiert, um das JAR erneut zu installieren, aber das Problem besteht immer noch.

Jede Hilfe wird sehr geschätzt!

//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; 
} 

Error Log

java.lang.NoClassDefFoundError: io/jsonwebtoken/signatureAlgorithm bei com.test.service.JWTToken.createJWT (JWTToken.java:21) bei com.test. controller.AccountController.authenticateUser (AccountController.java:82) bei sun.reflect.NativeMethodAccessorImpl.invoke0 (native Methode) bei sun.reflect.NativeMethodAccessorImpl.invoke (NativeMethodAccessorImpl.java:62) bei sun.reflect.DelegatingMethodAccessorImpl.invoke (DelegatingMethodAccessorIm pl.java:43) bei java.lang.reflect.Method.invoke (Methode.java:498) bei org.glassfish.jersey.server.internal.routing.SubResourceLocatorRouter $ 1.run (SubResourceLocatorRouter.java:158) bei org.glassfish.jersey.server.internal.routing.SubResourceLocatorRouter.getResource (SubResourceLocatorRouter.java:178) bei org.glassfish.jersey.server.internal.routing.SubResourceLocatorRouter.apply (SubResourceLocatorRouter.java:109) bei org .glassfish.jersey.server.internal.routing.RoutingStage._apply (RoutingStage.java:109) bei org.glassfish.jersey.server.internal.routing.RoutingStage._apply (RoutingStage.java:112) bei org.glassfish .jersey.server.internal.routing.RoutingStage._apply (RoutingStage.java:112) bei org.glassfish.jersey.server.internal.routing.Rou tingStage._apply (RoutingStage.java:112) bei org.glassfish.jersey.server.internal.routing.RoutingStage._apply (RoutingStage.java:112) bei org.glassfish.jersey.server.internal.routing.RoutingStage. Anwenden (RoutingStage.java:92) bei org.glassfish.jersey.server.internal.routing.RoutingStage.apply (RoutingStage.java:61) bei org.glassfish.jersey.process.internal.Stages.process (Stages. java: 197) bei org.glassfish.jersey.server.ServerRuntime $ 2.run (ServerRuntime.java301) bei org.glassfish.jersey.internal.Errors $ 1.call (Errors.java:271) bei org. glassfish.jersey.internal.Errors $ 1.call (Fehler.java:267) bei org.glassfish.jersey.internal.Errors.process (Errors.java:315) bei org.glassfish.jersey.internal.Errors.process (Error s.java:297) bei org.glassfish.jersey.internal.Errors.process (Fehler.java:267) bei org.glassfish.jersey.process.internal.RequestScope.runInScope (RequestScope.java:317) bei org.glassfish.jersey.server.ServerRuntime.process (ServerRuntime.java:292) unter org.glassfish.jersey.server.ApplicationHandler.handle (ApplicationHandler.java:1139) unter org.glassfish.jersey.servlet.WebComponent. Service (WebComponent.java:460) bei org.glassfish.jersey.servlet.ServletContainer.service (ServletContainer.java:386) bei org.glassfish.jersey.servlet.ServletContainer.service (ServletContainer.java:334) bei org.glassfish.jersey.servlet.ServletContainer.service (ServletContainer.java:221) bei org.apache.catalina.core.StandardWrapper.se rvice (StandardWrapper.java:1682) bei org.apache.catalina.core.StandardWrapperValve.invoke (StandardWrapperValve.java:318) bei org.apache.catalina.core.StandardContextValve.Rufen Sie (StandardContextValve.java:160) bei org.apache.catalina.core.StandardPipeline.doInvoke (StandardPipeline.java:734) bei org.apache.catalina.core.StandardPipeline.invoke (StandardPipeline.java:673) bei com.sun.enterprise.web.WebPipeline.invoke (WebPipeline.java:99) bei org.apache.catalina.core.StandardHostValve.invoke (StandardHostValve.java:174) bei org.apache.catalina.connector.CoyoteAdapter. doService (CoyoteAdapter.java:416) bei org.apache.catalina.connector.CoyoteAdapter.service (CoyoteAdapter.java:283) bei com.sun.enterprise.v3.services.impl.ContainerMapper $ HttpHandlerCallable.call (ContainerMapper. java: 459) unter com.sun.enterprise.v3.services.impl.ContainerMapper.service (ContainerMapper.java:167) bei org.glassfish.grizzly.http.server.HttpHandler.runService (HttpHandler.java:206) bei org.glassfish.grizzly.http.server.HttpHandler.doHandle (HttpHandler.java:180) bei org.glassfish.grizzly. http.server.HttpServerFilter.handleRead (HttpServerFilter.java:235) bei org.glassfish.grizzly.filterchain.ExecutorResolver $ 9.execute (ExecutorResolver.java:119) bei org.glassfish.grizzly.filterchain.DefaultFilterChain.executeFilter (DefaultFilterChain .java: 283) bei org.glassfish.grizzly.filterchain.DefaultFilterChain.executeChainPart (DefaultFilterChain.java:200) bei org.glassfish.grizzly.filterchain.DefaultFilterChain.execute (DefaultFilterChain.java:132) bei org.glassfish .grizzly.filterchain.DefaultFilterChain.process (DefaultFilterChain.java:111) bei org. glassfish.grizzly.ProcessorExecutor.execute (ProcessorExecutor.java:77) bei org.glassfish.grizzly.nio.transport.TCPNIOTransport.fireIOEvent (TCPNIOTransport.java:536) bei org.glassfish.grizzly.strategies.AbstractIOStrategy.fireIOEvent (AbstractIOStrategy.java:112) bei org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.run0 (WorkerThreadIOStrategy.java:117) bei org.glassfish.grizzly.strategies.WorkerThreadIOStrategy.access $ 100 (WorkerThreadIOStrategy.java:56) bei org .glassfish.grizzly.strategies.WorkerThreadIOStrategy $ WorkerThreadRunnable.run (WorkerThreadIOStrategy.java:137) bei org.glassfish.grizzly.threadpool.AbstractThreadPool $ Worker.doWork (AbstractThreadPool.java:591) bei org.glassfish.grizzly.threadpool .AbstractThreadPool $ Worker.run (AbstractThreadPool.java:571) bei java.lang.Thread.run (Thread.java:745)

POM Abhängigkeiten

<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> 

Antwort

0

NoClassDefFoundError ist eine Laufzeit Problem. Versuchen Sie, den jar Eintrag in Ihrer manifest Datei hinzuzufügen, dies sollte Ihnen helfen, Ihr Problem zu beheben.

+0

danke das funktioniert – pothios

+0

@pothios Hallo, ich habe gerade das gleiche Problem. Können Sie mitteilen, was Sie der Manifestdatei hinzugefügt haben? – JollyRoger

Verwandte Themen