J'ai un projet de haricot java, je dois utiliser jai, j'ajouter un maven depedendencyAjouter Jai en tant que module wildfly
<dependency>
<groupId>com.github.jai-imageio</groupId>
<artifactId>jai-imageio-core</artifactId>
<version>1.3.1</version>
</dependency>
J'essaie d'ajouter un nouveau module à wildfly 9 comme
Module. xml
<?xml version="1.0" encoding="UTF-8"?>
<module xmlns="urn:jboss:module:1.3" name="com.github.jaiimageio">
<resources>
<resource-root path="jai-imageio-core-1.3.1.jar"/>
</resources>
</module>
Puis-je ajouter un pot de mvnrepo Et mettre jar + module.xml dans
modules wildfly-9.0.2.Final \ \ system couches \ \ base \ com \ github \ jaiimageio \ principale
Puis dans mon projet Java
jboss-déploiement structure.xml
<jboss-deployment-structure>
<deployment>
<dependencies>
<module name="org.jboss.ejb3"/>
<module name="org.jboss.ws.api"/>
<module name="org.apache.cxf"/>
<module name="org.jboss.ws.cxf.jbossws-cxf-server"/>
<module name="com.github.jaiimageio"/>
</dependencies>
</deployment>
</jboss-deployment-structure>
Mais quand je suis en train d'appeler mon haricot java j'ai une exception
Caused by: java.util.NoSuchElementException
at javax.imageio.spi.FilterIterator.next(ServiceRegistry.java:836)
at javax.imageio.ImageIO$ImageWriterIterator.next(ImageIO.java:842)
at javax.imageio.ImageIO$ImageWriterIterator.next(ImageIO.java:827)
at ru.shop.createFile.CreateFileBean.write_tiff(CreateFileBean.java:541)
at ru.shop.createFile.CreateFileBean.testAdd(CreateFileBean.java:77)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:498)
at org.jboss.as.ee.component.ManagedReferenceMethodInterceptor.processInvocation(ManagedReferenceMethodInterceptor.java:52)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.invocation.InterceptorContext$Invocation.proceed(InterceptorContext.java:437)
at org.jboss.as.weld.ejb.Jsr299BindingsInterceptor.doMethodInterception(Jsr299BindingsInterceptor.java:82)
at org.jboss.as.weld.ejb.Jsr299BindingsInterceptor.processInvocation(Jsr299BindingsInterceptor.java:93)
at org.jboss.as.ee.component.interceptors.UserInterceptorFactory$1.processInvocation(UserInterceptorFactory.java:63)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.as.ejb3.component.invocationmetrics.ExecutionTimeInterceptor.processInvocation(ExecutionTimeInterceptor.java:43)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.as.jpa.interceptor.SBInvocationInterceptor.processInvocation(SBInvocationInterceptor.java:47)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.invocation.InterceptorContext$Invocation.proceed(InterceptorContext.java:437)
at org.jboss.weld.ejb.AbstractEJBRequestScopeActivationInterceptor.aroundInvoke(AbstractEJBRequestScopeActivationInterceptor.java:73)
at org.jboss.as.weld.ejb.EjbRequestScopeActivationInterceptor.processInvocation(EjbRequestScopeActivationInterceptor.java:83)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.as.ee.concurrent.ConcurrentContextInterceptor.processInvocation(ConcurrentContextInterceptor.java:45)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.invocation.InitialInterceptor.processInvocation(InitialInterceptor.java:21)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.invocation.ChainedInterceptor.processInvocation(ChainedInterceptor.java:61)
at org.jboss.as.ee.component.interceptors.ComponentDispatcherInterceptor.processInvocation(ComponentDispatcherInterceptor.java:52)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.as.ejb3.component.interceptors.NonPooledEJBComponentInstanceAssociatingInterceptor.processInvocation(NonPooledEJBComponentInstanceAssociatingInterceptor.java:59)
at org.jboss.invocation.InterceptorContext.proceed(InterceptorContext.java:340)
at org.jboss.as.ejb3.tx.CMTTxInterceptor.invokeInOurTx(CMTTxInterceptor.java:275)
... 79 more
mon code:
private void write_tiff() throws IOException
{
RenderedImage image=javax.imageio.ImageIO.read(new File("C:\\users\\user\\Desktop\\examples\\srts.jpg"));
RenderedImage image1=javax.imageio.ImageIO.read(new File("C:\\users\\user\\Desktop\\examples\\passport.jpg"));
Iterator<ImageWriter> iterator=ImageIO.getImageWritersByFormatName("TIFF");
System.out.println(iterator.hasNext());
ImageWriter writer=iterator.next();
}
ImageIO.getImageWritersByFormatName ("TIFF") renvoie la valeur null. Mais si j'appelle cette méthode de l'application java, pas en Java, tout est ok.
J'ai essayé de transformer le nom de module en com.github.jai-imageio, mais rien ne se passe.
Quelqu'un peut-il m'aider?
Possible duplicate [Problème dans getImageWritersByFormatName pour Tiff. Obtenir l'auteur de l'image] (http://stackoverflow.com/questions/22523644/envoyer-in-getimagewritersbyformatname-for-tiff-getting-image-writer). Notez surtout la 2ème réponse, en ce qui concerne Tomcat –
Merci Jon, mais j'ai déjà essayé d'appeler scanForPlugins(), pas de résultat. Aussi j'ajoute mon pot au dossier ext dans wildfly, mais malheureusement sans resutl aussi. –
Avez-vous ajouté 'jai-imageio-core-1.3.1.jar' dans le répertoire' lib/ext' de votre jre? Je pense que c'est ce que la première réponse indiquait. –