springboot的web开发

2019-01-23  本文已影响0人  白夜亮司丶

Ⅰ、简介

如何使用SpringBoot;
1)、创建SpringBoot应用,选中我们需要的模块;
2)、SpringBoot已经默认将这些场景配置好了,只需要在配置文件中指定少量配置就可以运行起来
3)、自己编写业务代码;
自动配置原理?
每当我们在创建项目中新增了一个模块场景时,我们都要考虑这个场景SpringBoot帮我们配置了什么?我们能不能修改?我们能修改哪些配置?我们能不能扩展?

怎么看spring帮我们配置了什么
项目的External Libraries中有一个自动配置包,这个包下有很多的自动配置模块:

image.png
每个模块中会有对应的自动配置类:
xxxxAutoConfiguration:帮我们给容器中自动配置组件;
xxxxProperties:配置类来封装配置文件的内容;

我们需要参考这个配置类,就能知道springboot帮我们自动配置了什么

Ⅱ、springboot对静态资源的映射

springboot中org.springframework.boot.autoconfigure.web.servlet.WebMvcAutoConfiguration
类定义了一些静态资源的默认配置,类的部分代码如下:

@ConfigurationProperties(prefix = "spring.resources", ignoreUnknownFields = false)
public class ResourceProperties implements ResourceLoaderAware {
  //可以设置和静态资源有关的参数,缓存时间等
    WebMvcAuotConfiguration:
        @Override
        public void addResourceHandlers(ResourceHandlerRegistry registry) {
            if (!this.resourceProperties.isAddMappings()) {
                logger.debug("Default resource handling disabled");
                return;
            }
            Integer cachePeriod = this.resourceProperties.getCachePeriod();
            if (!registry.hasMappingForPattern("/webjars/**")) {
                customizeResourceHandlerRegistration(
                        registry.addResourceHandler("/webjars/**")
                                .addResourceLocations(
                                        "classpath:/META-INF/resources/webjars/")
                        .setCachePeriod(cachePeriod));
            }
            String staticPathPattern = this.mvcProperties.getStaticPathPattern();
            //静态资源文件夹映射
            if (!registry.hasMappingForPattern(staticPathPattern)) {
                customizeResourceHandlerRegistration(
                        registry.addResourceHandler(staticPathPattern)
                                .addResourceLocations(
                                        this.resourceProperties.getStaticLocations())
                        .setCachePeriod(cachePeriod));
            }
        }

        //配置欢迎页映射
        @Bean
        public WelcomePageHandlerMapping welcomePageHandlerMapping(
                ResourceProperties resourceProperties) {
            return new WelcomePageHandlerMapping(resourceProperties.getWelcomePage(),
                    this.mvcProperties.getStaticPathPattern());
        }

       //配置喜欢的图标
        @Configuration
        @ConditionalOnProperty(value = "spring.mvc.favicon.enabled", matchIfMissing = true)
        public static class FaviconConfiguration {

            private final ResourceProperties resourceProperties;

            public FaviconConfiguration(ResourceProperties resourceProperties) {
                this.resourceProperties = resourceProperties;
            }

            @Bean
            public SimpleUrlHandlerMapping faviconHandlerMapping() {
                SimpleUrlHandlerMapping mapping = new SimpleUrlHandlerMapping();
                mapping.setOrder(Ordered.HIGHEST_PRECEDENCE + 1);
                //所有  **/favicon.ico 
                mapping.setUrlMap(Collections.singletonMap("**/favicon.ico",
                        faviconRequestHandler()));
                return mapping;
            }

            @Bean
            public ResourceHttpRequestHandler faviconRequestHandler() {
                ResourceHttpRequestHandler requestHandler = new ResourceHttpRequestHandler();
                requestHandler
                        .setLocations(this.resourceProperties.getFaviconLocations());
                return requestHandler;
            }

        }

1)、所有 /webjars/** ,都去 classpath:/META-INF/resources/webjars/ 找资源;
webjars:以jar包的方式引入静态资源;参考:http://www.webjars.org/

<!--引入jquery-webjar-->在访问的时候只需要写webjars下面资源的名称即可
<dependency>
<groupId>org.webjars</groupId>
<artifactId>jquery</artifactId>
<version>3.3.1</version>
</dependency>

2)、"/**" 访问当前项目的任何资源,都去(静态资源的文件夹)找映射

"classpath:/resources/",
"classpath:/static/",
"classpath:/public/"
"/":当前项目的根路径

localhost:8080/abc === 去静态资源文件夹里面找abc
3)、欢迎页; 静态资源文件夹下的所有index.html页面;被"/**"映射;
localhost:8080/ 找index页面
4)、所有的 **/favicon.ico 都是在静态资源文件下找;
如何更改默认的资源文件路径:

#更改默认配置静态文件访问路径,如改为:类路径下的hello文件夹,
spring.resources.static-locations=classpath:/test/
#多个路径,逗号分隔:
spring.resources.static-locations=classpath:/test/,classpath:/test2/,

Ⅲ、模板引擎

市面上的模板引擎大概有:JSP、Velocity、Freemarker、Thymeleaf

模板引擎功能图示

SpringBoot推荐的Thymeleaf;语法更简单,功能更强大;thymeleaf官网

1).引入thymeleaf;
 <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-thymeleaf</artifactId>
        </dependency>
<!--不需要手动导入,创建项目时选择模块那一步可以勾选idea会自动导入-->
2).thymeleaf的使用;
/**
*thymeleaf自动配置类的一小部分代码
*/
@ConfigurationProperties(prefix = "spring.thymeleaf")
public class ThymeleafProperties {

    private static final Charset DEFAULT_ENCODING = Charset.forName("UTF-8");

