【SpringBoot】 什么是springboot(二)?springboot操作mybatisPlus、swagger、thymeleaf模板

文章目录

  • SpringBoot
    • 第三章
      • 1、整合mybatsPlus
        • 1-2
        • 3
        • 4-6
        • 7-10
        • 问题
      • 2、整合pageHelper分页
      • 3、MP代码生成器
        • 1、编写yml文件
        • 2、导入依赖
        • 3、创建mp代码生成器
        • 4、生成代码
        • 5、编写配置类扫描mapper类
        • 6、编写控制器类
      • 4、swagger
        • 1、什么是swagger
        • 2、作用
        • 3、发展历程
        • 4、一个简单的swagger项目
    • 第四章
      • 1、swagger
      • 2、thymeleaf
        • 1、使用步骤
        • 2、thymeleaf中的表达式
          • 1、标准变量表达式
          • 2、选择变量表达式
          • 3、路径表达式
        • 3、标签语法
          • 1、th:text
          • 2、th:value
          • 3、th:href
          • 4、th:src
          • 5、th:attr
          • 6、th:each
          • 7、内敛文本
          • 8、内联脚本
          • 9、th:switch
          • 10、th:if
        • 4、thymeleaf中的内置对象
          • 1、日期
          • 2、数值
          • 3、统计
          • 4、作用域
      • 3、综合应用
          • 1-2
          • 3-5
          • 6
          • 7-8
          • 页面两种跳转方式

SpringBoot

第三章

1、springboot操作mybatisPlus
2、mybatisPlus代码生成器
3、swagger
4、thymeleaf

1、整合mybatsPlus

@@@@@@如果使用Mybatis所有操作要自己编写sql语句,自己编写mapper接口中方法,mybatisPlus对Mybatis进行了封装,常见的方法不用自己声明,即可直接使用

使用MybatisPlus后,常见的sql,mapper接口中的方法不需要自己编写了,由MybatisPlus直接提供,这样可以简化开发过程

步骤

1-2
@@@@@@@@在springboot中使用MybatisPlus

1、创建springboot项目

2、导入依赖

	1、web
	2、devtools 热部署
	3、mybatisPlus(需要手动导入)
	4、mysql (默认情况下,系统导入的是mysql 8.0,如果用的其他版本,就需要自己指定版本号)
	5、druid---------------这个依赖选不了,需要手动导入
	6、lombok

	注意:默认导入的mysql的依赖是:
	        <dependency>
		    <groupId>com.mysql</groupId>
		    <artifactId>mysql-connector-j</artifactId>
		    <scope>runtime</scope>
		</dependency>

		需要更改为:

		<dependency>
		    <groupId>mysql</groupId>
		    <artifactId>mysql-connector-java</artifactId>
		    <version>5.1.47</version>
		</dependency>


	导入druid
	<dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.1.16</version>
        </dependency>

	 <!--导入mybatisPlus的依赖-->
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.0.5</version>
        </dependency>

		<dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>3.0.5</version>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>5.1.47</version>
        </dependency>

        <dependency>
            <groupId>com.alibaba</groupId>
            <artifactId>druid-spring-boot-starter</artifactId>
            <version>1.1.16</version>
        </dependency>

        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>

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

        <dependency>
            <groupId>org.apache.velocity</groupId>
            <artifactId>velocity-engine-core</artifactId>
            <version>2.0</version>
        </dependency>
