• Intelij IDEA创建SpringBoot项目


    springboot介绍

    官网:spring.io

    Spring Boot is designed to get you up and running as quickly as possible, with minimal upfront configuration of Spring. Spring Boot takes an opinionated view of building production-ready applications.

    spring boot 致力于简洁,让开发者写更少的配置,程序能够更快的运行和启动。它是下一代javaweb框架,并且它是spring cloud(微服务架构)的基础。

    springboot主要是是针对单服务器,后续还有spring cloud针对多服务器协调的应用 。

    springboot与spring cloud的简单区别

    • springboot是针对单服务器,spring cloud是多服务器之间协调用

    建立第一个程序

    主要步骤如下

    1. 创建项目
    2. pom.xml解释-可以略过
    3. 配置application.yml
    4. 创建boot启动类

    项目的目录结构如下:

    1560610956787

    创建项目

    1.新建项目 选 择spring initializer项目

    1560604086840

    输入project Metadata

    1560604153748

    选择依赖 web=>sprbing web starter,其它也可以。

    1560604236198

    确认项目路径

    1560604270912

    POM.xml解释

    parent里配置spring boot的依赖。

    spring-boot-starter-parent:自动导入web模块运行时所依赖的组件

    pom是启动器,根据不同的场会自动配置使用到的相关技术 。简化开发。

      <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>2.0.5.RELEASE</version>
            <relativePath/> <!-- lookup parent from repository -->
        </parent>
        //parent 是springboot必须的。 
        
        //jdk的版本
            <properties>
            <java.version>1.8</java.version>
        </properties>
        
        //项目的插件
         <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
            </plugins>
          //项目的依赖
           <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
    
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-test</artifactId>
                <scope>test</scope>
            </dependency>
        </dependencies>
        

    配置application.yml

    在src-main-resources下右击添加文件

    添加 application.yml文件,配置文件名是固定的

    1560609333467

    配置服务器端口9001

    server:
      port: 9001
    

    同时删除项目中自带的一些不必要的文件 ,

    yml文件

    yml文件是以数据为中心,比json,xml等文件更适合做配置文件

    用缩近表示层级,不能使用tab,只能使用空格 。大小写敏感

    YAML支持三种数据格式:对象,数组,基本数据类型

    举例:
    person:name: 张三 age: 20 sex: false birthday: 2019/01/11 list: - a - b map: -k1: v1 -k2: v2 -dog: {name: ww,age: 12} dog: name: ww age: 2
    

    创建boot启动类

    在main-java-下建新类, web.controller.HelloController

    • RestController 添加在类的上面,表示以下的类都可以使用
    • RestController表示两个注解的结合,分别是@Controller 和@ResponseController注解,

    所以下面的方法中不需要再添加 @Responsecontroller注解了

    • 方法的注解前面要加上相应的注解mapping.
    package com.example.demo.web.controller;
    
    import org.springframework.web.bind.annotation.RequestMapping;
    import org.springframework.web.bind.annotation.RestController;
    
    @RestController //@Controller +@responsecontroller
    public class HelloController {
        @RequestMapping("/hello")
        public String Hello(String name){
            return name+" say good evening";
        }
    }
    
    • 在DemoApplication中的main方法中右击启动

    1560611307153

    可以在控制台中看到服务器端口会自动读取application.yml中的配置端口 9001

    1560611386700

    浏览器中输入网址进行测试 ,返回方法中的结果,测试成功

    1560611428183

    注解的解释

    参考:https://baijiahao.baidu.com/s?id=1623648034778672046&wfr=spider&for=pc

    @SpringBootApplication注解

    @SpringBootApplication是一个复合注解,包括@ComponentScan,@SpringBootConfiguration,@EnableAutoConfiguration。

    @SpringBootConfiguration继承自@Configuration,二者功能也一致,标注当前类是配置类,并会将当前类内声明的一个或多个以@Bean注解标记的方法的实例纳入到srping容器中,并且实例名就是方法名

    @EnableAutoConfiguration的作用启动自动的配置。据你添加的jar包来配置你项目的默认配置,比如根据spring-boot-starter-web,来判断你的项目是否需要添加了webmvc和tomcat,就会自动的帮你配置web项目中所需要的默认配置。

    @ComponentScan,扫描当前包及其子包下被@Component,@Controller,@Service,@Repository注解标记的类并纳入到spring容器中进行管理

    @ResponseBody

    表示该方法的返回结果直接写入HTTP response body中,一般在异步获取数据时使用,用于构建RESTful的api。在使用@RequestMapping后,返回值通常解析为跳转路径,加上@esponsebody后返回结果不会被解析为跳转路径,而是直接写入HTTP response body中。比如异步获取json数据,加上@Responsebody后,会直接返回json数据。该注解一般会配合@RequestMapping一起使用

    @Controller

    用于定义控制器类,在spring项目中由控制器负责将用户发来的URL请求转发到对应的服务接口(service层),一般这个注解在类中,通常方法需要配合注解@RequestMapping

    @RestController

    用于标注控制层组件(如struts中的action),@ResponseBody和@Controller的合集


    本文由 hcb 创作,采用 知识共享署名 3.0,可自由转载、引用,但需署名作者且注明文章出处。
  • 相关阅读:
    navicat 创建查询失败 can not create file
    使用Themeleaf时, HTML内嵌的JS代码需要注意< 和 >的问题
    window下查杀占用端口的进程
    Spring MVC的Rest URL 被错误解析成jsp, 导致404错误(XML方式下@Controller和@RestController需要配置<mvc:annotation-driving/>)
    一个本地DNS解析和mysql授权导致的Mysq连接失败问题(Access denied for user 'loan'@'kfcsdb1' (using password: YES))
    taglib报错The content of element type "taglib" must match "(tlib-version,...)
    cvc-complex-type.2.4.a: Invalid content was found starting with element 'display-name'
    在eclipse中运行spring web application时的异常: java.lang.ClassNotFoundException: org.springframework.web.context.ContextLoaderListener
    Spring3升级到Spring4时, 运行时出现找不到MappingJacksonHttpMessageConverter的情况
    如何在Spring MVC Test中避免”Circular view path” 异常
  • 原文地址:https://www.cnblogs.com/xichji/p/11211507.html
Copyright © 2020-2023  润新知