Failed to start JMagick

I have a strange problem with the JMagick library. I am using Debian, so I installed libjmagick6-java and libjmagick6-jni and here are the steps I took:

  • I copied jmagick-6.6.9.jar

    from /usr/share/java/

    to $JAVA_HOME/jre/lib/ext/

    .
  • I have set /usr/lib/jni

    (where libJMagick.so

    ) as the local library location to:
    • JRE Systems Library (in eclipse)
    • jmagick-6.6.9.jar (in eclipse)

Also I tested JMagick in a simple Java project and there it works, but in a second project that works in Tomcat 6 it just doesn't work.

Here is my code that WORKS - so jmagick should be installed correctly:

public class Main {
    public static void main(String[] arg) {
        MagickImage image = null;
        ImageInfo imageInfo = null;

        try {
            imageInfo = new ImageInfo("/home/firzen/IMG_0120.JPG");
            image = new MagickImage(imageInfo);
            System.out.println(image.getDimension().width);
        } catch (MagickException e) {
                System.out.println(e);
        }
        image.destroyImages();
    }
}

      

And here is the code in the webapp that DOESN'T WORK :

public void init() {        
    ServletContext sc = getServletContext();
    cacheHandlers = (Map<String, CacheContext>) sc.getAttribute("handlers");
    Boolean applicationReady = (Boolean) sc.getAttribute("ready");
    isReady = cacheHandlers != null && Boolean.TRUE.equals(applicationReady);

    System.out.println("zde");
    MagickImage image = null;
    ImageInfo imageInfo = null;

    try {
        imageInfo = new ImageInfo("/home/firzen/IMG_0120.JPG");
        image = new MagickImage(imageInfo);
        System.out.println(image.getDimension().width);
    } catch (MagickException e) {
            System.out.println(e);
    }
    image.destroyImages();
}

      

Finally, this is the exception thrown by the above code:

java.lang.UnsatisfiedLinkError: no JMagick in java.library.path
    at java.lang.ClassLoader.loadLibrary(Unknown Source)
    at java.lang.Runtime.loadLibrary0(Unknown Source)
    at java.lang.System.loadLibrary(Unknown Source)
    at magick.Magick.<clinit>(Magick.java:18)
    at cz.bach.mrimage.MrImageSrv.init(MrImageSrv.java:44)
    at javax.servlet.GenericServlet.init(GenericServlet.java:212)
    at org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1173)
    at org.apache.catalina.core.StandardWrapper.allocate(StandardWrapper.java:809)
    at org.apache.catalina.core.StandardWrapperValve.invoke(StandardWrapperValve.java:129)
    at org.apache.catalina.core.StandardContextValve.invoke(StandardContextValve.java:191)
    at org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:563)
    at org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:554)
    at org.apache.catalina.core.StandardHostValve.invoke(StandardHostValve.java:127)
    at org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102)
    at org.apache.catalina.core.StandardEngineValve.invoke(StandardEngineValve.java:109)
    at org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:298)
    at org.apache.coyote.http11.Http11Processor.process(Http11Processor.java:859)
    at org.apache.coyote.http11.Http11Protocol$Http11ConnectionHandler.process(Http11Protocol.java:588)
    at org.apache.tomcat.util.net.JIoEndpoint$Worker.run(JIoEndpoint.java:489)
    at java.lang.Thread.run(Unknown Source)

      

Please tell us some ideas how to solve this problem. Thanks in advance!

+3


source to share


1 answer


I finally solved this problem by checking the real java.library.path with

System.out.println("java.library.path is: " + System.getProperty("java.library.path"));

      

This gave me this mess:

java.library.path is: /opt/jdk1.7.0_45/jre/lib/i386/server:/opt/jdk1.7.0_45/jre/lib/i386:/opt/jdk1.7.0_45/jre/../lib/i386:/usr/lib/jvm/java-6-openjdk-i386/jre/lib/i386/client:/usr/lib/jvm/java-6-openjdk-i386/jre/lib/i386::/usr/java/packages/lib/i386:/lib:/usr/lib

      



At the end you can see / usr / lib, so I created a link to libJMagick.so in / usr / lib:

ln -s /usr/lib/jni/libJMagick.so /usr/lib/libJMagick.so

      

Enjoy! :-)

+5


source







All Articles