3
3、编写配置文件 application.yml

	#服务器端口号
	server:
	  port: 9999
	#指定数据库连接
	spring:
	  datasource:
	    #使用druid连接池
	    type: com.alibaba.druid.pool.DruidDataSource
	    #数据库驱动
	    driver-class-name: com.mysql.jdbc.Driver
	    #连接地址
	    url: jdbc:mysql:///d113
	    #用户名及密码
	    username: root
	    password: root
	mybatis-plus:
	  #对哪一个包下面的实体类生成别名,默认别名是类名的首字母小写
	  type-aliases-package: org.java.entity
	  #指定mybatis中生成的mapper.xml配置文件的位置
	  mapper-locations: classpath:mapper/*Mapper.xml
	#输出org.java.dao这个包中操作数据库时的底层sql语句
	logging:
	  level:
	    org:
	      java:
		dao: debug
4-6

11

4、编写实体类

	@Data
	@AllArgsConstructor
	@NoArgsConstructor
	@TableName("inf")//如果表名与类名一致,该注解可以省略
	public class Inf implements Serializable {

	    //它表示当前对应的是数据表中的主键,当前id的值是由数据库自动分配
	    @TableId(type = IdType.AUTO)
	    private Integer id;
	    @TableField("name")//描述当前属性与数据表中的哪一个字段有映射关系,如果同名可以省略不写
	    private String name;
	    private Integer score;
	}

5、编写Mapper接口继承于BaseMapper
	@Repository
	public interface InfMapper extends BaseMapper<Inf> {
	}


6、编写配置类扫描Mapper接口

	@Configuration
    @EnableTransactionManagement
	@MapperScan(basePackages = "org.java.dao")
	public class WebConfig {
	}

7-10
7、编写Service接口

8、编写service实现类
		
	@Service
	public class InfServiceImpl implements InfService {

	    @Autowired
	    private InfMapper infMapper;

	    @Override
	    public void add(Inf inf) {
		infMapper.insert(inf);
	    }

	    @Override
	    public List<Inf> getList() {
		return infMapper.selectList(null);
	    }
	}

9、编写控制器类
	@RestController
	public class InfController {
	    @Autowired
	    private InfService infService;
	    
	    @GetMapping("/init")
	    public List<Inf> getList(){
		return infService.getList();
	    }
	    
	    @PostMapping("/add")
	    public void add(Inf inf){
		infService.add(inf);
	    }
	}
10、测试

问题
@@@@@@@问题:如果我们要使用一个方法findByScore,但mybatisplus中没有这个方法,我们可以直接扩展

1、在mapper接口指定方法
	@Repository
	public interface InfMapper extends BaseMapper<Inf> {

	    public List<Inf> findByScore();
	}

2、编写mapper.xml

	<mapper namespace="org.java.dao.InfMapper">
	    <select id="findByScore" parameterType="int" resultType="inf">
		select * from inf where score >=#{score}
	    </select>
	</mapper>


3、在yml文件中配置mybatis的信息
mybatis-plus:
  mapper-locations: classpath:mapper/*Mapper.xml
  type-aliases-package: org.java.entity

2、整合pageHelper分页

@@@@@@@@在springboot使用pageHelper实现分页

1、导入pageHelper依赖

	<dependency>
            <groupId>com.github.pagehelper</groupId>
            <artifactId>pagehelper-spring-boot-starter</artifactId>
            <version>1.2.12</version>
        </dependency>

2、在控制器编写方法接收参数进行分页显示

    @GetMapping("/show/{page}/{rows}")
    public PageInfo<Inf> showPage(@PathVariable("page")  Integer page, @PathVariable("rows")  Integer rows){
        //分页加载数据
        PageInfo<Inf> pg = infService.showPage(page,rows);

        return pg;
    }
 
3、编写InfService类中的方法,实现分页显示

    public PageInfo<Inf> showPage(Integer page, Integer rows) {
        //设置分页的信息
        PageHelper.startPage(page,rows);

        //创建一个queryWrapper对象,用于封装查询条件
        QueryWrapper<Inf> queryWrapper = new QueryWrapper<>();

        //分页查询
        PageInfo<Inf> pageInfo = new PageInfo<>(infMapper.selectList(queryWrapper));

        return pageInfo;
    }

3、MP代码生成器

使用MP代码生成器

作用:在项目中使用MP的代码生成器可以生成通用的:Mapper接口,service接口,service实现类,实体
类,以及项目的基本结构
1、编写yml文件
#服务器端口号
server:
  port: 8099
#指定数据库连接
spring:
  datasource:
    #使用druid连接池
    type: com.alibaba.druid.pool.DruidDataSource
    #数据库驱动
    driver-class-name: com.mysql.jdbc.Driver
    #连接地址
    url: jdbc:mysql:///d118?useUnicode=true&characterEncoding=UTF-8&useSSL=false
    #用户名及密码
    username: root
    password: 123456
mybatis-plus:
  #对哪一个包下面的实体类生成别名,默认别名是类名的首字母小写
  type-aliases-package: org.java.entity
  #指定mybatis中生成的mapper.xml配置文件的位置
  mapper-locations: classpath:mapper/*Mapper.xml
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
#输出org.java.dao这个包中操作数据库时的底层sql语句
#logging:
#  level:
#    org:
#      java:
#        mapper: debug

2、导入依赖
1、web
2、热部署
3、mysql
    <dependency>
        <groupId>mysql</groupId>
        <artifactId>mysql-connector-java</artifactId>
        <version>5.1.47</version>
    </dependency>
4、druid
    <dependency>
        <groupId>com.alibaba</groupId>
        <artifactId>druid-spring-boot-starter</artifactId>
        <version>1.1.16</version>
    </dependency>
5、mybatis-plus
    <dependency>
        <groupId>com.baomidou</groupId>
        <artifactId>mybatis-plus-boot-starter</artifactId>
        <version>3.0.5</version>
    </dependency>
6、velocity--------------------------------生成代码时需要用到
    <dependency>
        <groupId>org.apache.velocity</groupId>
        <artifactId>velocity-engine-core</artifactId>
        <version>2.0</version>
    </dependency>
7、lombok
8、junit
3、创建mp代码生成器
导入生成代码的配置工具类,修改对应的信息,用于生成代码
注意:这个工具类一般放在test目录 
package org.java.test;

import org.junit.Test;
import com.baomidou.mybatisplus.annotation.DbType;
import com.baomidou.mybatisplus.annotation.IdType;
import com.baomidou.mybatisplus.generator.AutoGenerator;
import com.baomidou.mybatisplus.generator.config.DataSourceConfig;
import com.baomidou.mybatisplus.generator.config.GlobalConfig;
import com.baomidou.mybatisplus.generator.config.PackageConfig;
import com.baomidou.mybatisplus.generator.config.StrategyConfig;
import com.baomidou.mybatisplus.generator.config.rules.DateType;
import com.baomidou.mybatisplus.generator.config.rules.NamingStrategy;
/**
 * @author arjun
 * @title: CodeGenerator
 * @description: 描述信息
 * @date 2023.08.27 09:16
 */
