• springboot+thymeleaf+mybatis 基础学习


    秉承有输入就要有输出的学习态度,编写博客记录。毕竟好的记忆是需要反复练习的。

    springboot + thymeleaf + myBatis 

    springboot 创建项目。

    可视化界面操作  :  File --New priject --> Spring Initializr --> 选择依赖(web/thymeleaf/mybatis)  创建成功

    官网一键操作 : 进入 spring 官网 下的 快速创建项目  纯净版

    解压出来后,用Interllij idea打开文件夹。删除几个没作用的文件,简化页面。目录结构如下

       

    src/main/java:主程序入口 Application,可以通过直接运行该类来 启动 Spring Boot应用
    src/main/resources:配置目录,该目录用来存放应用的一些配置信息,比如应用名、服务端口、数据库配置等。由于我们应用了Web模块,因此产生了 static目录与templates目录,前者用于存放静态资源,如图片、CSS、JavaScript等;后者用于存放Web页面的模板文件。
    src/test:单元测试目录,生成的 ApplicationTests 通过 JUnit4实现,可以直接用运行 Spring Boot应用的测试。
    application.properties/application.yml 用于存放程序的各种依赖模块的配置信息,比如 服务端口,数据库连接配置等。。。

    1)代码层的结构

      根目录:com.springboot.demo

        1.工程启动类(Application.java)

        2.实体类(domain)置于com.springboot.domain

        3.数据访问层(Dao)置于com.springboot.repository

        4.数据传输类(vo)置于com.springboot.vo

        5.前端控制器(Controller)置于com.springboot.controller

        6.工具类(utils)置于com.springboot.utils

        7.配置信息类(config)置于com.springboot.config

        8.数据服务层(Service)置于com,springboot.service,数据服务的实现接口(serviceImpl)至于com.springboot.service.impl

    (2)资源文件的结构

      根目录:src/main/resources

        1.配置文件(.properties/.xml等) 置于 根目录文件夹下

        2.html 页面文件存放在templates 文件夹下

        3.页面以及js/css/image等置于static文件夹下的各自文件下

        4.Mapper 映射文件,自定义sql 语句服务的实现接口(mapperImpl)至于impl 。

    其中的 application.properties 配置文件中: 

    server.port= 8080
    
    spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
    spring.datasource.druid.type=com.alibaba.druid.pool.DruidDataSource
    spring.datasource.druid.url=jdbc:mysql://0.0.0.0:3306/book_test?useUnicode=true&characterEncoding=utf-8
    spring.datasource.druid.username=root
    spring.datasource.druid.password=123456
    spring.datasource.druid.max-active=20
    spring.datasource.druid.max-wait=10000
    spring.datasource.druid.initial-size=8
    
    # 上传文件总的最大值
    spring.servlet.multipart.max-request-size=10MB
    # 单个文件的最大值
    spring.servlet.multipart.max-file-size=10MB
    
    ## jsp
    #spring.mvc.view.prefix=/WEB-INF/jsp/
    #spring.mvc.view.suffix=.jsp
    
    # thymeleaf 模板配置
    spring.thymeleaf.prefix=classpath:/templates/
    spring.thymeleaf.suffix=.html
    spring.thymeleaf.mode=HTML5
    spring.thymeleaf.encoding=UTF-8
    spring.thymeleaf.servlet.content-type=text/html
    
    #热部署文件,页面不产生缓存,及时更新
    spring.thymeleaf.cache=false
    spring.resources.chain.strategy.content.enabled=true
    spring.resources.chain.strategy.content.paths=/**
    
    # mybatis 标注SQL映射文件位置
    mybatis.mapper-locations=classpath:mapper/**/*.xml
    mybatis.type-aliases-package=com.example.demo.entity
    #mybatis.config-location=classpath:mybatis.xml
    mybatis.config-location=classpath:mybatis-config.xml
    View Code

    Mybatis 生成 

    generatorConfig.xml  配置映射文件的路径地址+映射数据库实体名(图中是逆向生成的插件,在文件中配置好映射的文件位置,点击生成)

    log4j2.xml (日志配置文件),mybatus-config.xml (mybatis 分页)  

    配置文件 pom.xml 的配置

    <?xml version="1.0" encoding="UTF-8"?>
    <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
        <modelVersion>4.0.0</modelVersion>
        <parent>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-parent</artifactId>
            <version>2.1.7.RELEASE</version>
            <relativePath/> <!-- lookup parent from repository -->
        </parent>
    
        <groupId>com.example</groupId>
        <artifactId>demo</artifactId>
        <version>0.0.1-SNAPSHOT</version>
        <name>demo</name>
        <description>Demo project for Spring Boot</description>
    
        <properties>
            <java.version>1.8</java.version>
        </properties>
    
        <dependencies>
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-web</artifactId>
            </dependency>
    
            <!-- jsp -->
            <!--<dependency>-->
            <!--<groupId>javax.servlet</groupId>-->
            <!--<artifactId>jstl</artifactId>-->
            <!--</dependency>-->
            <!--<dependency>-->
            <!--<groupId>org.apache.tomcat.embed</groupId>-->
            <!--<artifactId>tomcat-embed-jasper</artifactId>-->
            <!--&lt;!&ndash;<scope>provided</scope>&ndash;&gt;-->
            <!--</dependency>-->
    
            <!--<dependency>-->
                <!--<groupId>org.springframework.boot</groupId>-->
                <!--<artifactId>spring-boot-starter-test</artifactId>-->
                <!--<scope>test</scope>-->
                <!--<exclusions>-->
                    <!--<exclusion>-->
                        <!--<groupId>org.springframework.boot</groupId>-->
                        <!--<artifactId>spring-boot-starter-logging</artifactId>-->
                    <!--</exclusion>-->
                <!--</exclusions>-->
            <!--</dependency>-->
    
            <dependency>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-starter-thymeleaf</artifactId>
                <version>2.1.4.RELEASE</version>
            </dependency>
    
    
            <dependency>
                <groupId>org.mybatis.spring.boot</groupId>
                <artifactId>mybatis-spring-boot-starter</artifactId>
                <version>2.1.1</version>
            </dependency>
    
            <dependency>
                <groupId>mysql</groupId>
                <artifactId>mysql-connector-java</artifactId>
                <!--<scope>8.0.12</scope>-->
            </dependency>
    
            <!-- druid  阿里的数据库连接池-->
            <dependency>
                <groupId>com.alibaba</groupId>
                <artifactId>druid-spring-boot-starter</artifactId>
                <version>1.1.10</version>
            </dependency>
            <!-- druid -->
    
            <dependency>
                <groupId>com.github.pagehelper</groupId>
                <artifactId>pagehelper-spring-boot-starter</artifactId>
                <version>1.2.12</version>
            </dependency>
    
        </dependencies>
    
        <build>
            <plugins>
                <plugin>
                    <groupId>org.springframework.boot</groupId>
                    <artifactId>spring-boot-maven-plugin</artifactId>
                </plugin>
    
                <!-- mybatis 逆向工程插件 -->
                <plugin>
                    <groupId>org.mybatis.generator</groupId>
                    <artifactId>mybatis-generator-maven-plugin</artifactId>
                    <version>1.3.2</version>
                    <configuration>
                        <!--自动生成的配置-->
                        <configurationFile>
                            ${project.basedir}/src/main/resources/generatorConfig.xml
                        </configurationFile>
                        <!--是否覆盖-->
                        <overwrite>true</overwrite>
                        <!--允许移动生成的文件-->
                        <verbose>true</verbose>
                    </configuration>
                    <dependencies>
                        <!-- https://mvnrepository.com/artifact/mysql/mysql-connector-java -->
                        <dependency>
                            <groupId>mysql</groupId>
                            <artifactId>mysql-connector-java</artifactId>
                            <version>5.1.30</version>
                        </dependency>
                    </dependencies>
                </plugin>
            </plugins>
    
        </build>
    
    </project>
    View Code

    在pom.xml 中的 阿里云中的 druid 数据库连接池 依赖 ,还有mybatis 逆向生成插件依赖 需要多注意。

    spring-boot-starter-parent 父依赖 自带适配的插件依赖版本,不需要额外的配置插件版本。查看方法,按住Ctrl +鼠标点击 

     

    实例地址传送门

  • 相关阅读:
    No result defined for action
    敏捷管理视频
    如何预测一个互联网产品的未来:一套关于产品的数学模型
    ZooKeeper 笔记(3) 实战应用之【统一配置管理】
    mybatis migrate常用指令
    dubbo远程调试运行
    解决 nginx https反向代理http协议 302重定向localtion到http问题
    nginx设置不使用缓存 add_header Cache-Control no-cache
    openssl数字证书私钥删除私钥密码
    读 Zepto 源码系列
  • 原文地址:https://www.cnblogs.com/zhangrh/p/14281361.html
Copyright © 2020-2023  润新知