2016-12-21 207 views
1

我試圖用bndtools對OSGI REST包進行編碼。實施OSGI REST時出錯:`OSGi包未啓動:缺少需求`

我在cnf項目中添加了我需要的所有罐子。 然後我將它們添加到包構建路徑。

我得到以下運行時異常

OSGi包沒有啓動:缺需求osgi.wiring.package (&(osgi.wiring.package = javax.ws.rs)(版本2.0.0 = )((版本 = 3.0.0)))

,因爲我用javax.ws.rs-api 2.0.1.

我試圖指定版本明確的,我不理解的錯誤buildpath像這樣

-buildpath: \ 
javax.ws.rs-api;version2.0.1 \ 

沒有任何運氣。

我使用錯誤的jar嗎?

謝謝

這裏是我的BND

-buildpath: \ 
    osgi.annotation,\ 
    osgi.core,\ 
    osgi.cmpn,\ 
    org.apache.felix.dependencymanager,\ 
    com.google.guava,\ 
    lmca.ps.util;version=latest,\ 
    lmca.ps.infrastructure;version=latest,\ 
    org.ops4j.pax.logging.pax-logging-api,\ 
    com.fasterxml.jackson.core.jackson-annotations,\ 
    com.fasterxml.jackson.core.jackson-core,\ 
    com.fasterxml.jackson.core.jackson-databind,\ 
    com.fasterxml.jackson.jaxrs.jackson-jaxrs-base,\ 
    com.fasterxml.jackson.jaxrs.jackson-jaxrs-json-provider,\ 
    com.fasterxml.jackson.module.jackson-module-jaxb-annotations,\ 
    org.eclipse.jetty.alpn.server,\ 
    org.eclipse.jetty.annotations,\ 
    org.eclipse.jetty.cdi.core,\ 
    org.eclipse.jetty.cdi.servlet,\ 
    org.eclipse.jetty.cdi.websocket,\ 
    org.eclipse.jetty.client,\ 
    org.eclipse.jetty.continuation,\ 
    org.eclipse.jetty.deploy,\ 
    org.eclipse.jetty.gcloud.session,\ 
    org.eclipse.jetty.http,\ 
    org.eclipse.jetty.infinispan,\ 
    org.eclipse.jetty.io,\ 
    org.eclipse.jetty.jaas,\ 
    org.eclipse.jetty.jmx,\ 
    org.eclipse.jetty.jndi,\ 
    org.eclipse.jetty.memcached.session,\ 
    org.eclipse.jetty.nosql,\ 
    org.eclipse.jetty.plus,\ 
    org.eclipse.jetty.proxy,\ 
    org.eclipse.jetty.quickstart,\ 
    org.eclipse.jetty.rewrite,\ 
    org.eclipse.jetty.schemas,\ 
    org.eclipse.jetty.security,\ 
    org.eclipse.jetty.security.jaspi,\ 
    org.eclipse.jetty.server,\ 
    org.eclipse.jetty.servlet,\ 
    org.eclipse.jetty.servlets,\ 
    org.eclipse.jetty.unixsocket,\ 
    org.eclipse.jetty.util,\ 
    org.eclipse.jetty.webapp,\ 
    org.eclipse.jetty.xml,\ 
    org.glassfish.hk2.api,\ 
    org.glassfish.hk2.external.aopalliance-repackaged,\ 
    org.glassfish.hk2.external.javax.inject,\ 
    org.glassfish.hk2.locator,\ 
    org.glassfish.hk2.osgi-resource-locator,\ 
    org.glassfish.hk2.utils,\ 
    org.glassfish.jersey.bundles.repackaged.jersey-guava,\ 
    org.glassfish.jersey.containers.jersey-container-servlet,\ 
    org.glassfish.jersey.containers.jersey-container-servlet-core,\ 
    org.glassfish.jersey.core.jersey-client,\ 
    org.glassfish.jersey.core.jersey-common,\ 
    org.glassfish.jersey.core.jersey-server,\ 
    org.glassfish.jersey.media.jersey-media-jaxb,\ 
    javax.servlet-api,\ 
    javax.annotation-api,\ 
    javax.jms-api,\ 
    javax.validation.api,\ 
    jaxb-api,\ 
    slf4j.api,\ 
    org.osgi.service.log,\ 
    org.ops4j.pax.logging.pax-logging-service,\ 
    org.ops4j.pax.logging.pax-logging-logback,\ 
    json,\ 
    javax.ws.rs-api,\ 
    persistence-api,\ 
    javassist 