public class CodeGenerator {
    @Test
    public void run() {

        // 1、创建代码生成器
        AutoGenerator mpg = new AutoGenerator();

        // 2、全局配置
        GlobalConfig gc = new GlobalConfig();
        String projectPath = System.getProperty("user.dir");
        gc.setOutputDir("F:\\D118SpringBootFile\\item\\sb_MP" + "/src/main/java");

        gc.setAuthor("刘文君");
        gc.setOpen(false); //生成后是否打开资源管理器
        gc.setFileOverride(false); //重新生成时文件是否覆盖

        //UserServie
        // 默认情况下,接口的名称前会有一个字母i,如istuService
        gc.setServiceName("%sService");	//去掉Service接口的首字母I

        gc.setIdType(IdType.AUTO); //主键策略
        gc.setDateType(DateType.ONLY_DATE);//定义生成的实体类中日期类型
        gc.setSwagger2(false);//开启Swagger2模式

        mpg.setGlobalConfig(gc);

        // 3、数据源配置
        DataSourceConfig dsc = new DataSourceConfig();
        dsc.setUrl("jdbc:mysql://localhost:3306/d118?serverTimezone=GMT%2B8");
        dsc.setDriverName("com.mysql.jdbc.Driver");
        dsc.setUsername("root");
        dsc.setPassword("123456");
        dsc.setDbType(DbType.MYSQL);
        mpg.setDataSource(dsc);

        // 4、包配置
        PackageConfig pc = new PackageConfig();
        pc.setModuleName(""); //模块名 可以为空
        //包
        pc.setParent("org.java");
        pc.setController("controller");
        pc.setEntity("entity");
        pc.setService("service");
        pc.setMapper("mapper");
        mpg.setPackageInfo(pc);

        // 5、策略配置
        StrategyConfig strategy = new StrategyConfig();

        strategy.setInclude("stu","studemo");//数据表名 可同时选择多个表(如果注释此行代码,意味着映射数据库中所有的表)
     

        strategy.setNaming(NamingStrategy.underline_to_camel);//数据库表映射到实体的命名策略
        strategy.setTablePrefix(pc.getModuleName() + "_"); //生成实体时去掉表前缀

        strategy.setColumnNaming(NamingStrategy.underline_to_camel);//数据库表字段映射到实体的命名策略
        strategy.setEntityLombokModel(true); // lombok 模型 @Accessors(chain = true) setter链式操作

        strategy.setRestControllerStyle(true); //restful api风格控制器
        strategy.setControllerMappingHyphenStyle(true); //url中驼峰转连字符

        mpg.setStrategy(strategy);

        // 6、执行
        mpg.execute();
    }
}

4、生成代码
@Accessors(chain = true) //支持链式操作 new stu().setID(1)...;

image-20230827104420248

注意要修改的地方:
	1、生成的xml包要重新放到resourses文件下,重命名为mapper
5、编写配置类扫描mapper类
    @Configuration
    @MapperScan(basePackages = "com.qs.mapper")
    public class WebConfig {
    }
6、编写控制器类
    @RestController
    @RequestMapping("/info")
    public class InfoController {
        @Autowired
        private InfoService infoService;

        @GetMapping("/init")
        public List<Info> getList(){
        return infoService.list(null);
        }
    }
通过mybatisPlus生成器生成的代码中,如果没有需要的方法,此时我们可以在service接口以及
Mapper接口中自己声明方法即可

4、swagger

1、什么是swagger
答:Api文档在线自动生成工具
2、作用
根据在代码中使用自定义的注解来生成接口文档,它可以支持在线调试,这个在前后端分离的项目中很重
要。这样做的好处是 在开发接口时可以通过swagger将接口文档定义好,同时也方便以后的维护
3、发展历程
后端时代:前端只用管理静态页面,将整个html交给后端;后端的模板引擎JSP, 后端是主力。



前后端分离时代:
    后端:后端控制层,服务层,数据访问层
    前端:前端控制层,视图层
    前端可以伪造后端的数据,通过json跟后端进行交互。现在已经不需要后端,前端工程依然可以运行起来。
    前后端交互方式:API接口
    前后端相对独立,松耦合
    前后端甚至可以部署到不同的服务器上面

产生的问题

1. 前后端集成联调,前端人员和后端人员无法做到及时协商以便尽快解决问题,最终将导致问题集中
爆发
2. 简单来讲,也就是前端不知道后端将提供给前端的接口名字以及后端将传送给前端的数据以及数据
类型

解决方案

首先应该指定计划,实时更新后端提供给前端的最新API,来降低集成的风险。

1、比如早些年,会指定word计划文档
    前后端分离:
    前端测试后端的接口:postman
    后端提供接口,需要实时更新最新的消息以及改动
    不太方便:这样需要特定去下载安装postman
    
2、Swagger:
	是世界上最流行的API框架
    RestFull Api文档在线自动生成工具==》Api文档与API接口定义同步更新
    直接运行,可以在线测试API接口
    支持多种语言:java、Php
4、一个简单的swagger项目
1、创建springboot项目
2、导入依赖
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
        <scope>runtime</scope>
        <optional>true</optional>
    </dependency>
    <dependency>
        <groupId>org.projectlombok</groupId>
        <artifactId>lombok</artifactId>
        <optional>true</optional>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-tomcat</artifactId>
        <scope>provided</scope>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
    </dependency>

	swqgger主要的4个依赖
	<dependency>
        <groupId>io.springfox</groupId>
        <artifactId>springfox-swagger2</artifactId>
        <version>2.9.2</version>
    </dependency>
    <dependency>
        <groupId>io.springfox</groupId>
        <artifactId>springfox-swagger-ui</artifactId>
        <version>2.9.2</version>
    </dependency>
    <dependency>
        <groupId>io.swagger</groupId>
        <artifactId>swagger-annotations</artifactId>
        <version>1.5.22</version>
    </dependency>
    <dependency>
        <groupId>io.swagger</groupId>
        <artifactId>swagger-models</artifactId>
        <version>1.5.22</version>
    </dependency>

