springboot +thymeleaf 实现本地图片显示,和数据库查询显示

在页面显示静态资源,在程序中非常常见,当然也有很多种方式例如保存在resources/META-INF目录下或直接引用本地路径等。

1、了解springboot的静态资源的地址与访问路径

springboot自己是有默认的静态访问资源地址和路径(默认寻找static目录),如果你在配置文件中修改
则会覆盖其默认配置。
那先来了解一下在配置文件中想更改默认地址的代码:

spring.mvc.static-path-pattern

这句话的意思的你应该以什么路径来访问静态资源,也可以说静态资源满足这个配置路径才会处理此请求。

#这种情况下只有请求路径满足img格式才可以处理此请求
#如果按照默认的8080端口的话那么路径就应该为localhost:8080/img/1.jpg
#此时我们想找寻1.jpg的图片,那么springboot就会默认在该路径下寻找对应的文件,
#而寻找对应文件的地址就应该由spring.resources.static-locations里决定
spring.mvc.static-path-pattern=/img/**

spring.resources.static-locations

这行代码配置用来告诉springboot应该去什么路径下访问并寻找相应的文件

默认的官方配置

pring.resources.static-locations=classpath:/static,classpath:/public,classpath:/resources,classpath:/META-INF/resources
这里的匹配机制是列表性的会依次寻找相应目录是否有对应的文件
但是大家也都发现了,这些是项目里自带的资源目录如果我又想访问本地
路径的资源呐?

引用本地路径资源

spring.resources.static-locations=file:F:/images/rotPhoto/
这里我们引用的是F盘的路径,想要成功引用只需要在路径前面加上file即可,
不过根据网上资料显示,不同操作系统之间file的写法好像并不相同,这里演示的>Windows的写法。
当然你如果觉得这样不好的话,也可以通过bean的方式来修改,这样的话需要你创建个extends WebMvcConfigurerAdapter 的类,类重写里面的addResourceHandlers方法来进行修改。
通过查阅资料,也可以通过xml的格式来进行修改代码如下:

<mvc:resources mapping="/resources/**" location="/public-resources/">
    <mvc:cache-control max-age="3600" cache-public="true"/>
</mvc:resources>
总结:spring.mvc.static-path-pattern 更像是指定http请求访问的地址规范,spring.resources.static-locations则是请求之后访问文件的路径!

2、结合springboot,thymeleaf 来简单的实现访问本地路径图片到浏览器上!

博主使用工具为sts,maven,boot版本都为截稿前官网最新(2020.6.30)

  1. 创建项目

     1.修改静态资源的地址和访问路径的配置文件
    
代码如下:spring.resources.static-locations=file:F:/images/rotPhoto/
		spring.mvc.static-path-pattern=/**
博主使用的是自己F盘路径下的images文件夹里的rotPhoto文件夹下的目录
这里出示的为properties配置文件的代码。
      2.创建controller页面
	  3.创建thymeleaf页面

需要的thymeleaf页面配置代码:<html xmlns:th="http://www.thymeleaf.org" lang="en">

  1. 添加代码
    1.博主创建的thymeleaf页面叫Demo
    控制controller代码如下:
	@RequestMapping("/Demo")
	public String demo(Model model){
		String img2 ="/1.jpg";
		model.addAttribute("img2", img2);
		return "Demo";
	}
博主相应目录有一个jpg格式的图片名1,这里定义一个文件名的字符串
用model向前端页面传值
Demo页面代码如下:
<img th:src="@{${img2}}">
用${img2} 来接受后台传入的数据,这里用到了th:src
  1. 运行
    1.启动@SpringBootApplication类
    在这里插入图片描述
    运行成功之后,去浏览器输入请求
    在这里插入图片描述
    自此显示成功
    补:文件路径图片
    在这里插入图片描述
    连接数据库这几天补上~~~~~~ O(∩_∩)O哈哈~
    2020-7-07:
    比较忙,一直没时间,不要慌再等等O(∩_∩)O 2020 - 7-10
本文理论方面参考博客:https://blog.csdn.net/yiifaa/article/details/78299052?utm_medium=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.nonecase&depth_1-utm_source=distribute.pc_relevant_t0.none-task-blog-BlogCommendFromMachineLearnPai2-1.nonecase

大家如果觉得博主表达的不好,推荐大家去看原博主

  • 10
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 15
    评论
要通过Spring和MyBatis依赖并运用Thymeleaf模板技术将数据库中的表格显示在HTML页面上,你可以按照以下步骤实现: 1. 在pom.xml文件中添加Spring Boot、MyBatis和Thymeleaf的相关依赖: ```xml <dependencies> <!-- Spring Boot dependencies --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-web</artifactId> </dependency> <!-- MyBatis dependencies --> <dependency> <groupId>org.mybatis.spring.boot</groupId> <artifactId>mybatis-spring-boot-starter</artifactId> <version>2.2.0</version> </dependency> <dependency> <groupId>com.h2database</groupId> <artifactId>h2</artifactId> <version>1.4.200</version> </dependency> <!-- Thymeleaf dependencies --> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-thymeleaf</artifactId> </dependency> </dependencies> ``` 2. 在application.properties配置文件中配置数据库和MyBatis的相关参数: ```properties # Data Source Configuration spring.datasource.driverClassName=org.h2.Driver spring.datasource.url=jdbc:h2:mem:testdb spring.datasource.username=sa spring.datasource.password= # MyBatis Configuration mybatis.mapper-locations=classpath:mapper/*.xml mybatis.type-aliases-package=com.example.demo.domain ``` 3. 创建数据库表格对应的实体类,并在MyBatis的映射文件中编写SQL语句: ```java package com.example.demo.domain; public class User { private Long id; private String name; private Integer age; // Getters and Setters } ``` ```xml <!-- /src/main/resources/mapper/UserMapper.xml --> <mapper namespace="com.example.demo.mapper.UserMapper"> <select id="selectAll" resultType="com.example.demo.domain.User"> SELECT * FROM user </select> </mapper> ``` 4. 创建MyBatis的Mapper接口: ```java package com.example.demo.mapper; import com.example.demo.domain.User; import org.apache.ibatis.annotations.Mapper; import org.apache.ibatis.annotations.Select; import java.util.List; @Mapper public interface UserMapper { @Select("SELECT * FROM user") List<User> selectAll(); } ``` 5. 在Spring Boot项目中创建Controller,并在其方法中调用MyBatis的Mapper接口获取数据,并将数据传递给Thymeleaf模板: ```java package com.example.demo.controller; import com.example.demo.mapper.UserMapper; import org.springframework.stereotype.Controller; import org.springframework.ui.Model; import org.springframework.web.bind.annotation.GetMapping; @Controller public class UserController { private final UserMapper userMapper; public UserController(UserMapper userMapper) { this.userMapper = userMapper; } @GetMapping("/") public String index(Model model) { model.addAttribute("users", userMapper.selectAll()); return "index"; } } ``` 6. 创建Thymeleaf模板,并在其中使用Thymeleaf标签和表达式来显示数据: ```html <!DOCTYPE html> <html xmlns:th="http://www.thymeleaf.org"> <head> <meta charset="UTF-8"> <title>User List</title> </head> <body> <table> <thead> <tr> <th>ID</th> <th>Name</th> <th>Age</th> </tr> </thead> <tbody> <tr th:each="user : ${users}"> <td th:text="${user.id}"></td> <td th:text="${user.name}"></td> <td th:text="${user.age}"></td> </tr> </tbody> </table> </body> </html> ``` 以上就是通过Spring和MyBatis依赖并运用Thymeleaf模板技术将数据库中的表格显示在HTML页面上的基本步骤,你可以根据实际需求进行调整和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 15
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值