-runfw: org.apache.felix.framework;version='[5.6.1,5.6.1]' 
-runee: JavaSE/compact1-1.9 
-runrequires: \ 
    osgi.identity;filter:='(osgi.identity=org.apache.felix.dependencymanager.shell)',\ 
    osgi.identity;filter:='(osgi.identity=org.apache.felix.dependencymanager)',\ 
    osgi.identity;filter:='(osgi.identity=org.apache.felix.gogo.command)',\ 
    osgi.identity;filter:='(osgi.identity=org.apache.felix.gogo.runtime)',\ 
    osgi.identity;filter:='(osgi.identity=org.apache.felix.gogo.shell)',\ 
    osgi.identity;filter:='(osgi.identity=com.google.guava)',\ 
    osgi.identity;filter:='(osgi.identity=org.apache.felix.scr)',\ 
    osgi.identity;filter:='(osgi.identity=org.apache.felix.fileinstall)',\ 
    osgi.identity;filter:='(osgi.identity=org.apache.felix.configadmin)',\ 
    osgi.identity;filter:='(osgi.identity=lmca.ps.util)',\ 
    osgi.identity;filter:='(osgi.identity=lmca.ps.infrastructure)',\ 
    osgi.identity;filter:='(osgi.identity=org.apache.felix.log)',\ 
    osgi.identity;filter:='(osgi.identity=org.ops4j.pax.logging.pax-logging-service)',\ 
    osgi.identity;filter:='(osgi.identity=jaxb-api)' 
-runbundles: \ 
    ch.qos.logback.classic;version='[1.1.7,1.1.8)',\ 
    ch.qos.logback.core;version='[1.1.7,1.1.8)',\ 
    com.google.guava;version='[20.0.0,20.0.1)',\ 
    org.apache.felix.configadmin;version='[1.8.12,1.8.13)',\ 
    org.apache.felix.dependencymanager;version='[4.3.0,4.3.1)',\ 
    org.apache.felix.dependencymanager.shell;version='[4.0.4,4.0.5)',\ 
    org.apache.felix.gogo.command;version='[0.16.0,0.16.1)',\ 
    org.apache.felix.gogo.runtime;version='[0.16.2,0.16.3)',\ 
    org.apache.felix.gogo.shell;version='[0.10.0,0.10.1)',\ 
    org.apache.felix.metatype;version='[1.1.2,1.1.3)',\ 
    slf4j.api;version='[1.7.21,1.7.22)',\ 
    org.apache.felix.fileinstall;version='[3.5.4,3.5.5)',\ 
    org.apache.felix.scr;version='[2.0.6,2.0.7)',\ 
    lmca.ps.util;version=snapshot,\ 
    lmca.ps.infrastructure;version=snapshot,\ 
    org.apache.felix.log;version='[1.0.1,1.0.2)',\ 
    org.ops4j.pax.logging.pax-logging-api;version='[1.9.1,1.9.2)',\ 
    org.ops4j.pax.logging.pax-logging-service;version='[1.9.1,1.9.2)' 
Bundle-Name: foo.bar 
Bundle-Description: Example bundle 
-runvm: -Dfelix.fileinstall.dir=/home/bar\n\ 
    -Dfelix.fileinstall.noInitialDelay=true\n\ 
    -Dfelix.fileinstall.poll=1000\n\ 
    -Dorg.ops4j.pax.logging.DefaultServiceLog.level=INFO 
Bundle-Activator: foo.bar.Activator 
Private-Package: foo.bar 

完整的錯誤是

could not resolve the bundles: [foo.bar-0.0.0 org.osgi.framework.BundleException: Unable to resolve foo.bar [19](R 19.0): missing requirement [foo.bar [19](R 19.0)] osgi.wiring.package; (&(osgi.wiring.package=javax.ws.rs)(version>=2.0.0)(!(version>=3.0.0))) Unresolved requirements: [[foo.bar [19](R 19.0)] osgi.wiring.package; (&(osgi.wiring.package=javax.ws.rs)(version>=2.0.0)(!(version>=3.0.0)))] 
] 

Failed to start bundle foo.bar-0.0.0, exception Unable to resolve foo.bar [19](R 19.0): missing requirement [foo.bar [19](R 19.0)] osgi.wiring.package; (&(osgi.wiring.package=javax.ws.rs)(version>=2.0.0)(!(version>=3.0.0))) Unresolved requirements: [[foo.bar [19](R 19.0)] osgi.wiring.package; (&(osgi.wiring.package=javax.ws.rs)(version>=2.0.0)(!(version>=3.0.0)))] 
+1

你能否用你在運行時綁定的信息更新你的問題,哪一個沒有解決(什麼是完整的錯誤信息)? –

+0

@MilenDyankov我更新了我的問題 – Marc

回答

1

我不得不改變

-runee: JavaSE/compact1-1.9

-runee: JavaSE-1.8