步骤太多了。。还是直接看pdf吧

文件查看地址

第四章

1、swagger的使用
2、thymeleaf的使用
@Api(tags="用于描述当前类的信息")--放在控制类上
    
@ApiOperration(value="基本描述信息",notes="详情描述信息")--放在方法上
    
@ApiParam(value = "学生编号id",required = true)--放在参数里面
    
@ApiResponses({
            @ApiResponse(code = 200,message = "删除成功!"),
            @ApiResponse(code = 204,message = "服务器成功处理了请求,但没返回任何内容!"),
            @ApiResponse(code = 400,message = "参数无效!"),
            @ApiResponse(code = 401,message = "用户未授权!"),
            @ApiResponse(code = 403,message = "服务器拒绝请求!"),
            @ApiResponse(code = 404,message = "请求的资源不存在!"),
    })-----自定义服务器状态 放在方法上
    
@ApiImplicitParams({
            @ApiImplicitParam(name = "id", value = "学生编号id", required = true,paramType = "query"),
            @ApiImplicitParam(name = "name", value = "学生姓名", required = true, paramType = "query"),
            @ApiImplicitParam(name = "score", value = "学生成绩", required = true, paramType = "query"),
    })---多个参数的设置,放在方法上
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
 /*************************实体类*************************/
    
    
@ApiModel("学生实体类")--放在实体类上
    
@ApiModelProperty(value = "学生编号(主键)", required = false,notes = "编号可以为空,为空则由数据库自动分配")--放在属性上
    

控制器类上的注解

@RestController---返回josn数据类型
    
@Slf4j------------输出日志
    
@RequestMapping("/studemo")---请求路径
    
@Api(tags = "studemo的控制器类")---控制器类的描述信息

webconfig配置类

package com.java.config;

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.transaction.annotation.EnableTransactionManagement;
import org.springframework.web.bind.annotation.RestController;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.service.VendorExtension;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

import java.util.ArrayList;

/**
 * @author arjun
 * @title: webConfig
 * @description: 描述信息
 * @date 2023.08.27 11:45
 */
@Configuration
@MapperScan(basePackages = "com.java.mapper")
@EnableSwagger2
@EnableTransactionManagement
public class webConfig {


    //自定义设置swagger文档描述信息
    @Bean
    public Docket docket01() {
        //docket--一个docket就是一个swagger标签,用于描述swagger的信息
       Docket docket=new Docket(DocumentationType.SWAGGER_2).apiInfo(apiInfo()).groupName("1、扫描所有控制器类");
       return docket;
    }

    @Bean
    public Docket docket02() {
        //docket--一个docket就是一个swagger标签,用于描述swagger的信息
        Docket docket=new Docket(DocumentationType.SWAGGER_2)
                .apiInfo(apiInfo())
                .select()
                //设置条件
//                .paths(PathSelectors.ant("/user/**"))// 1、仅对user开头的请求,生成接口文档
                .apis(RequestHandlerSelectors.basePackage("com.java.controller"))// 2、只对这个包下面的控制器生成接口文档
                .build()
                .groupName("2、扫描自定义的控制器类");
        return docket;
    }

    //返回swagger的具体描述信息
    public static final Contact DEFAULT_CONTACT = new Contact("arjun", "https://arjunna.gitee.io", "arjunna@163.com");
    public ApiInfo apiInfo() {
        ApiInfo apiInfo=new ApiInfo("swagger的Api文档",
                                    "所有接口的描述信息及使用方法",
                                    "1.0",
                                    "urn:tos",
                                    DEFAULT_CONTACT,
                                    "Apache 2.0",
                                    "http://www.apache.org/licenses/LICENSE-2.0",
                                     new ArrayList<VendorExtension>());
        return apiInfo;
    }
}

1、swagger

看pdf就行

帮助文档:PDF地址

2、thymeleaf

在springboot中可以用jsp作为视图,呈现数据。但是,并不推荐

springboot中推荐使用“模板引擎”作为视图呈现数据

	开发中常用的模板引擎:

		1、thymeleaf-----------百里香叶

		2、freemaker

		3、velocity

更多的是使用thymeleaf作为springboot的视图组件,呈现数据

image-20230828161742415

1、使用步骤
1、创建工程
2、导入依赖
	1、web
    2、热部署
    3、lombok
    4、thymeleaf
3、配置yml文件
server:
    port: 9999
spring:
    thymeleaf:
    enabled: true #启用thymeleaf
    encoding: utf-8 #编码
    cache: false #页面不缓存数据
    suffix: .html #模板页面的后缀名
    mode: HTML #模板页面是以html为基础
4、编写第一个模板页面 index.html
	
    要求:模板页必须放在templates目录中
    
    如果名称叫作: index.html,则该页面会自动加载
    
    如果在页面使用thymeleaf标签,需要导入下列指令
    <html lang="en" xmlns:th="http://www.thymeleaf.org">