    private static final MimeType DEFAULT_CONTENT_TYPE = MimeType.valueOf("text/html");
 //规定了要thymeleaf所在的文件路径前缀是classpath:/templates/
    public static final String DEFAULT_PREFIX = "classpath:/templates/";
 //规定了thymeleaf所在文件的后缀名是  .html
    public static final String DEFAULT_SUFFIX = ".html";
//就是说只要我们把HTML页面放在classpath:/templates/,thymeleaf就能自动渲染;

使用:
控制器层

package com.byls.springboot;

import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;

import java.util.Map;

@Controller
public class HelloController {

    @RequestMapping(value = "succeed")
    public String helloController(Map<String, String > map){
        map.put("hello","你好");
        return "index";
    }
}

页面

<!DOCTYPE html>
<!--导入命名空间-->
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
    <!--${hello}直接取值,注意要卸载标签的属性中-->
    <div th:text="${hello}">
    直接访问
   </div>
</body>
</html>

值得注意的是,当通过浏览器的导航栏,请求地址访问页面时,页面会显示的是控制器预设的值,如果将该html文件复制到桌面直接访问,页面的返回值则是div中的“直接访问”

3).语法规则

官方文档传送门
1、th:text;改变当前元素里面的文本内容;th:任意html属性;来替换原生属性的值
2.表达式:

Simple expressions:(表达式语法)
  Variable Expressions: ${...}:获取变量值;OGNL;         
  Selection Variable Expressions: *{...}:选择表达式:和${}在功能上是一样;     
  Message Expressions: #{...}:获取国际化内容
  Link URL Expressions: @{...}:定义URL;           
  Fragment Expressions: ~{...}:片段引用表达式
       
Literals(字面量)
  Text operations:(文本操作) 
  Arithmetic operations:(数学运算)
  Boolean operations:(布尔运算)  
  Comparisons and equality:(比较运算)
  Conditional operators:条件运算(三元运算符)
   
Special tokens:
    No-Operation: _ 

Ⅳ、springMVC的自动配置

官方文档传送门

1). Spring MVC auto-configuration

Spring Boot 自动配置好了SpringMVC
以下是SpringBoot对SpringMVC的默认配置:(WebMvcAutoConfiguration)

@Bean
@ConditionalOnProperty(prefix = "spring.mvc", name = "date-format")//在文件中配置日期格式化的规则
public Formatter<Date> dateFormatter() {
    return new DateFormatter(this.mvcProperties.getDateFormat());//日期格式化组件
}

​ 自己添加的格式化器转换器,我们只需要放在容器中即可

org.springframework.boot.autoconfigure.web:web的所有自动场景;
If you want to keep Spring Boot MVC features, and you just want to add additional MVC configuration (interceptors, formatters, view controllers etc.) you can add your own @Configuration class of type WebMvcConfigurerAdapter, but without@EnableWebMvc. If you wish to provide custom instances of RequestMappingHandlerMapping, RequestMappingHandlerAdapter or ExceptionHandlerExceptionResolver you can declare a WebMvcRegistrationsAdapter instance providing such components.
If you want to take complete control of Spring MVC, you can add your own @Configuration annotated with @EnableWebMvc.

2).如何扩展SpringMVC

编写一个配置类(@Configuration),是WebMvcConfigurerAdapter类型;不能标注@EnableWebMvc;既保留了所有的自动配置,也能用我们扩展的配置;

@Configuration
// WebMvcConfigurerAdapter过时,使用WebMvcConfigurer接口
public class MyMvcConfig implements WebMvcConfigurer {
    @Override
    public void addViewControllers(ViewControllerRegistry registry) {
        // 浏览器发送 /cuzz 请求来到 success
        registry.addViewController("/cuzz").setViewName("success");
    }
}

原理:
1、WebMvcAutoConfiguration是SpringMVC的自动配置类
2、在做其他自动配置时会导入;@Import(EnableWebMvcConfiguration.class)

    @Configuration
    public static class EnableWebMvcConfiguration extends DelegatingWebMvcConfiguration {
      private final WebMvcConfigurerComposite configurers = new WebMvcConfigurerComposite();

     //从容器中获取所有的WebMvcConfigurer
      @Autowired(required = false)
      public void setConfigurers(List<WebMvcConfigurer> configurers) {
          if (!CollectionUtils.isEmpty(configurers)) {
              this.configurers.addWebMvcConfigurers(configurers);
                //一个参考实现;将所有的WebMvcConfigurer相关配置都来一起调用;  
                @Override
                // public void addViewControllers(ViewControllerRegistry registry) {
                //      for (WebMvcConfigurer delegate : this.delegates) {
                //      delegate.addViewControllers(registry);
                //   }
              }
          }
    }

3、容器中所有的WebMvcConfigurer都会一起起作用;
4、我们的配置类也会被调用;
效果:SpringMVC的自动配置和我们的扩展配置都会起作用;

3).全面接管SpringMVC;

SpringBoot对SpringMVC的自动配置不需要了,所有都是我们自己配置;所有的SpringMVC的自动配置都失效了
我们需要在配置类中添加@EnableWebMvc即可;

Ⅴ、如何修改spring的自动配置

模式:
​ 1)、SpringBoot在自动配置很多组件的时候,先看容器中有没有用户自己配置的(@Bean、@Component)如果有就用用户配置的,如果没有,才自动配置;如果有些组件可以有多个(ViewResolver)将用户配置的和自己默认的组合起来;
​ 2)、在SpringBoot中会有非常多的xxxConfigurer帮助我们进行扩展配置
​ 3)、在SpringBoot中会有很多的xxxCustomizer帮助我们进行定制配置

Ⅵ、RestfulCRUD

1)、默认访问首页
2)、国际化
3)、登陆

Ⅶ、禁用缓存

上一篇下一篇

猜你喜欢

热点阅读