栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java > SpringBoot

SpringBoot开发深入

SpringBoot 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

SpringBoot开发深入

设置环境属性

SpringBoot默认启动的端口是8080,如果要换成别的端口就需要设置端口属性覆盖默认值,我们需要通过在项目中的"src/main/resources"下创建application.properties文件(或者是application.yml文件)。

YAML 的意思其实是:"Yet Another Markup Language"(仍是一种标记语言)。和properties文件简单区别,如properties文件中db.username=root,转换成yml的格式则为
db:
username: root
具体格式请参考:YAML 语言教程

如果要改变端口,则在applicaiton.xml文件中配置server.port即可

server.port=80# 配置contextPath,访问路径变为: http://127.0.0.1/springboot/xxxserver.context-path=/springboot

如果是使用application.yml文件,配置如下

server:
  port: 80
  context-path: /springboot
读取资源文件

实际开发中我们常需要读取资源文件,国际化也需要依赖资源文件。下面分步骤讲解一下在springboot中如何读取资源文件。

  1. 在src/main/resources目录下建立i18n文件夹;

  2. 在i18n目录中创建2个资源文件
    Messages.properties文件

welcome.url=www.google.com
welcome.msg=u6b22u8fce{0}u5149u4e34uff01

Pages.properties文件

member.add.page=/pages/back/admin/member/member_add.jsp
member.add.action=/pages/back/admin/member/member_add.action
  1. 在applicaion.yml文件中增加如下配置

spring:
  messages:
    basename: i18n/Messages,i18n/Pages
  1. 创建读取配置信息的控制器类MessageController

@RestControllerpublic class MessageController {    @Resource
    private MessageSource messageSource; // 自动注入此资源对象

    @RequestMapping(value = "showMsg",method = RequestMethod.GET)    public String showMessage(String user){
        System.out.println("request url:" + this.getMessage("member.add.action"));        return this.getMessage("welcome.msg", user);
    }    private String getMessage(String key,String... args) {        return messageSource.getMessage(key,args, Locale.getDefault());
    }
}
配置Bean

SpringBoot没有单独提供配置Bean的方式,它配置Bean的方式还是得依赖Spring提供的方式。Spring中提供了3中装配Bean的方式

  • 自动化装配bean;

  • 在Java类中进行配置;

  • 在xml文件中配置。

自动化配置bean

自动配置一般使用的最多,通过@Controller、@Service、@Component等注解完成Bean的配置,而通过@Resource、@Autowired注解完成依赖的注入。不过默认情况下自动配置不是开启的,在传统Spring项目中可以通过在Java配置类中增加@ComponentScan注解或者在xml配置文件中加入配置来打开组件扫描功能。在Springboot中,通过在启动类中加入@SpringBootApplication注解既能打开组件扫描功能,默认扫描路径为启动类所在的包路径。

Java配置文件类配置bean
package cn.zgc.springboot.advanced.config;import cn.zgc.springboot.advanced.service.impl.MessageJavaConfigServiceImpl;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;

@Configuration  // 此处为配置项
public class ServiceConfig {
    @Bean(name="configService")     // 此处返回的是一个Spring的配置Bean,与xml的“”等价
    public MessageJavaConfigServiceImpl getMessageService() {        return new MessageJavaConfigServiceImpl() ;
    }
}
XML文件配置bean

一般情况下,是不推荐使用xml文件进行配置的,但是如果非要在Springboot项目中使用xml文件该如何办呢?可以在程序启动类上使用 @importResource注解引入xml 文件进行配置加载

@SpringBootApplication // 启动SpringBoot程序,而后自带子包扫描@importResource(locations={"classpath:spring-common.xml"})public class StartSpringBootMain { public static void main(String[] args) throws Exception {
 SpringApplication.run(StartSpringBootMain.class, args);
 }
}
profile配置

实际项目中一般会存在多个环境,例如:开发、测试、生产。每个环境都有自己不同的配置,我们可以借助spring的profile来方便的实现不同环境之间的切换。profile的配置针对项目中使用的是application.yml还是application.properties有所不同,下面讲解是基于application.yml的。

  1. 在application.yml文件中配置如下内容

spring:
  profiles:
    active: product
---
spring:
  messages:
    basename: i18n/Messages,i18n/Pages
  profiles: dev
server:
  port: 8080
---
spring:
  messages:
    basename: i18n/Messages,i18n/Pages
  profiles: testserver:
  port: 9090
---
spring:
  messages:
    basename: i18n/Messages,i18n/Pages
  profiles: product

可以看到不同环境所启动的端口有所不同。

  1. 对工程进行打包,然后进行不同环境的切换。
    打包命令:clean package
    切换不同环境指令:java -jar microboot.jar --spring.profiles.active=test 如果直接运行java -jar xxx.jar则运行的是yml文件中配置的激活(active,示例中为product)的环境

  2. 打包的时候,页面和一些资源文件也需要一起打到jar包中,这时需要在pom文件中加入以下配置


    
        src/main/resources
        
            ***.yml
            ***.tld
        
        false
    
    
        src/main/java
        
            ***.xml
            ***.*
        
        false
    
页面模板渲染

常见的页面模板渲染技术有:FreeMarker、Velocity、Thymeleaf,Spring官方推荐使用Thymeleaf。下面介绍一下如何在springboot中使用Thymeleaf。

  1. 在pom文件中导入thymeleaf的依赖

org.springframework.bootspring-boot-starter-thymeleaf
  1. 创建controller类,通过Model向显示层传递参数

@Controllerpublic class ThymeleafController {    @RequestMapping(value = "/thymeleaf", method = RequestMethod.GET)    public String toThymeleaf(String username, Model model){
        model.addAttribute("username",username);
        model.addAttribute("password","123456789");        // 此处返回的是一个路径, 该路径的后缀默认是*.html
        return "message/user";
    }
}
  1. 创建页面文件,thymeleaf相关的页面文件保存的路径是有规定的:在CLASSPATH路径下(src/main/resources、src/main/view)必须建立有一个templates的目录,在这个目录里面保存有thymeleaf的页面,这些页面可以按照文件目录保存。


    SpringBoot模版渲染
    
    
    


  1. 如果现在我们所定义的要访问的页面不是通过控制器跳转的怎么办?那么为了解决这样的问题,可以考虑在 thymeleaf 所在的父路径中“src/main/view”建立一个 static 的子目录,该目录保存的是所有静态页面。项目中的静态的资源都放入该目录下。

    springboot页面资源路径


    如果要更改thymeleaf页面默认的后缀,可以在application.yml文件中加入如下配置(页面文件的后缀要和修改后的后缀保持一致)

spring: 
 thymeleaf: suffix: .htm



作者:Coding小聪
链接:https://www.jianshu.com/p/de2e4d1cb342


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/235923.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号