5、编写控制器类
	用于加载数据,然后在init.html页面显示此处的语法,与springmvc语法一致
	
	@Controller
    public class InfoController {
    
        @GetMapping("/")
        public String init(Model model){
            //将数据存放在Model中(等同于request),在页面中显示数据
            model.addAttribute("msg","hello123");
            Info info = new Info(1,"bruce",99);
            model.addAttribute("info",info);
            return "/init";
            
        }
    }
6、在init.html页面,准备在页面中取到存储数据

	结果是: ${msg}----------- EL表达式取不值,它会原样显示

	原因是:thymeleaf页面中,不能直接使用EL表达式取值,thymeleaf它有自己的表达式

	在页面中引入th指令:
    <html lang="en" xmlns:th="http://www.thymeleaf.org">
    thymeleaf的表达式不能直接使用,只有在给html标签的属性赋值时才能使用

    <div th:属性=“${表达式}”>
    </div>
2、thymeleaf中的表达式

在thymeleaf页面中使用thymeleaf标签的基本步骤:

1、导入标签指令
	<html xmlns:th="http://www.thymeleaf.org">

2、使用thymeleaf表达式动态取值
	
	要求:thymeleaf的表达式不能直接使用,必须作为标签的属性来使用

	表达式的分类:
		
		1、标准变量表达式
	
		2、选择变量表达式

		3、路径表达式

1、标准变量表达式
@@@@@标准变量表达式   ${xxx}  ${xxx.属性}   ${xxx.xx()}


	作用:用于从作用域取值,显示在当前位置中

		<标签 th:text="${xxxx}">静态内容</标签>

	例如:  <span th:text="${msg}">消息</span>


	如果在容器中运行:那么就会显示${msg}的内容
	如果在非容器中显示,就只会显示 消息 两个字
2、选择变量表达式
@@@@@@选择变量表达式 *{xxx}  *{xxx.属性}   *{xxx.xx()}

	作用:用于从作用域取值,显示在当前位置中

		<标签 th:text="*{xxxx}">静态内容</标签>

	例如:  <span th:text="*{msg}">消息</span>
3、路径表达式
作用:一般在路径中动态取值时使用

语法: @{xxx} @{xxx.xxx} @{xxx.xxx()}
方式1: <a href="del/12345">删除数据1</a>

    href这种方式传递参数,只能传递固定参数,如果要动态取值向后传递,必须使用th:href
    @@@@@注意:在thymeleaf中,只有th开头的标签属性才允许动态取值
方式2: <a th:href="'del/'+${info.id}">删除数据2</a><Br>

    如果要使用th属性动态传递,静态内容要与动态内容分开,静态内容必须包含在‘’中
    这种方式的缺点:如果参数多了,这种写法很容易出错
方式3: <a th:href="@{|del/${info.id}|}">删除数据3</a><Br>
    通过路径表达式动态取值

 简化写法:以上代码可以进行简化 @{}可以省略不写
    <a th:href="|del/${info.id}|">删除数据4</a><Br>

显示图片

    <img src="/imgs/4.jpg">
    这种方式只能显示固定路径的图片
    <img th:src="'/imgs/'+${photo}">
    <img th:src="@{|/imgs/${photo}|}">
    <img th:src="|/imgs/${photo}|">
3、标签语法
1、th:text
th:text
    该标签属性,用于动态取值显示在当前位置
    <div th:text="${msg}"></div>
2、th:value
th:value
    该标签属性,用于动态取值显示在表单组件中,用于进行数据回显
    编号:<input type="text" th:value="${info.id}"><Br>
    姓名:<input type="text" th:value="${info.name}"><Br>
    成绩:<input type="text" th:value="${info.score}"><Br>
注意:有时候修改与新增共享同一个表单组件
    区别是:
    新增时表单数据为空,没有默认数据
    修改时,表单中是有默认数据的
    
    编号:<input type="text" th:value="${stu?.id}"><Br>
    姓名:<input type="text" th:value="${stu?.name}"><Br>
    成绩:<input type="text" th:value="${stu?.score}"><Br>
    
    ?表示,如果stu对象存在,就执行后面的取值操作。如果不存在就不执行

3、th:href
作用:设置超连接路径,并且允许在连接路径中动态取值

    <a th:href="'del/'+${info.id}">删除数据2</a><
    <a th:href="@{|del/${info.id}|}">删除数据3</a>
    <a th:href="|del/${info.id}|">删除数据3</a>(推荐使用)
4、th:src
作用:设置路径,允许在路径中动态取值

    <img th:src="'/imgs/'+${photo}">
    <img th:src="@{|/imgs/${photo}|}">
    <img th:src="|/imgs/${photo}|">
5、th:attr
作用:用于给标签的属性动态赋值

    <input type="text" th:attr="value='jack'"><Br>
    性别:<input type="radio" value="" name="gender"
    th:attr="checked=${gender=='男'}"><input type="radio" value="" name="gender"
    th:attr="checked=${gender=='女'}">
6、th:each
作用:用于对集合遍历,相当于C标签中的forEach

    <c:forEach items="${list}" var="info" varStatus="st">
    
        st:它用于保存当前对象在集合的状态
            ${st.index}---------获得当前对象在集合中的下标 0
            ${st.count}---------获得当前对象在集合中的个数 1
            ${st.first}---------判断当前对象是否是集合中的第1个对象
            ${st.last}---------获得当前对象是否是集合中的最后1个对象
        
    <tr th:each="info,st:${list}">
        <Td th:text="${info.id}"></Td>
        <Td th:text="${info.name}"></Td>
        <Td th:text="${info.score}"></Td>
        <td th:text="${st.index}"></td>
        <td th:text="${st.count}"></td>
        <td th:text="${st.first}"></td>
        <td th:text="${st.last}"></td>
    </tr>
