當前位置:首頁 » 文件管理 » mybatis上傳下載

mybatis上傳下載

發布時間: 2024-03-15 10:08:59

㈠ springboot上傳文件寫入資料庫

首先導入了相應的jar包
<!--thymeleaf--><dependency>
<groupId>org.thymeleaf</groupId>
<artifactId>thymeleaf-spring5</artifactId></dependency><dependency>
<groupId>org.thymeleaf.extras</groupId>
<artifactId>thymeleaf-extras-java8time</artifactId></dependency><!--資料庫連接--><dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId></dependency><!--mybatis整合springboot--><dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>2.1.2</version></dependency><!--druid數據源--><dependency>
<groupId>com.alibaba</groupId>
<artifactId>druid</artifactId>
<version>1.1.22</version></dependency>

對數據源,mybatis,和上傳文件進行配置
spring:
datasource:
type: com.alibaba.druid.pool.DruidDataSource username: root password: shw123zxc url: jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=UTF-8&serverTimezone=UTC driver-class-name: com.mysql.cj.jdbc.Driver servlet:
multipart:
max-request-size: 10MB #上傳文件的最大總大小
max-file-size: 10MB #上傳單個文件的最大大小mybatis:
type-aliases-package: cn.codewei.pojo mapper-locations: classpath:/mapper/*.xml1234567891011121314

然後寫一個文件上傳的html,注意表單的==enctype屬性要設置為multipart/form-data==
<!DOCTYPE html><html lang="en"><head>
<meta charset="UTF-8">
<title>Title</title></head><body>
<h1>文件上傳</h1>
<form method="post" enctype="multipart/form-data" action="/upload">
<input type="file" name="file">
<input type="submit" value="上傳">
</form></body></html>1234567891011121314

然後寫一個Mapper和對應的Mapper.xml和service
@Mapper@Repositorypublic interface PhotoMapper {
// 向資料庫中添加圖片
public int addPhoto(Photo photo);

// 從資料庫中取出圖片
public Photo getPhotoById(@Param("id") int id);}123456789
<?xml version="1.0" encoding="UTF-8" ?><!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="cn.codewei.mapper.PhotoMapper">
<insert id="addPhoto" parameterType="photo">
insert into image values (#{id},#{photo},#{photo_name},#{photo_type}) </insert>
<select id="getPhotoById" resultType="photo">
select * from image where id=#{id} </select></mapper>123456789101112

在Controller中進行調用
上傳
@Autowiredprivate PhotoService photoService;@Autowiredprivate Photo photo;@PostMapping("/upload")@ResponseBodypublic String upload(@RequestParam("file") MultipartFile file, HttpServletRequest request) throws IOException {
byte[] bytes = file.getBytes();
photo.setPhoto(bytes);
photo.setPhoto_name(file.getOriginalFilename());
photo.setPhoto_type(".jpg");

photoService.addPhoto(photo);

return "上傳成功!";}123456789101112131415161718

取出,在頁面中顯示
@RequestMapping("/getPhoto")public String getImage(HttpServletResponse response) throws IOException {
Photo photo = photoService.getPhotoById(1);
byte[] photo1 = photo.getPhoto();
ServletOutputStream os = response.getOutputStream();
os.write(photo1);
os.close();
return "";}123456789
<!DOCTYPE html><html lang="en"><head>
<meta charset="UTF-8">
<title>Title</title></head><body>
<h1>首頁</h1>
<img src="/getPhoto" width="200px" height="200px"></body></html>

㈡ 學習java需要什麼基礎

學java需要數據結構基礎。要學好一門編程語言,數據結構是必不可少的知識,搞不清楚演算法復雜度的程序員也就只能做做填空式的增刪改查了。

一、掌握靜態方法和屬性

靜態方法和屬性用於描述某一類對象群體的特徵,而不是單個對象的特徵。Java中大量應用了靜態方法和屬性,這是一個通常的技巧。但是這種技巧在很多語言中不被頻繁地使用。理解靜態方法和屬性對於理解類與對象的關系是十分有幫助的,在大量的Java規范中,靜態方法和屬性被頻繁使用。

由於很多語言沒有這么強大的集合框架體系,很多初學者不知所措,更不知道拿來做什麼用,因此應該引起足夠的重視。

熱點內容
java返回this 發布:2025-10-20 08:28:16 瀏覽:564
製作腳本網站 發布:2025-10-20 08:17:34 瀏覽:854
python中的init方法 發布:2025-10-20 08:17:33 瀏覽:554
圖案密碼什麼意思 發布:2025-10-20 08:16:56 瀏覽:732
怎麼清理微信視頻緩存 發布:2025-10-20 08:12:37 瀏覽:655
c語言編譯器怎麼看執行過程 發布:2025-10-20 08:00:32 瀏覽:973
郵箱如何填寫發信伺服器 發布:2025-10-20 07:45:27 瀏覽:226
shell腳本入門案例 發布:2025-10-20 07:44:45 瀏覽:85
怎麼上傳照片瀏覽上傳 發布:2025-10-20 07:44:03 瀏覽:775
python股票數據獲取 發布:2025-10-20 07:39:44 瀏覽:682