spring boot 起步-原型实例

2024-08-22 13:38

本文主要是介绍spring boot 起步-原型实例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

自从struts2出现上次的漏洞以后 对spring的关注度开始越来越浓;

以前也那spring做过几个项目 感觉是xml配置文件需要写一大堆,后来spring加入了annotation,使得xml配置简化了很多,当然还是有些配置需要使用xml,比如申明component scan等。

前段时间发现了spring开了一个新的model spring boot,主要思想就是降低spring的入门,使得新手可以以最快的速度让程序在spring框架下跑起来。

公司以后的项目打算都使用spring boot为基础进行开发,所以打算将spring boot所有的特性都记录在博文中,也就是说些一个spring boot的系列吧,废话少说,先上第一步,看看spring boot怎么以最简单的方式让程序跑起来的 而且还是一个web项目。

首先 使用eclipse jee创建一个maven工程,一般的工程就可以(我用的是quickstart),工程就叫spring-boot-sample;

第二步 在pom.xml中引入spring-boot-start-parent,spring官方的解释叫什么stater POMs,它可以提供dependency management,也就是说依赖管理,应该是说工程需要依赖的jar包的管理,引入以后在申明其他dependency的时候就不需要version了,后面可以看到。 

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>1.0.1.RELEASE</version>
  </parent>

第三步 因为我们开发的是web工程,所以需要在pom.xml中引入spring-boot-starter-web,spring官方解释说spring-boot-starter-web包含了spring webmvc和tomcat等web开发的特性。

<dependencies>
    <dependency>
          <groupId>org.springframework.boot</groupId>
          <artifactId>spring-boot-starter-web</artifactId>
      </dependency>
  </dependencies>

第四步 真正的程序开始啦,我们需要一个启动类 然后在这个启动类中申明让spring boot自动给我们配置spring需要的配置,比如component scan等;为了可以尽快让程序跑起来,我们使用spring官方的实例: 

@Controller
@EnableAutoConfiguration
public class App {
  
  @RequestMapping("/")
  @ResponseBody
  public String hello(){
    return "Hello world!";
  }
  
  public static void main(String[] args) {
    SpringApplication.run(App.class, args);
  }
}

 其中@EnableAutoConfiguration申明让spring boot自动给程序进行必要的配置;

@Controller表示这个一个controller类;

@RequestMapping("/") 表示通过/可以访问的方法;

@ResponseBody 表示将结果直接返回给调用着。

第五步 右键pom.xml -> debug configuration,在Goals里输入 spring-boot:run,然后点击Apply,最后点击Debug。 



 

最后会出现以下log:


  .   ____          _            __ _ _ 
 /\\ / ___'_ __ _ _(_)_ __  __ _ \ \ \ \ 
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \ 
 \\/  ___)| |_)| | | | | || (_| |  ) ) ) ) 
  '  |____| .__|_| |_|_| |_\__, | / / / / 
 =========|_|==============|___/=/_/_/_/ 
 :: Spring Boot ::        (v1.0.1.RELEASE) 