:list--------它表示对哪一个集合遍历
    info---------它表示从集合中取到的第一个对象
    st-----------它用于保存当前对象在集合的状态
    
        ${st.index}---------获得当前对象在集合中的下标 0
        ${st.count}---------获得当前对象在集合中的个数 1
        ${st.first}---------判断当前对象是否是集合中的第1个对象
        ${st.last}---------获得当前对象是否是集合中的最后1个对象
隐藏状态:
	    <tr th:each="info:${list}">
        <Td th:text="${info.id}"></Td>
        <Td th:text="${info.name}"></Td>
        <Td th:text="${info.score}"></Td>
        <td th:text="${infoStat.index}"></td>
        <td th:text="${infoStat.count}"></td>
        <td th:text="${infoStat.first}"></td>
        <td th:text="${infoStat.last}"></td>
    </tr>
    
   使用:在对象info后面加上Stat,则可以触发隐藏状态
7、内敛文本
    作用:直接在页面中用表达取值
        语法:
        [[${msg}]] [[${info.name}]] [[${info.getScore()}]]
    
    msg:[[${msg}]]<Br>
    编号:[[${info.id}]]<Br>
    姓名:[[${info.name}]]<Br>
    成绩:[[${info.getScore()}]]<Br>

8、内联脚本
作用:用于在Js代码中,通过表达式直接取值

    <script th:inline="javascript">
    var msg = [[${msg}]];
    </script>

9、th:switch
作用:根据条件显示不同的结果,类似于java中的switch

    <div th:switch="${mylevel}">
    <div th:case="1">一级用户</div>
    <div th:case="2">二级用户</div>
    <div th:case="3">三级用户</div>
    </div>
10、th:if
作用:用于进行逻辑判断
    <span>
        <b th:if="${info.score>=60}" style="color: green">合格</b>
        <b th:if="${info.score<60}" style="color: red">不合格</b>
    </span>
    <Td>
        <b th:if="${info.score>=90}" style="color:green">优秀</b>
        <b th:if="${info.score>=80 && info.score<90}"
        style="color:blue">良好</b>
        <b th:if="${info.score>=60 && info.score<80}"
        style="color:gray">合格</b>
        <b th:if="${info.score<60}" style="color:red">不合格</b>
    </Td>

4、thymeleaf中的内置对象
1、日期
1、与日期相关的内置对象 #dates

