如何访问 Codenvy Spring 启动网络控制器?
How to access a Codenvy Spring Boot web controller?
我正在测试 Codenvy (https://codenvy.io) 并制作了一个非常简单的 Spring 启动网络控制器:
@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)
在我的浏览器中,项目的 url 是:https://codenvy.io/dashboard/#/ide/tyvain/BOTS
简单(愚蠢)的问题:我如何调用这个 URL 来测试它??
这不是一个愚蠢的问题:)
当您在云端 IDE 时,应用程序 运行 处于另一个 运行 时间之内。对于codenvy,我们使用Docker个容器作为运行时间。 Docker 允许您启动您的应用程序,但随后使用临时端口范围获取您服务器的内部端口号并使其可供外部世界使用。它将端口映射到从 32765+ 范围开始的另一个数字。这样做是因为如果在同一个端口上的两个工作区 运行 中有两台服务器,它们会相互冲突,因此 docker 将端口置于此范围内以避免端口冲突。
您需要设置一个带预览的命令URL,以便在您 运行 时向您的服务器显示 URL。我们有很多关于如何在 www.eclipse.org 生成预览 URL 的文档。而且,您还可以在示例中查看命令的结构(尝试 Maven spring 示例)。
https://codenvy.com/docs/user-guide/previews/index.html
这是您要找的东西吗?
看起来变量是 运行 命令
的命令面板的一部分
我正在测试 Codenvy (https://codenvy.io) 并制作了一个非常简单的 Spring 启动网络控制器:
@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)
在我的浏览器中,项目的 url 是:https://codenvy.io/dashboard/#/ide/tyvain/BOTS
简单(愚蠢)的问题:我如何调用这个 URL 来测试它??
这不是一个愚蠢的问题:)
当您在云端 IDE 时,应用程序 运行 处于另一个 运行 时间之内。对于codenvy,我们使用Docker个容器作为运行时间。 Docker 允许您启动您的应用程序,但随后使用临时端口范围获取您服务器的内部端口号并使其可供外部世界使用。它将端口映射到从 32765+ 范围开始的另一个数字。这样做是因为如果在同一个端口上的两个工作区 运行 中有两台服务器,它们会相互冲突,因此 docker 将端口置于此范围内以避免端口冲突。
您需要设置一个带预览的命令URL,以便在您 运行 时向您的服务器显示 URL。我们有很多关于如何在 www.eclipse.org 生成预览 URL 的文档。而且,您还可以在示例中查看命令的结构(尝试 Maven spring 示例)。
https://codenvy.com/docs/user-guide/previews/index.html
这是您要找的东西吗?
看起来变量是 运行 命令
的命令面板的一部分