zoukankan      html  css  js  c++  java
  • 11. SpringBoot 之CRUD实例


    SpringBoot静态页路径,可直接通过URL访问的:
    1. /META-INF/resources
    2. /resources
    3. /static
    4. /public

    而    5. /template 只和模板引擎有关,加载了模板引擎才能用

    welcome页面的设置默认为index.html

    按照1,2,3,4,5的顺序寻找index.html,先找到的先解析,但是一般都放到templates目录下。

      

    SpringBoot CRUD开发


    1.将页面文件和类文件:SpringBoot_crud_页面.tar  加入到项目相应路径下:

    实现方式


     1. 只在/templates目录下创建index.html页面,什么也不配智,根据SpringBoot的自动配置自动匹配上

    2. 在Controller中指定,但是此时Controller的类上不能配置@RequestMapping("/somePath"),因为页面引用的静态文件默认是在当前路径下,也会被加上/somePath,以至于找不到静态资源文件而无法渲染

    • @RequestMapping("/hello")
      @Controller
      public class HelloWorldController
      {
          /**
           * 这里会被模板引擎解析而走/templates/index.html
           * @return
           */
          @RequestMapping({"/","/index","/index.html"})
          public String index() {
            return "index";
          }
      }

      

    3. 自定义配置SpringBoot web的配置类

    @Configuration
    public class MyConfig implements WebMvcConfigurer {
        /**
         * 浏览器发送addViewTest请求,来到success页面
         * 发请求到页面,就没有必要在Controller里写空方法了,直接来做视图映射
         */
        @Override
        public void addViewControllers(ViewControllerRegistry registry) {
            registry.addViewController("/addViewTest").setViewName("success");
            registry.addViewController("/").setViewName("index");
        }
    }

     即等同于SpringMvc的如下配置

    <mvc:view-controller path="/" view-name="success"/><!-- 配置文件设置页面跳转,发一个请求到页面,就没必要写空方法了,配一下即可 -->

    4. 配置文件类中@Bean注册WebMvcConfigurer对象实例

    @Configuration
    public class MyConfig implements WebMvcConfigurer {
    
        @Bean
        public WebMvcConfigurer webMvcConfigurer() {
            WebMvcConfigurer configurer = new WebMvcConfigurer() {
                @Override
                public void addViewControllers(ViewControllerRegistry registry) {
                    registry.addViewController("/").setViewName("index");
                }
            };
            return configurer;
        }
    
    }

    二、引入BootStrap的webjars取代本地文件


     1.maven依赖

    <dependency>
           <groupId>org.webjars</groupId>
           <artifactId>bootstrap</artifactId>
           <version>4.1.3</version>
    </dependency>

     2. 在yml文件中加入配种:

    server:
      servlet:
        context-path: /crud  //注意,值前面必须带斜杠

    3.在页面源码中加入thymeleaf模板元素

    <!DOCTYPE html>
    <html lang="en" xmlns:th="http://www.thymeleaf.org">
        <head>
            <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
            <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
            <meta name="description" content="">
            <meta name="author" content="">
            <title>Signin Template for Bootstrap</title>
            <!-- Bootstrap core CSS -->
            <!--
                 1.原生的href标签
                     引用值前面不能加斜杠:"/",表示相对路径,以下路径皆可识别
                         1)项目的/resources/static/路径
                         2)webjars的jar包中的/META-INF/resources/ 路径下,
                  2.thymeleaf模板引擎标签
                      2.1 值前面不➕斜杠,效果与原生的href无异,都是取相对路径
                    2.2 值前面➕斜杠,thymeleaf会在斜杠前自动加上系统的根路径
                              即配置文件中:server.servlet.context-path=/crud3 指定的值,不指定则默认为空
             -->
            <link href="webjars/bootstrap/4.1.3/css/bootstrap.css" th:href="@{/webjars/bootstrap/4.1.3/css/bootstrap.css}"  rel="stylesheet">
            <!-- Custom styles for this template -->
            <link href="asserts/css/signin.css" th:href="@{/asserts/css/signin.css}" rel="stylesheet">
        </head>
    
        <body class="text-center">
            <form class="form-signin" action="dashboard.html">
                <img class="mb-4" th:src="@{/asserts/img/bootstrap-solid.svg}" src="asserts/img/bootstrap-solid.svg" alt="" width="72" height="72">
                <h1 class="h3 mb-3 font-weight-normal">Please sign in</h1>
                <label class="sr-only">Username</label>
                <input type="text" class="form-control" placeholder="Username" required="" autofocus="">
                <label class="sr-only">Password</label>
                <input type="password" class="form-control" placeholder="Password" required="">
                <div class="checkbox mb-3">
                    <label>
              <input type="checkbox" value="remember-me"> Remember me
            </label>
                </div>
                <button class="btn btn-lg btn-primary btn-block" type="submit">Sign in</button>
                <p class="mt-5 mb-3 text-muted">© 2017-2018</p>
                <a class="btn btn-sm">中文</a>
                <a class="btn btn-sm">English</a>
            </form>
    
        </body>
    
    </html>

     

  • 相关阅读:
    TF利用分布式队列控制线程
    非随机的抽样
    代码杂谈-split函数
    beta函数与置信度估计
    tensorflow模型
    SQL的技巧
    tensorflow输入数据处理
    flink学习
    Python
    通过淘宝IP地址库获取IP位置
  • 原文地址:https://www.cnblogs.com/guchunchao/p/9933683.html
Copyright © 2011-2022 走看看