Amdatu 休息示例不起作用?

Amdatu rest example doesn't work?

我已经用 amdatu-bootstrap jar 文件创建了一个 bnd-workspace。然后创建一个测试 rest 项目和一个 bnd 运行 描述符文件来测试它。当我 运行 运行 描述符文件并导航到 http://localhost:8080/test 时,我遇到了 404 页面 :(.

HTTP ERROR: 404

Problem accessing /test. Reason:

    Not Found

以下是我为此采取的详细步骤:

  1. 已下载并使用 bootstrap-bin-r9.zip
  2. 在 Amdatu Bootstrap UI 中,为了初始化工作区,我使用 "amdatu" 模板
  3. 发布了 "workspace-init"
  4. 然后我用"project-create"命令
  5. 创建了一个项目"osgi.test"
  6. 然后我使用"rest-createcomponent"命令
  7. 创建了一个测试组件"tmp.Test",其中“/test”为url
  8. 然后我使用 "rest-install" 命令
  9. 添加了其余所需的依赖项
  10. 然后我用 org.apache.felix.framework;version='[5.2.0,5.2.0]' 和 Java-1.8 作为 OSGI 框架创建了 launcher.bndrun。
  11. 然后我用 "rest-run" 命令
  12. 添加了其他需要的库到 launcher.bndrun
  13. 然后我用 "shell-run" 命令添加了 gogo 和 dm shell

测试组件:

package tmp;

import java.util.List;

import javax.ws.rs.Path;
import javax.ws.rs.core.MediaType;
import javax.ws.rs.GET;
import javax.ws.rs.Produces;
import java.util.Arrays;
import org.apache.felix.dm.annotation.api.Component;

@Component(provides = Object.class)
@Path("/test")
public class Test {

    @GET
    @Produces(MediaType.APPLICATION_JSON)
    public List<String> list() {
        return Arrays.asList("test");
    }
}

这是捆绑包列表:

lb
START LEVEL 1
   ID|State      |Level|Name
    0|Active     |    0|System Bundle (5.2.0)
    1|Active     |    1|Apache Felix Http Jetty (3.2.0)
    2|Active     |    1|Apache Felix Http API (3.0.0)
    3|Active     |    1|Apache Felix Servlet API (1.1.2)
    4|Active     |    1|Apache Felix Http Whiteboard (3.0.0)
    5|Active     |    1|org.amdatu.web.rest.jaxrs (1.1.1)
    6|Active     |    1|org.amdatu.web.rest.wink (3.0.1)
    7|Active     |    1|org.amdatu.web.rest.doc (1.2.3)
    8|Active     |    1|Jackson-annotations (2.6.3)
    9|Active     |    1|Jackson-core (2.6.3)
   10|Active     |    1|jackson-databind (2.6.3)
   11|Active     |    1|Jackson-JAXRS-base (2.6.3)
   12|Active     |    1|Jackson-JAXRS-JSON (2.6.3)
   13|Active     |    1|Apache Felix Dependency Manager (4.3.0)
   14|Active     |    1|Apache Felix Dependency Manager Runtime (4.0.3)
   15|Active     |    1|Apache Felix Metatype Service (1.0.12)
   16|Active     |    1|Apache Felix EventAdmin (1.3.2)
   17|Active     |    1|Apache Felix Configuration Admin Service (1.8.6)
   18|Active     |    1|OPS4J Pax Logging - API (1.7.0)
   19|Active     |    1|OPS4J Pax Logging - Service (1.7.0)
   20|Active     |    1|osgi.test (0.0.0)
   21|Active     |    1|Apache Felix Gogo Command (0.12.0)
   22|Active     |    1|Apache Felix Gogo Runtime (0.10.0)
   23|Active     |    1|Apache Felix Gogo Shell (0.10.0)
   24|Active     |    1|Apache Felix Dependency Manager Shell (4.0.4)

这里是 "dm" 命令的结果

dm
[6] org.amdatu.web.rest.wink
 [0] org.amdatu.web.rest.jaxrs.JaxRsSpi registered
 [1] org.slf4j.impl.StaticLoggerBinder(OSGi) registered
    org.osgi.service.log.LogService service optional available
 [2] org.amdatu.web.rest.whiteboard.JaxRsWhiteboard registered
    active{bundle.id=6} bundle required available
    org.osgi.service.log.LogService service optional available
    javax.ws.rs.core.Application (osgi.jaxrs.application.base=*) service optional unavailable
    java.lang.Object (osgi.jaxrs.resource.base=*) service optional unavailable
 [3] Adapter for interface org.amdatu.web.rest.jaxrs.ApplicationService registered
    org.amdatu.web.rest.jaxrs.ApplicationService service optional unavailable
[14] org.apache.felix.dependencymanager.runtime
 [4] org.apache.felix.dm.runtime.DependencyManagerRuntime registered
    active (DependencyManager-Component=*) bundle optional unavailable
    org.osgi.service.packageadmin.PackageAdmin service required available
    org.osgi.service.log.LogService service optional available

当我导航到 http://localhost:8080/test 时显示以下错误

HTTP ERROR: 404

Problem accessing /test. Reason:

    Not Found

感谢任何帮助。

将org.amdatu.web.rest.wink的版本更改为2.0.3即可解决问题。

我不知道版本 3+ 有什么问题以及为什么它只适用于 2.0.3?!!!