SpringBoot2-基础开发环境

1.本地Maven部署

  1.1 下载3.8.4地址

https://maven.apache.org/download.cgi

  1.2 解压Maven核心程序

  1.3 配置文件

修改配置文件conf/settings.xml

#1.指定本地仓库 记住:

#一定要把 localRepository 标签从注释中拿出来。

#注意:本地仓库本身也需要使用一个非中文、没有空格的目录

<localRepository>D:\maven-repository</localRepository>

#2.阿里云提供的镜像仓库,将原有的例子配置注释掉

<mirror>
        <id>nexus-aliyun</id>
        <mirrorOf>central</mirrorOf>
        <name>Nexus aliyun</name>
       <url>http://maven.aliyun.com/nexus/content/groups/public</url>

</mirror>

#3.配置 Maven 工程的基础 JDK 版本

<profile>
      <id>jdk-1.8</id>
      <activation>
        <activeByDefault>true</activeByDefault>
        <jdk>1.8</jdk>
      </activation>
      <properties>
        <maven.compiler.source>1.8</maven.compiler.source>
        <maven.compiler.target>1.8</maven.compiler.target>
        <maven.compiler.compilerVersion>1.8</maven.compiler.compilerVersion>
      </properties>
    </profile>

  1.4 配置Java环境变量

  1.5 配置MAVEN_HOME

    1) MAVEN_HOME通常指向的是 bin 目录的上一级

    2) PATH 指向的是 bin 目录

    3) 验证

C:\Users\Administrator>mvn -v
Apache Maven 3.8.4 (9b656c72d54e5bacbed989b64718c159fe39b537)
Maven home: D:\software\apache-maven-3.8.4
Java version: 1.8.0_141, vendor: Oracle Corporation, runtime: D:\software\Java\jre
Default locale: zh_CN, platform encoding: GBK
OS name: "windows 10", version: "10.0", arch: "amd64", family: "windows"

2.SpringBoot2

  2.1 Idea配置本地Maven

  2.2 配置Settings

  2.3 File Encodings

  2.4 打包信息

        否则提示jar中没有主清单属性 

 <!-- 打包格式 -->
 <packaging>jar</packaging>

<!-- 打包插件-->
<build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <version>2.3.12.RELEASE</version>
                <executions>
                    <execution>
                        <goals>
                            <goal>repackage</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
</build>

  2.5 Lombok

    1) 安装插件lombok

    2) 添加依赖

<dependency>
    <groupId>org.projectlombok</groupId>
     <artifactId>lombok</artifactId>
</dependency>

    3) 代码

@Data
public class User {
    private String userName;
}

    4) 构造器

@AllArgsConstructor
@NoArgsConstructor

  2.6 devtools

 <!--热启动,就是不重启服务前提下刷新页面-->
<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-devtools</artifactId>
   <optional>true</optional>
</dependency>

  2.7 阿里云源

https://start.spring.io

https://start.aliyun.com 啊里云

查询版本
https://mvnrepository.com/
https://central.sonatype.com/?smo=true

  2.8 jar中没有主清单属性

    pom中添加

<build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <version>2.3.12.RELEASE</version>
                <executions>
                    <execution>
                        <goals>
                            <goal>repackage</goal>
                        </goals>
                    </execution>
                </executions>
            </plugin>
        </plugins>
</build>

  2.9 虚拟机网卡导致IP不可调用

    1) 忽略掉

spring:
  cloud:
    inetutils:
      # 可用正则表达式,表示禁用以VMware开头的网络
      ignoredInterfaces: ['VMware.*']

    显示的地址依旧可能是虚拟网卡的地址,但我试没问题,

    2)最稳妥是指定ip

spring:
  cloud:
    inetutils:
      preferred-networks: 192.168.2.18  #可以是IP段:192.168.20

    3)所有

