如何访问Codenvy Spring Boot Web控制器?

时间:2016-11-17 22:41:45

标签: spring maven spring-boot codenvy

我正在测试Codenvy(https://codenvy.io)并制作了一个非常简单的Spring Boot Web控制器:

@Controller
@EnableAutoConfiguration
public class SampleController { 

@RequestMapping("/")
@ResponseBody
String home() {
    return "Hello World!";
}

public static void main(String[] args) throws Exception {
    SpringApplication.run(SampleController.class, args);
}

}

的pom.xml:

 <parent>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-parent</artifactId>
  <version>1.4.2.RELEASE</version>
 </parent>
 <dependencies>
 <dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-web</artifactId>
  </dependency>

启动就可以了:

          2016-11-17 22:34:23.060  INFO 344 --- [           main] sample.SampleController                  : Starting SampleController on 780c1f85387b with PID 344 (/projects/Spring-boot started by user in /projects/Spring-boot)
      2016-11-17 22:34:23.084  INFO 344 --- [           main] sample.SampleController                  : No active profile set, falling back to default profiles: default
      2016-11-17 22:34:23.334  INFO 344 --- [           main] ationConfigEmbeddedWebApplicationContext : Refreshing org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@70e8f8e: startup date [Thu Nov 17 22:34:23 UTC 2016]; root of context hierarchy
      2016-11-17 22:34:34.172  INFO 344 --- [           main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat initialized with port(s): 8080 (http)
      2016-11-17 22:34:34.343  INFO 344 --- [           main] o.apache.catalina.core.StandardService   : Starting service Tomcat
      2016-11-17 22:34:34.358  INFO 344 --- [           main] org.apache.catalina.core.StandardEngine  : Starting Servlet Engine: Apache Tomcat/8.5.6
      2016-11-17 22:34:34.746  INFO 344 --- [ost-startStop-1] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext
      2016-11-17 22:34:34.748  INFO 344 --- [ost-startStop-1] o.s.web.context.ContextLoader            : Root WebApplicationContext: initialization completed in 11431 ms
      2016-11-17 22:34:35.782  INFO 344 --- [ost-startStop-1] o.s.b.w.servlet.ServletRegistrationBean  : Mapping servlet: 'dispatcherServlet' to [/]
      2016-11-17 22:34:35.808  INFO 344 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'characterEncodingFilter' to: [/*]
      2016-11-17 22:34:35.810  INFO 344 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'hiddenHttpMethodFilter' to: [/*]
      2016-11-17 22:34:35.812  INFO 344 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'httpPutFormContentFilter' to: [/*]
      2016-11-17 22:34:35.814  INFO 344 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean   : Mapping filter: 'requestContextFilter' to: [/*]
      2016-11-17 22:34:37.532  INFO 344 --- [           main] s.w.s.m.m.a.RequestMappingHandlerAdapter : Looking for @ControllerAdvice: org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@70e8f8e: startup date [Thu Nov 17 22:34:23 UTC 2016]; root of context hierarchy
      2016-11-17 22:34:38.123  INFO 344 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/]}" onto java.lang.String sample.SampleController.home()
      2016-11-17 22:34:38.170  INFO 344 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error]}" onto public org.springframework.http.ResponseEntity> org.springframework.boot.autoconfigure.web.BasicErrorController.error(javax.servlet.http.HttpServletRequest)
      2016-11-17 22:34:38.170  INFO 344 --- [           main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error],produces=[text/html]}" onto public org.springframework.web.servlet.ModelAndView org.springframework.boot.autoconfigure.web.BasicErrorController.errorHtml(javax.servlet.http.HttpServletRequest,javax.servlet.http.HttpServletResponse)
      2016-11-17 22:34:38.490  INFO 344 --- [           main] o.s.w.s.handler.SimpleUrlHandlerMapping  : Mapped URL path [/webjars/**] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler]
      2016-11-17 22:34:38.490  INFO 344 --- [           main] o.s.w.s.handler.SimpleUrlHandlerMapping  : Mapped URL path [/**] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler]
      2016-11-17 22:34:38.646  INFO 344 --- [           main] o.s.w.s.handler.SimpleUrlHandlerMapping  : Mapped URL path [/**/favicon.ico] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler]
      2016-11-17 22:34:39.377  INFO 344 --- [           main] o.s.j.e.a.AnnotationMBeanExporter        : Registering beans for JMX exposure on startup
      2016-11-17 22:34:39.669  INFO 344 --- [           main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat started on port(s): 8080 (http)
      2016-11-17 22:34:39.708  INFO 344 --- [           main] sample.SampleController                  : Started SampleController in 20.214 seconds (JVM running for 21.802)

在我的浏览器中,该项目的网址为:https://codenvy.io/dashboard/#/ide/tyvain/BOTS

简单(愚蠢)问题:如何调用此URL来测试它?

2 个答案:

答案 0 :(得分:2)

这不是一个愚蠢的问题:)

当您在云IDE中时,应用程序在另一个运行时内运行。在codenvy的情况下,我们使用Docker容器作为运行时。 Docker允许您启动应用程序,但随后使用临时端口范围获取服务器的内部端口号并使其可供外部使用。它将端口映射到另一个从32765+范围开始的数字。这样做是因为如果两个工作区中有两个服务器在同一个端口上运行,它们都会相互冲突,因此docker将端口放入此范围以避免端口冲突。

您需要设置一个带有previewURL的命令,该命令会在您运行服务器时显示服务器的URL。我们有很多关于如何在www.eclipse.org上生成预览URL的文档。但是,您也可以看到样本中命令的结构(尝试maven spring样本)。

答案 1 :(得分:-1)

https://codenvy.com/docs/user-guide/previews/index.html

这是你在问什么,寻找?

看起来变量是运行命令命令pallette的一部分