zoukankan      html  css  js  c++  java
  • SpringBoot整合系列-整合SpringMVC

    原创作品,可以转载,但是请标注出处地址:https://www.cnblogs.com/V1haoge/p/9984607.html

    SpringBoot整合Spring MVC

    步骤

    第一步:添加必要依赖

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    

    第二步:添加必要的配置

    第三步:添加必要的配置类

    SpringBoot整合SpringMVC没有必需的配置类,只有在想要自定义的时候添加一些实现了WebMvcConfigurer接口的配置类

    @Configuration
    public class WebMvcConfig implements WebMvcConfigurer {
        // 添加针对swagger的处理,避免swagger404
        @Override
        public void addResourceHandlers(ResourceHandlerRegistry registry) {
            registry.addResourceHandler("swagger-ui.html")
                    .addResourceLocations("classpath:/META-INF/resources/");
        }
        //...自定义实现WebMvcConfigurer中的若干默认方法
    }
    

    第四步:整合模板引擎

    整合Freemarker

    第一步:添加必要的依赖
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-freemarker</artifactId>
    </dependency>
    
    第二步:添加必要的设置(重点)
    #Freemarker-config
    # 设置模板前后缀名
    #spring.freemarker.prefix=
    spring.freemarker.suffix=.ftl
    spring.freemarker.enabled=true
    # 设置文档类型
    spring.freemarker.content-type=text/html
    spring.freemarker.request-context-attribute=request
    # 设置ftl文件路径
    spring.freemarker.template-loader-path=classpath:/templates/
    # 设置页面编码格式
    spring.freemarker.charset=UTF-8
    # 设置页面缓存
    spring.freemarker.cache=false
    
    第三步:添加必要的配置类

    第四步:添加控制器和动态页面
    @Controller
    @RequestMapping("base")
    @Log4j2
    @Api(hidden = true)
    public class Base {
        @RequestMapping("/book")
        @ApiOperation(value = "测试",hidden = true)
        public String toBookIndexPage(ModelMap model){
            log.info("进来啦!!!");
            model.put("name","浩哥");
            return "/book/index";
        }
    }
    

    resources/book/index.ftl

    <#assign base = request.contextPath/>
    <!DOCTYPE HTML>
    <HTML>
    <HEAD>
        <TITLE>测试首页</TITLE>
        <base id="base" href="${base}">
        <link rel="stylesheet" href="/webjars/bootstrap/3.3.7-1/css/bootstrap.min.css" />
        <script src="/webjars/jquery/3.1.1/jquery.min.js"></script>
        <script src="/webjars/bootstrap/3.3.7-1/js/bootstrap.min.js"></script>
    </HEAD>
    <BODY>
    ${name}
    <a class="getBook" onclick="dianji()">点击</a><br/>
    <button onclick="dianji()">点击</button>
    </BODY>
    <SCRIPT>
        function dianji() {
            $.ajax({
                url: "/account/g/1",
                type: "GET",
                success: function (data) {
                    alert(data);
                }
            })
        }
        var base = document.getElementById("base").href;
        // 与后台交互
        _send = function(async,url, value, success, error) {
            $.ajax({
                async : async,
                url : base + '/' + url,
                contentType : "application/x-www-form-urlencoded; charset=utf-8",
                data : value,
                dataType : 'json',
                type : 'post',
                success : function(data) {
                    success(data);
                },
                error : function(data) {
                    error(data);
                }
            });
        };
    
    </SCRIPT>
    </HTML>
    

    整合Thymeleaf

    第一步:添加必要的jar包
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-thymeleaf</artifactId>
    </dependency>
    
    第二步:添加必要的配置
    spring.thymeleaf.cache=false
    spring.thymeleaf.encoding=UTF-8
    spring.thymeleaf.enabled=true
    spring.thymeleaf.mode=HTML
    spring.thymeleaf.prefix=classpath:/templates/
    spring.thymeleaf.suffix=.html
    spring.thymeleaf.servlet.content-type=text/html
    

    以上配置中除了第一个之外,其余皆可不配置,上面的值也是默认值,需要修改的时候再进行配置

    第三步:添加必要配置类

    第四步:添加控制器和动态页面
    @Controller
    public class BaseController {
        @RequestMapping("index")
        public String toIndex(ModelMap model){
            model.put("name","首页啊");
            return "index";
        }
    }
    

    resources/index.html

    <!Doctype html>
    <html>
    <head>
        <title>下一页</title>
    </head>
    <body>
    <h1 th:text="${name}">Hello World</h1>
    </body>
    </html>
    

    整合WebJar

    第一步:添加必要的jar包
    <!--导入bootstrap-->
    <dependency>
        <groupId>org.webjars</groupId>
        <artifactId>bootstrap</artifactId>
        <version>3.3.7-1</version>
    </dependency>
    <!--导入Jquery-->
    <dependency>
        <groupId>org.webjars</groupId>
        <artifactId>jquery</artifactId>
        <version>3.1.1</version>
    </dependency>
    
    第二步:使用WebJar开发前端页面
    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Dalaoyang</title>
        <link rel="stylesheet" href="/webjars/bootstrap/3.3.7-1/css/bootstrap.min.css" />
        <script src="/webjars/jquery/3.1.1/jquery.min.js"></script>
        <script src="/webjars/bootstrap/3.3.7-1/js/bootstrap.min.js"></script>
    </head>
    <body>
    <div class="container"><br/>
        <div class="alert alert-success">
            <a href="#" class="close" data-dismiss="alert" aria-label="close">×</a>
            Hello, <strong>Dalaoyang!</strong>
        </div>
    </div>
    </body>
    </html>
    
  • 相关阅读:
    mongodb 安装为windos service
    30分钟搭建一个小型网站框架(python django)
    WAL学习
    postgres读写性能测试(本地、NFS)
    小麦带你看postgres(代码模块结构)
    使用zookeeper实现分布式master选举(c 接口版本)
    Alluxio1.0.1最新版(Tachyon为其前身)介绍,+HDFS分布式环境搭建
    CAF(C++ actor framework)(序列化之复杂类,分析 还有自己不懂的细思恐极函数实现)(三)
    CAF(C++ actor framework)(序列化之类,无需序列化,直接传)(二)
    CAF(C++ actor framework)(序列化之结构体,任意嵌套STL)(一)
  • 原文地址:https://www.cnblogs.com/V1haoge/p/9984607.html
Copyright © 2011-2022 走看看