spring.cloud.inetutils.default-hostname
spring.cloud.inetutils.default-ip-address
spring.cloud.inetutils.ignored-interfaces
spring.cloud.inetutils.preferred-networks
spring.cloud.inetutils.timeout-seconds
spring.cloud.inetutils.use-only-site-local-interfaces

  2.10 YML文件不识别

Project Structure -> Modules -> Spring -> + 

  2.11 如何查看历史版本帮助文档

    1) 打开Spring官网

spring.io

    2) 选择菜单栏中Projects下拉菜单中的Spring Framework

    3) 将OVERVIEW页面切换为LEARN页面

    4)点击任意一个版本后面的 Reference Doc.链接,选择的是current版本

    5)将上URL修改为https://docs.spring.io/spring-framework/docs/并访问,即每个版本所对应的帮助文档目录

    6) 点击任意一个版本,选择reference目录,可以看到html和pdf两种查看方式供选择

3.如何将配置文件挂到ja包外面

  3.1 java -jar 命令行中

        通过 --spring.config.location 参数指定的方式优先级最高

  3.2 设置 SPRING_CONFIG_LOCATION

        环境变量来指定配置文件的路径是次优先级

  3.3 在执行 java -jar 命令同级目录下的 config 文件夹是第三优先级

       1)注意:如果 java -jar 命令不是在项目 jar 包 同级目录执行的话,在项目 jar 包同级目录下的 config 文件夹是不生效的

        2) 在应用程序(jar包)启动命令执行目录下 创建一个名为 config 的文件夹,然后将配置文件放在该文件夹中

        3) 在代码的配置文件 application.properties 或 application.yml 中添加以下行

spring:
  config:
    location: classpath:/,file:./config/

  3.4 项目 jar 包同级下直接放 properties 文件是第四优先级,直接把配置文件放到 jar 包的同级目录

4.跨域

<!--fastjson2-->
<dependency>
    <groupId>com.alibaba.fastjson2</groupId>
    <artifactId>fastjson2</artifactId>
    <version>2.0.21</version>
</dependency>

<dependency>
    <groupId>com.alibaba.fastjson2</groupId>
    <artifactId>fastjson2-extension</artifactId>
    <version>2.0.21</version>
</dependency>

@Configuration
public class WebConfig implements WebMvcConfigurer {

    @Override
    public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {

        WebMvcConfigurer.super.configureMessageConverters(converters);

    }

    @Override
    public void extendMessageConverters(List<HttpMessageConverter<?>> converters) {

        //Json 格式化,时间格式化
        FastJsonHttpMessageConverter converter = new FastJsonHttpMessageConverter();

        // 添加支持的媒体类型
        List<MediaType> supportedMediaTypes = new ArrayList<>();
        supportedMediaTypes.add(MediaType.APPLICATION_JSON);
        supportedMediaTypes.add(MediaType.APPLICATION_ATOM_XML);
        supportedMediaTypes.add(MediaType.APPLICATION_FORM_URLENCODED);
        supportedMediaTypes.add(MediaType.APPLICATION_OCTET_STREAM);
        supportedMediaTypes.add(MediaType.APPLICATION_PDF);
        supportedMediaTypes.add(MediaType.APPLICATION_RSS_XML);
        supportedMediaTypes.add(MediaType.APPLICATION_XHTML_XML);
        supportedMediaTypes.add(MediaType.APPLICATION_XML);
        supportedMediaTypes.add(MediaType.IMAGE_GIF);
        supportedMediaTypes.add(MediaType.IMAGE_JPEG);
        supportedMediaTypes.add(MediaType.IMAGE_PNG);
        supportedMediaTypes.add(MediaType.TEXT_EVENT_STREAM);
        supportedMediaTypes.add(MediaType.TEXT_HTML);
        supportedMediaTypes.add(MediaType.TEXT_MARKDOWN);
        supportedMediaTypes.add(MediaType.TEXT_PLAIN);
        supportedMediaTypes.add(MediaType.TEXT_XML);
        converter.setSupportedMediaTypes(supportedMediaTypes);

        //配置fastjson
        FastJsonConfig config = new FastJsonConfig();
        //config.setDateFormat("yyyy-MM-dd HH:mm:ss");
        //config.setCharset(StandardCharsets.UTF_8);
        config.setWriterFilters(new PascalNameFilter());
        config.setWriterFeatures(
                JSONWriter.Feature.WriteNullListAsEmpty,
                //json格式化
                JSONWriter.Feature.PrettyFormat,
                //输出map中value为null的数据
                JSONWriter.Feature.WriteMapNullValue,
                //输出boolean 为 false
                JSONWriter.Feature.WriteNullBooleanAsFalse,
                //输出list 为 []
                JSONWriter.Feature.WriteNullListAsEmpty,
                //输出number 为 0
                JSONWriter.Feature.WriteNullNumberAsZero,
                //输出字符串 为 ""
                JSONWriter.Feature.WriteNullStringAsEmpty,
                //对map进行排序
                JSONWriter.Feature.MapSortField
        );

        converter.setFastJsonConfig(config);

        //将fastjson添加到视图消息转换器列表内
        converters.add(0, converter);

    }
    