${#dates.format(属性名,'yyyy-MM-dd')}
作用:按指定格式显示数据

出生日期:<b th:text="${#dates.format(bir,'yyyy-MM-dd')}"></b><Br>
出生日期2:<input type="date" th:value="${#dates.format(bir,'yyyy-MMdd')}"></input>
2、数值
2、与数值相关的内置对象 #numbers

账户余额:<B th:text="${#numbers.formatCurrency(balance)}"></B>
将当前数值,转换成货币格式显示

${#numbers.sequence(1,120)}
    从1开始到120结束,产生一个序列
    <select onchange="alert(this.value)">
    <option value="-1">请选择年龄</option>
    <option th:value="${age}" th:each="age:${#numbers.sequence(1,120)}">
    [[${age}]]岁</option>
    </select>

    <select onchange="alert(this.value)">
    <option value="-1">请选择年龄</option>
    <option th:attr="selected=${age==myAge}"
    th:value="${age}"
    th:each="age:${#numbers.sequence(1,120)}">[[${age}]]岁</option>
</select>

3、统计
3、与统计相关的内置对象

${#aggregates.sum[集合.![属性名]}
作用:用于对集合遍历,得到集合中的对象的某一个属性值相加的总和

例如:统计购物车的应付总金额
list集合中,所有学生的总分数为: <B th:text="${#aggregates.sum(list.!
[score])}"></B>
4、作用域
4、作用域相关的一组对象:
		${xxxx}--------------------它是从request范围中取值
        ${session.xxxx}------------它是从session范围中取值
        ${application.xxxx}-------它是从application范围中取值

    请求:<b th:text="${message}"></b> <Br>
    会话:<b th:text="${session.message}"></b> <Br>
    全局上下文:<b th:text="${application.message}"></b> <Br>
        
  /**/另外一种写法:
      请求:       <b th:text="${#request.getAttribute('msg2')}"></b>
      会话:       <b th:text="${#session.getAttribute('msg2')}"></b>
      上下文:     <b th:text="${#servletContext.getAttribute('msg2')}"></b>
        

3、综合应用

1-2
1、创建工程
2、导入依赖
        1、web
        2、热部署
        3、mysql
        4、mybatis-plus(3.0.5)
        5、velocity(用于生成代码)
        6、thymeleaf
        7、druid
        8、lombok
        9、pagehable
        

依赖

  <parent>
    <artifactId>spring-boot-starter-parent</artifactId>
    <groupId>org.springframework.boot</groupId>
    <version>2.3.12.RELEASE</version>
  </parent>

  <dependencies>
    <dependency>
      <groupId>junit</groupId>
      <artifactId>junit</artifactId>
      <version>4.11</version>
      <scope>test</scope>
    </dependency>
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <dependency>
      <groupId>com.baomidou</groupId>
      <artifactId>mybatis-plus-boot-starter</artifactId>
      <version>3.0.5</version>
    </dependency>

    <dependency>
      <groupId>com.github.pagehelper</groupId>
      <artifactId>pagehelper-spring-boot-starter</artifactId>
      <version>1.2.12</version>
    </dependency>
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-thymeleaf</artifactId>
    </dependency>
    <dependency>
      <groupId>mysql</groupId>
      <artifactId>mysql-connector-java</artifactId>
      <version>5.1.47</version>
    </dependency>

    <dependency>
      <groupId>com.alibaba</groupId>
      <artifactId>druid-spring-boot-starter</artifactId>
      <version>1.1.16</version>
    </dependency>

    <dependency>
      <groupId>org.projectlombok</groupId>
      <artifactId>lombok</artifactId>
    </dependency>

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

    <dependency>
      <groupId>org.apache.velocity</groupId>
      <artifactId>velocity-engine-core</artifactId>
      <version>2.0</version>
    </dependency>


    <dependency>
      <groupId>io.springfox</groupId>
      <artifactId>springfox-swagger2</artifactId>
      <version>2.9.2</version>
    </dependency>
    <dependency>
      <groupId>io.springfox</groupId>
      <artifactId>springfox-swagger-ui</artifactId>
      <version>2.9.2</version>
    </dependency>
    <dependency>
      <groupId>io.swagger</groupId>
      <artifactId>swagger-annotations</artifactId>
      <version>1.5.22</version>
    </dependency>
    <dependency>
      <groupId>io.swagger</groupId>
      <artifactId>swagger-models</artifactId>
      <version>1.5.22</version>
    </dependency>
  </dependencies>
3-5
3、导入代码生成的工具类

4、生成代码

5、编写yml文件
6
6、编写配置类

	@Configuration
    @MapperScan(basePackages = "com.qs.mapper")
    public class WebConfig {
    }
7-8
7、控制器类

8、问题处理

	注意:thymeleaf的超连接不能直接跳转页面
	<A href="add.html">添加</A> -----------错误写法
	
页面两种跳转方式
方式1:编写配置类实现配置跳转

	@Configuration
    @MapperScan(basePackages = "com.qs.mapper")
    public class WebConfig implements WebMvcConfigurer {
        @Override
        public void addViewControllers(ViewControllerRegistry registry) {
        //配置视图的跳转,指定发出什么请求,跳转到哪个页面
        registry.addViewController("/add").setViewName("add");
        }
    }
方式2:编写一个控制器类专门处理跳转

	@Controller
    public class ForwardController {
        @GetMapping("/forward/{page}")
        public String forward(@PathVariable String page){
        return "/"+page;
        }
    }

注意:在提交表单数据时,如果有日期类型的数据,需要在实体类中日期类型的属性上加上如下注解

@DateTimeFormat(pattern = "yyyy-MM-dd")
private Date bir;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/620185.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Hexo博客重新部署与Git配置

由于电脑重装了一次&#xff0c;发现之前Hexo与NexT主题版本过于落后&#xff0c;重新部署了下。 1 Node.js与git安装 这一块安装就不赘述了。去两个官网找安装文件安装即可。 node.js git 打开git以后配置的几个关键命令行。 git config --global user.name "你的gi…

ArcGIS水文水环境数据编辑、管理、处理与分析;ArcGIS水文分析及流域特征提取;湖泊水库水环境监测及评价;河道水污染预测与水环境容量计算等案例实践

目录 专题一 ArcGIS&#xff1a;数据管理 专题二 ArcGIS&#xff1a;数据转换 专题三 ArcGIS&#xff1a;地图制作 专题四 水文水环境数据编辑与管理 专题五 水文水环境数据处理与分析 专题六 ArcGIS水文分析及流域特征提取 专题七 湖泊水库水环境监测及评价 专题八 河…

java学习之zip炸弹攻击

一、概述 Zip炸弹是一种特殊类型的Zip文件&#xff0c;它包含了大量的无用数据。Zip文件格式允许使用压缩算法来减小文件的大小&#xff0c;但是如果Zip文件中的某些内容被重复压缩&#xff0c;就会导致文件大小急剧增加。Zip炸弹利用这个特性&#xff0c;将一些无用的数据多次…

配置接口的主从IP地址

组网需求 如图1所示&#xff0c;Router上只有一个空闲接口GE1/0/0&#xff0c;但该局域网中的计算机分别属于2个不同的网段10.16.1.0/24和10.16.2.0/24&#xff0c;要求通过Router可以实现一个接口接入两个不同的网段。 图1 配置IP地址示例 配置思路 配置主从IP地址的思路…

【C++】STL-list的使用

目录 1、list的使用 1.1 list的构造 1.2 list的遍历 1.3 list capacity 1.4 list element access 1.5 容量相关 list是一个带头双向循环链表 1、list的使用 1.1 list的构造 1.2 list的遍历 list只有两种遍历方式&#xff0c;因为没有operator[] 因为list的双向链表&am…

Docker复习

文章目录 基础Docker基础命令镜像操作命令容器操作命令 案例:安装MySql案例:查看DockerHub&#xff0c;拉取Nginx镜像&#xff0c;并运行容器 基础 Docker基础命令 启动Docker systemctl start docker镜像操作命令 从远程仓具下载镜像到本地 docker pull 镜像名称 无版本号…

高并发系统设计-系统的“三高“目标

目录 一、高并发 1.高并发相关指标 2.如何提高并发能力 二、高并发的目标 1.高性能 2.高可用 3.高扩展 一、高并发 高并发&#xff08;High Concurrency&#xff09;是互联网分布式系统架构设计中必须考虑的因素之一&#xff0c;它通常是指&#xff0c;通过设计保证系统能…

parallelsdesktop19密钥激活 PD19虚拟机完整图文安装教程

Parallels Desktop 19 &#xff08;简称 PD 19)是最新发布的 macOS 平台的 windows 虚拟机&#xff0c;本文是使用 Parallels Desktop 19 虚拟机安装 Windows 的详细图文破解安装教程。 一下载安装 Parallels Desktop 软件下载完成后打开&#xff0c;双击打开 安装.dmg Para…

1070: 邻接矩阵存储简单路径

解法&#xff1a; #include<iostream> #include<vector> using namespace std; int arr[100][100]; int n; int sta, des; vector<int> path; vector<vector<int>> res; void dfs(vector<int> &a,int i) {a[i] 1;path.push_back(i);…

【漏洞复现】osCommerce install.php存在远程代码执行漏洞

免责声明&#xff1a;文章来源互联网收集整理&#xff0c;请勿利用文章内的相关技术从事非法测试&#xff0c;由于传播、利用此文所提供的信息或者工具而造成的任何直接或者间接的后果及损失&#xff0c;均由使用者本人负责&#xff0c;所产生的一切不良后果与文章作者无关。该…

第5章 处理GET请求参数

1 什么是GET请求参数 表单GET请求参数是指在HTML表单中通过GET方法提交表单数据时所附带的参数信息。在HTML表单中&#xff0c;可以通过表单元素的name属性来指定表单字段的名称&#xff0c;通过表单元素的value属性来指定表单字段的值。当用户提交表单时&#xff0c;浏览器会将…

C# WinForm —— 16 MonthCalendar 介绍

1. 简介 可以选择单个日期&#xff0c;也可以选择一段日期&#xff0c;在选择时间范围上 比较适用&#xff0c;但不能跨月份选择日期范围 在直观上&#xff0c;可以快速查看、选择日期/日期范围 2. 常用属性 属性解释(Name)控件ID&#xff0c;在代码里引用的时候会用到,一般…

邮箱API发送邮件调试的方法?有哪些限制?

邮箱API发送邮件调试的好处&#xff1f;如何正确调试邮箱API&#xff1f; 使用邮箱API发送邮件是一个常见的需求。然而&#xff0c;当遇到发送失败、内容错误或格式问题时&#xff0c;如何进行有效的调试就显得尤为重要。本文将为您介绍一些邮箱API发送邮件调试的方法&#xf…

Leetcode-有效的括号

20. 有效的括号 - 力扣&#xff08;LeetCode&#xff09;https://leetcode.cn/problems/valid-parentheses/ 题目 给定一个只包括 (&#xff0c;)&#xff0c;{&#xff0c;}&#xff0c;[&#xff0c;] 的字符串 s &#xff0c;判断字符串是否有效。 有效字符串需满足&…

MySql软件安装

1.打开mysql官网网址 MySQL :: Download MySQL Community Server 2.本次针对版本8的图形化界面安装&#xff0c;下载成功后接下来对MySQL进行安装 3.图形化下载后有一个MSI文件 4.我们安装典型即可&#xff0c;选择第一个 5.选择数据库信息存放的路径&#xff0c;我默认放在C盘…

Redis继续(黑马)

Redis持久化 RDB与AOF RDB记录是二进制数据&#xff0c;Redis停机时会触发保存&#xff0c;名称&#xff1a; dump.rdb 缺点&#xff1a;间歇式复制可能存在宕机数据更新丢失 AOF 记录的写操作命令&#xff0c;每秒记录一下&#xff0c;也存在数据更新丢失的可能&#xff0c;相…

【数轮】数论、质数、最大公约数、菲蜀定理

数学 唯一分解定理 n>2都可以表示为质因数的乘方。 令 n a1b1a2b2 … \dots … a1,b1 … \dots …都是质因数&#xff0c;b1,b2 … \dots …是对应质因数的数量。 调和级数 11/2 1/3 1/4 ⋯ \cdots ⋯ 1/ n 约等于 logn。 证明过程&#xff1a; 1/3 1/4 < (1/2) …

idea已配置的git仓库地址 更换新的Git仓库地址 教程

文章目录 目录 文章目录 更改流程 小结 概要更改流程技术细节小结 概要 先在idea控制台走一下流程 先将本地的git仓库删除 1. 查看当前远程仓库地址&#xff1a; 在终端或命令行中&#xff0c;导航到你的项目目录&#xff0c;并运行以下命令查看当前的远程仓库地址&#xff…

CTF之love_math

这个题目简单看一下就知道要传参进行执行系统命令以达到找到flag的目的。 但是又可以发现过滤了很多东西。 这个题的绕过方法可以用到三个函数 base_convert(number,froombase,tobase)//分别为原始值&#xff0c;原来进制&#xff0c;要转换的进制dechex("十进制数"…

气膜建筑电源配置是怎样的—轻空间

在气膜建筑中&#xff0c;电源配置是确保建筑控制系统连续运行的重要组成部分。以下是该建筑的电源配置方案&#xff1a; 1. 市电供电与备用发电机&#xff1a; 为了应对市电中断等突发情况&#xff0c;系统采用市电供电与备用柴油发电机双重供电方式。这种配置保证了即使在市电…