2014-04-13 00:06:16.992  INFO 3472 --- [mple.App.main()] com.sample.App                           : Starting App on XUMAM4F7Q5P41FE with PID 3472 (E:\jee_workspace\spring-boot-sampe\target\classes started by Administrator) 
2014-04-13 00:06:17.254  INFO 3472 --- [mple.App.main()] ationConfigEmbeddedWebApplicationContext : Refreshing org.springframework.boot.context.embedded.AnnotationConfigEmbeddedWebApplicationContext@1c239aa: startup date [Sun Apr 13 00:06:17 GMT+08:00 2014]; root of context hierarchy 
2014-04-13 00:06:19.630  INFO 3472 --- [mple.App.main()] .t.TomcatEmbeddedServletContainerFactory : Server initialized with port: 8080 
2014-04-13 00:06:20.086  INFO 3472 --- [mple.App.main()] o.apache.catalina.core.StandardService   : Starting service Tomcat 
2014-04-13 00:06:20.086  INFO 3472 --- [mple.App.main()] org.apache.catalina.core.StandardEngine  : Starting Servlet Engine: Apache Tomcat/7.0.52 
2014-04-13 00:06:20.568  INFO 3472 --- [ost-startStop-1] o.a.c.c.C.[Tomcat].[localhost].[/]       : Initializing Spring embedded WebApplicationContext 
2014-04-13 00:06:20.578  INFO 3472 --- [ost-startStop-1] o.s.web.context.ContextLoader            : Root WebApplicationContext: initialization completed in 3334 ms 
2014-04-13 00:06:22.134  INFO 3472 --- [ost-startStop-1] o.s.b.c.e.ServletRegistrationBean        : Mapping servlet: 'dispatcherServlet' to [/] 
2014-04-13 00:06:22.154  INFO 3472 --- [ost-startStop-1] o.s.b.c.embedded.FilterRegistrationBean  : Mapping filter: 'hiddenHttpMethodFilter' to: [/*] 
2014-04-13 00:06:22.787  INFO 3472 --- [mple.App.main()] o.s.w.s.handler.SimpleUrlHandlerMapping  : Mapped URL path [/**/favicon.ico] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler] 
2014-04-13 00:06:23.061  INFO 3472 --- [mple.App.main()] s.w.s.m.m.a.RequestMappingHandlerMapping : Mapped "{[/],methods=[],params=[],headers=[],consumes=[],produces=[],custom=[]}" onto public java.lang.String com.sample.App.hello() 
2014-04-13 00:06:23.130  INFO 3472 --- [mple.App.main()] o.s.w.s.handler.SimpleUrlHandlerMapping  : Mapped URL path [/**] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler] 
2014-04-13 00:06:23.130  INFO 3472 --- [mple.App.main()] o.s.w.s.handler.SimpleUrlHandlerMapping  : Mapped URL path [/webjars/**] onto handler of type [class org.springframework.web.servlet.resource.ResourceHttpRequestHandler] 
2014-04-13 00:06:23.623  INFO 3472 --- [mple.App.main()] o.s.j.e.a.AnnotationMBeanExporter        : Registering beans for JMX exposure on startup 
2014-04-13 00:06:23.724  INFO 3472 --- [mple.App.main()] s.b.c.e.t.TomcatEmbeddedServletContainer : Tomcat started on port(s): 8080/http 
2014-04-13 00:06:23.725  INFO 3472 --- [mple.App.main()] com.sample.App                           : Started App in 7.867 seconds (JVM running for 18.295) 

这个时候在浏览器中访问http://localhost:8080/ ,你会发现"Hello world!"出现啦... 

转自:http://www.tuicool.com/articles/iANRF3

这篇关于spring boot 起步-原型实例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/1096433

相关文章

JDK8(Java Development kit)的安装与配置全过程

《JDK8(JavaDevelopmentkit)的安装与配置全过程》文章简要介绍了Java的核心特点(如跨平台、JVM机制)及JDK/JRE的区别,重点讲解了如何通过配置环境变量(PATH和JA... 目录Java特点JDKJREJDK的下载,安装配置环境变量总结Java特点说起 Java,大家肯定都

Spring定时任务之fixedRateString的实现示例

《Spring定时任务之fixedRateString的实现示例》本文主要介绍了Spring定时任务之fixedRateString的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录从毫秒到 Duration:为何要改变?核心:Java.time.Duration.parse

Java 中 Optional 的用法及最佳实践

《Java中Optional的用法及最佳实践》在Java开发中,空指针异常(NullPointerException)是开发者最常遇到的问题之一,本篇文章将详细讲解Optional的用法、常用方... 目录前言1. 什么是 Optional?主要特性:2. Optional 的基本用法2.1 创建 Opti

docker编写java的jar完整步骤记录

《docker编写java的jar完整步骤记录》在平常的开发工作中,我们经常需要部署项目,开发测试完成后,最关键的一步就是部署,:本文主要介绍docker编写java的jar的相关资料,文中通过代... 目录all-docker/生成Docker打包部署文件配置服务A的Dockerfile (a/Docke

Java中实现对象的拷贝案例讲解

《Java中实现对象的拷贝案例讲解》Java对象拷贝分为浅拷贝(复制值及引用地址)和深拷贝(递归复制所有引用对象),常用方法包括Object.clone()、序列化及JSON转换,需处理循环引用问题,... 目录对象的拷贝简介浅拷贝和深拷贝浅拷贝深拷贝深拷贝和循环引用总结对象的拷贝简介对象的拷贝,把一个

Java 字符串操作之contains 和 substring 方法最佳实践与常见问题

《Java字符串操作之contains和substring方法最佳实践与常见问题》本文给大家详细介绍Java字符串操作之contains和substring方法最佳实践与常见问题,本文结合实例... 目录一、contains 方法详解1. 方法定义与语法2. 底层实现原理3. 使用示例4. 注意事项二、su

Spring Boot中获取IOC容器的多种方式

《SpringBoot中获取IOC容器的多种方式》本文主要介绍了SpringBoot中获取IOC容器的多种方式,包括直接注入、实现ApplicationContextAware接口、通过Spring... 目录1. 直接注入ApplicationContext2. 实现ApplicationContextA

详解Spring中REQUIRED事务的回滚机制详解

《详解Spring中REQUIRED事务的回滚机制详解》在Spring的事务管理中,REQUIRED是最常用也是默认的事务传播属性,本文就来详细的介绍一下Spring中REQUIRED事务的回滚机制,... 目录1. REQUIRED 的定义2. REQUIRED 下的回滚机制2.1 异常触发回滚2.2 回

Java 单元测试之Mockito 模拟静态方法与私有方法最佳实践

《Java单元测试之Mockito模拟静态方法与私有方法最佳实践》本文将深入探讨如何使用Mockito来模拟静态方法和私有方法,结合大量实战代码示例,带你突破传统单元测试的边界,写出更彻底、更独立... 目录Mockito 简介:为什么选择它?环境准备模拟静态方法:打破“不可变”的枷锁传统困境解法一:使用M

linux查找java项目日志查找报错信息方式

《linux查找java项目日志查找报错信息方式》日志查找定位步骤:进入项目,用tail-f实时跟踪日志,tail-n1000查看末尾1000行,grep搜索关键词或时间,vim内精准查找并高亮定位,... 目录日志查找定位在当前文件里找到报错消息总结日志查找定位1.cd 进入项目2.正常日志 和错误日