    @Override
    public void addCorsMappings(CorsRegistry registry) {

        //跨域
        WebMvcConfigurer.super.addCorsMappings(registry);

        CorsRegistration config = registry.addMapping("/**") ;

        config.allowCredentials(true); // 允许cookies跨域
        //config.allowedOrigins("*");// #允许向该服务器提交请求的URI,*表示全部允许,在SpringMVC中,如果设成*,会自动转成当前请求头中的Origin
        config.allowedOriginPatterns("*");//Vue时用allowedOriginPatterns替换allowedOrigins
        config.allowedHeaders("*");// #允许访问的头信息,*表示全部
        config.maxAge(18000L);     // 预检请求的缓存时间(秒),即在这个时间段里,对于相同的跨域请求不会再预检了

        config = config.allowedMethods("POST","GET","OPTIONS","HEAD","PUT","DELETE","PATCH");
    }

    @Override
    public void addInterceptors(InterceptorRegistry registry) {

        JwtHandlerInterceptor handlerInterceptor = new JwtHandlerInterceptor();
        registry.addInterceptor(handlerInterceptor)
                .addPathPatterns("/**")
                .excludePathPatterns("/user/login/**");

    }
}
import org.springframework.stereotype.Component;
import javax.servlet.*;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

@Component
public class CorsFilter implements Filter {

    @Override
    public void init(FilterConfig filterConfig) throws ServletException {

    }

    @Override
    public void destroy() {

    }

    @Override
    public void doFilter(ServletRequest req, ServletResponse res, FilterChain chain) throws IOException, ServletException {

        HttpServletResponse response = (HttpServletResponse) res;
        response.setHeader("Access-Control-Allow-Origin", "*");
        response.setHeader("Access-Control-Allow-Methods", "POST, GET, OPTIONS, DELETE");
        response.setHeader("Access-Control-Max-Age", "3600");
        response.setHeader("Access-Control-Allow-Headers", "*");

        chain.doFilter(req, res);
    }
}

5.SpringBoot和JDK版本兼容性

SpringBoot JDK来源
2.08 - 9https://docs.spring.io/spring-boot/docs/2.0.x/reference/html/getting-started-system-requirements.html
2.18-12https://docs.spring.io/spring-boot/docs/2.1.x/reference/html/getting-started-system-requirements.html 
2.2 - 2.38-15https://docs.spring.io/spring-boot/docs/2.2.x/reference/html/getting-started.html#getting-started-system-requirements
https://docs.spring.io/spring-boot/docs/2.3.x/reference/html/getting-started.html#getting-started-system-requirements
2.48-16https://docs.spring.io/spring-boot/docs/2.4.x/reference/html/getting-started.html#getting-started-system-requirements
2.58-18https://docs.spring.io/spring-boot/docs/2.5.x/reference/html/getting-started.html#getting-started.system-requirements
2.68-19https://docs.spring.io/spring-boot/docs/2.6.x/reference/html/getting-started.html#getting-started.system-requirements
2.78-21https://docs.spring.io/spring-boot/docs/2.7.x/reference/html/getting-started.html#getting-started.system-requirements
3.0 - 3.217-21

