使用Opencv进行人脸检测:找不到javacv类

时间:2013-10-04 09:29:43

标签: java php jsp opencv javacv

任务工作流程 使用网络摄像头拍摄照片并保存在目录中并加载该图像以进行opencv检测(面部)

第一次在Ubuntu中运行程序时,图像没有被保存并且发生异常。

错误1:

HTTP状态500 -

输入例外报告

消息

description The server encountered an internal error () that prevented it from fulfilling this request.

例外

javax.servlet.ServletException: Servlet execution threw an exception
root cause

java.lang.UnsatisfiedLinkError: /var/cache/tomcat6/temp/javacpp8724578391270070/libjniopencv_core.so: /lib64/libc.so.6: version `GLIBC_2.14' not found (required by /var/cache/tomcat6/temp/javacpp8724578391270070/libopencv_core.so.2.4)
    java.lang.ClassLoader$NativeLibrary.load(Native Method)
    java.lang.ClassLoader.loadLibrary0(ClassLoader.java:1750)
    java.lang.ClassLoader.loadLibrary(ClassLoader.java:1646)
    java.lang.Runtime.load0(Runtime.java:787)
    java.lang.System.load(System.java:1022)
    com.googlecode.javacpp.Loader.loadLibrary(Loader.java:566)
    com.googlecode.javacpp.Loader.load(Loader.java:489)
    com.googlecode.javacpp.Loader.load(Loader.java:431)
    com.googlecode.javacv.cpp.opencv_core.<clinit>(opencv_core.java:136)
    java.lang.Class.forName0(Native Method)
    java.lang.Class.forName(Class.java:266)
    com.googlecode.javacpp.Loader.load(Loader.java:453)
    com.googlecode.javacv.cpp.opencv_imgproc.<clinit>(opencv_imgproc.java:97)
    java.lang.Class.forName0(Native Method)
    java.lang.Class.forName(Class.java:266)
    com.googlecode.javacpp.Loader.load(Loader.java:453)
    com.googlecode.javacv.cpp.opencv_highgui.<clinit>(opencv_highgui.java:85)
    facerecognition.javafaces.TestServlet.doPost(TestServlet.java:104)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:717)
root cause

java.lang.UnsatisfiedLinkError: /var/cache/tomcat6/temp/javacpp8724578391270070/libopencv_core.so.2.4: libtbb.so: cannot open shared object file: No such file or directory
    java.lang.ClassLoader$NativeLibrary.load(Native Method)
    java.lang.ClassLoader.loadLibrary0(ClassLoader.java:1750)
    java.lang.ClassLoader.loadLibrary(ClassLoader.java:1646)
    java.lang.Runtime.load0(Runtime.java:787)
    java.lang.System.load(System.java:1022)
    com.googlecode.javacpp.Loader.loadLibrary(Loader.java:566)
    com.googlecode.javacpp.Loader.load(Loader.java:481)
    com.googlecode.javacpp.Loader.load(Loader.java:431)
    com.googlecode.javacv.cpp.opencv_core.<clinit>(opencv_core.java:136)
    java.lang.Class.forName0(Native Method)
    java.lang.Class.forName(Class.java:266)
    com.googlecode.javacpp.Loader.load(Loader.java:453)
    com.googlecode.javacv.cpp.opencv_imgproc.<clinit>(opencv_imgproc.java:97)
    java.lang.Class.forName0(Native Method)
    java.lang.Class.forName(Class.java:266)
    com.googlecode.javacpp.Loader.load(Loader.java:453)
    com.googlecode.javacv.cpp.opencv_highgui.<clinit>(opencv_highgui.java:85)
    facerecognition.javafaces.TestServlet.doPost(TestServlet.java:104)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:717)

注意Apache Tomcat / 6.0.24日志中提供了根本原因的完整堆栈跟踪。

当程序第二次运行时,图像会保存,但会发生异常

错误2:

HTTP状态500 -

输入例外报告

消息

description服务器遇到内部错误(),导致无法完成此请求。

例外

javax.servlet.ServletException: Servlet execution threw an exception
root cause

java.lang.NoClassDefFoundError: Could not initialize class com.googlecode.javacv.cpp.opencv_highgui
    facerecognition.javafaces.TestServlet.doPost(TestServlet.java:104)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:637)
    javax.servlet.http.HttpServlet.service(HttpServlet.java:717)

注意Apache Tomcat / 6.0.24日志中提供了根本原因的完整堆栈跟踪。

我使用过try catch,但是异常来了。程序在Windows中运行时没有问题。

1 个答案:

答案 0 :(得分:0)

错误1:

libtbb.so是英特尔线程构建块库,您需要安装它。因为正在加载其他本机库,您要么没有安装tbb,要么它不在您的usr / lib文件夹中。

错误2: 这是缺少jar文件错误。检查运行时应用程序类路径中是否包含javacv jar文件。