先来一段扯皮,本人是个今年刚毕业的小菜鸟(在校主要学的Android)。之前在github发表个几个Android的demo,主要也就是当做笔记(其实是没人看我那么low的代码)。
现在,我来到简书发表自己的第一篇简书文章。希望能帮助一些刚走上code这条路的小白们。希望大家可以一起分享,一起讨论,一起学习。所以我会把我自己在平时学习过程遇到的坑也讲出来,避免大家走同样的弯路。
今天要讲的是springboot项目的创建,如果你还不知道springboot可以看下这个链接(百度百科)spring boot官网
springboot大多数是为 快速应用开发领域 因为比较传统的spring 他少了繁琐的xml配置,加载spring和spring mvc配置数据库连接,配置spring事务,配置加载配置文件的读取,开启注解,配置日志文件等(有利必有弊...)
进入正题 --->IntelliJ IDEA maven搭建springboot项目
选择Spring Initializr JDK版本 URL默认即可,点击next
Group: 对应pom.xml文件中的groupId,项目组织的唯一标识,对应Java包的结构
Artifact:对应pom文件的artifactId,项目唯一标识,对应项目名称
Type:项目类型Maven Project(因为这篇是介绍使用maven 当然可以选择gradle管理)
Language:开发语言,选择Java
Packaging:打包类型,根据需要可以选择jar 和war
Java Version:jdk版本
Version:项目版本,对应pom文件的version
Description:项目描述,对应pom文件的description
Package:包名
我们可以选择springBoot的版本 和在项目的定位方向 框架选择 数据库选择,所有选择完成以后点击next
还可以选择项目的保存路径和项目文件夹的名称
点击finish以后我们的项目就创建完成了(第一次用maven创建spring boot项目时间比较长因为要去maven下载很多东西 如果你对maven不熟悉的话可以看下链接 )另外为了加快maven构建速度我们还可以修改maven本地仓库地址具体可以参考链接
看下项目初始图,基本创建就完成了
pom.xml中的已经有了springBoot的基础配置
我们在com.example.demo报下新建controller包新建HelloController
代码如下
@Controller
public class HelloController {
@RequestMapping("/")
@ResponseBody
public Map<String,Object> index() {
Map<String,Object> jsonMap=new HashMap<>();
jsonMap.put("msg","Hello spring boot");
return jsonMap;
}
}
在application.properties(sprinigBoot的配置文件 以后会更新文章详细讲解)文件中添加
server.context-path=/BlackWingXuTest
server.port=80
这里的server.context-path是项目发布的path
注意我们在平时debug开发模式下我们启动的是这个application类由他的main方法进入
点击运行控制台输入如下
. ____ _ __ _ _
/\\ / ___'_ __ _ _(_)_ __ __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
\\/ ___)| |_)| | | | | || (_| | ) ) ) )
' |____| .__|_| |_|_| |_\__, | / / / /
=========|_|==============|___/=/_/_/_/
:: Spring Boot :: (v1.5.8.RELEASE)
2017-11-17 18:44:43.411 INFO 3240 --- [ main] com.example.demo.DemoApplication : Starting DemoApplication on DESKTOP-BIE9BFH with PID 3240 (G:\ideaProjects\target\classes started by xuwei in G:\ideaProjects)
2017-11-17 18:44:43.413 INFO 3240 --- [ main] com.example.demo.DemoApplication : No active profile set, falling back to default profiles: default
2017-11-17 18:44:43.467 INFO 3240 --- [ main] ationConfigEmbeddedWebApplicationContext : Refreshing org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@166fa74d: startup date [Fri Nov 17 18:44:43 CST 2017]; root of context hierarchy
2017-11-17 18:44:44.871 INFO 3240 --- [ main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat initialized with port(s): 80 (http)
2017-11-17 18:44:44.879 INFO 3240 --- [ main] o.apache.catalina.core.StandardService : Starting service [Tomcat]
2017-11-17 18:44:44.879 INFO 3240 --- [ main] org.apache.catalina.core.StandardEngine : Starting Servlet Engine: Apache Tomcat/8.5.23
2017-11-17 18:44:44.980 INFO 3240 --- [ost-startStop-1] o.a.c.c.C.[.[.[/BlackWingXuTest] : Initializing Spring embedded WebApplicationContext
2017-11-17 18:44:44.981 INFO 3240 --- [ost-startStop-1] o.s.web.context.ContextLoader : Root WebApplicationContext: initialization completed in 1517 ms
2017-11-17 18:44:45.110 INFO 3240 --- [ost-startStop-1] o.s.b.w.servlet.ServletRegistrationBean : Mapping servlet: 'dispatcherServlet' to [/]
2017-11-17 18:44:45.115 INFO 3240 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean : Mapping filter: 'characterEncodingFilter' to: [/*]
2017-11-17 18:44:45.115 INFO 3240 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean : Mapping filter: 'hiddenHttpMethodFilter' to: [/*]
2017-11-17 18:44:45.115 INFO 3240 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean : Mapping filter: 'httpPutFormContentFilter' to: [/*]
2017-11-17 18:44:45.115 INFO 3240 --- [ost-startStop-1] o.s.b.w.servlet.FilterRegistrationBean : Mapping filter: 'requestContextFilter' to: [/*]
2017-11-17 18:44:45.435 INFO 3240 --- [ main] s.w.s.m.m.a.RequestMappingHandlerAdapter : Looking for @ControllerAdvice: org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@166fa74d: startup date [Fri Nov 17 18:44:43 CST 2017]; root of context hierarchy
2017-11-17 18:44:45.497 INFO 3240 --- [ main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/]}" onto public java.util.Map<java.lang.String, java.lang.Object> com.example.demo.controller.HelloController.index()
2017-11-17 18:44:45.501 INFO 3240 --- [ main] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/error]}" onto public org.springframework.http.ResponseEntity<java.util.Map<java.lang.String, java.lang.Object>> org.springframework.boot.autoconfigure.web.BasicErrorController.error(javax.servlet.http.HttpServletRequest)
2017-11-17 18:44:45.502 INFO 3240 --- [ 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)
2017-11-17 18:44:45.530 INFO 3240 --- [ main] o.s.w.s.handler.SimpleUrlHandlerMapping : Mapped URL path [/webjars/**] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler]
2017-11-17 18:44:45.531 INFO 3240 --- [ main] o.s.w.s.handler.SimpleUrlHandlerMapping : Mapped URL path [/**] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler]
2017-11-17 18:44:45.569 INFO 3240 --- [ main] o.s.w.s.handler.SimpleUrlHandlerMapping : Mapped URL path [/**/favicon.ico] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler]
2017-11-17 18:44:45.735 INFO 3240 --- [ main] o.s.j.e.a.AnnotationMBeanExporter : Registering beans for JMX exposure on startup
2017-11-17 18:44:45.792 INFO 3240 --- [ main] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat started on port(s): 80 (http)
2017-11-17 18:44:45.796 INFO 3240 --- [ main] com.example.demo.DemoApplication : Started DemoApplication in 2.685 seconds (JVM running for 3.066)
打开chrome 输入http://localhost/BlackWingXuTest/ 如图
我们看到了HelloController index()返回的map了
到这里大概的springboot就走通了 后续我会进一步和大家分享springboot的拦截器等
谢谢您的耐心浏览,如果喜欢请给个赞或者留下您的评论,您的赞是我努力的动力。