https://docs.spring.io/spring-boot/docs/3.0.x/reference/html/getting-started.html#getting-started
https://docs.spring.io/spring-boot/docs/3.1.x/reference/html/getting-started.html#getting-started
https://docs.spring.io/spring-boot/docs/3.2.x/reference/html/getting-started.html#getting-starte                                                                                                                                                                                

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: idea-springboot-projectes是指使用IDEA开发工具构建Spring Boot项目的过程。Spring Boot是一个流行的开源框架,可以帮助Java开发者快速构建高效的微服务应用。IDEA则是一个以Java基础的集成开发环境,可以提供代码编辑、调试、测试和部署等功能。 在构建Spring Boot项目时,IDEA可以通过自带的Spring Initializr工具或者通过手动配置的方式来进行。Spring Initializr可以自动生成项目基础框架,包括依赖库、项目结构、POM文件等。而手动配置则需要开发者自行添加所需要的依赖库和配置文件。 在项目开发过程中,IDEA可以提供强大的代码提示和自动补全功能,包括快捷键、代码重构、调试等。此外,IDEA还支持各种测试框架和部署方式,方便开发者快速进行测试和部署。 总的来说,使用IDEA开发Spring Boot项目可以提高开发效率和代码质量,并且可以使用各种插件和扩展来增强开发体验。这是一个非常流行的Java开发模式,适用于各种类型的应用程序和系统。 ### 回答2: Idea-SpringBoot-Project是一个使用了Spring Boot框架的项目,有助于Java开发者轻松构建Web应用程序。Spring Boot是一个流行的Java框架,它可以帮助开发者更快地构建更好的应用程序。使用Idea-SpringBoot-Project,开发者可以轻松创建具有高可用性和可扩展性的Java Web应用程序。 Idea-SpringBoot-Project引入了许多方便的功能,如Spring容器管理、数据访问和Web MVC框架等。通过使用Spring Boot,开发者可以在不需要手动配置的情况下快速构建应用程序。而使用Idea作为开发工具,则能帮助开发者更快地编写代码和进行调试。这个项目不仅可以在Windows和Linux平台上运行,还与许多其他大型Java库和框架兼容,如Spring Security和Hibernate等。 总之,Idea-SpringBoot-Project帮助开发者将更多的时间专注于应用程序逻辑和功能,而不是花费时间和精力去手动配置。通过这个项目,开发者可以构建出高性能、高度可用性和可扩展性的Java应用程序。 ### 回答3: idea-springboot-projectes是针对Spring Boot框架的项目管理功能的开发工具集成环境。它提供了一种方便快捷的方式来创建、维护和调试Spring Boot项目。 idea-springboot-projectes使开发人员能够在一个单一的界面中,管理不同的Spring Boot项目,包括应用程序、库和插件。它自动生成项目结构,提供依赖管理,支持代码重构、调试和测试等功能,同时也能够整合其他常用开发工具如Maven、Gradle等,进一步提升开发效率。 通过idea-springboot-projectes,开发人员可以快速创建Spring Boot应用程序。一旦项目创建完成,可以通过IDEA的自动配置机制,无需编写大量的代码即可完成基础设施的搭建和配置。同时,IDEA也提供了许多Spring Boot Starter库,这些库包含了大量常用的功能和组件,帮助开发人员轻松实现各种业务需求。 总之,idea-springboot-projectes是一款非常实用的开发工具,为Spring Boot开发提供了强大的项目管理和开发支持,同时提高了开发效率和代码质量,使得开发人员能够更专注于业务代码的编写。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

wang_peng

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值