欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java 客戶端操作 FastDFS 實現(xiàn)文件上傳下載替換刪除功能

 更新時間:2020年10月17日 09:24:48   作者:哈嘍沃德先生  
這篇文章主要介紹了Java 客戶端操作 FastDFS 實現(xiàn)文件上傳下載替換刪除功能,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

FastDFS 的作者余慶先生已經(jīng)為我們開發(fā)好了 Java 對應(yīng)的 SDK。這里需要解釋一下:作者余慶并沒有及時更新最新的 Java SDK 至 Maven 中央倉庫,目前中央倉庫最新版仍舊是 1.27 版。所以我們需要通過 Github:https://github.com/happyfish100/fastdfs-client-java 下載項目源碼,再通過命令 mvn clean install 編譯打包導(dǎo)入 Maven 倉庫使用即可。

接下來我們通過 Java API 操作 FastDFS 實現(xiàn)文件的上傳、下載、替換、刪除、查詢元數(shù)據(jù)、查詢詳情等功能。

文中案例已同步至:

Github:https://github.com/imrhelloworld/fastdfs-javaGitee:https://gitee.com/imrhelloworld/fastdfs-java

創(chuàng)建項目

添加依賴

在項目的 pom.xml 中添加以下依賴。因為我們需要一些常用工具包和單元測試,所以需要引入它們。

<!-- fastdfs java client -->
<dependency>
 <groupId>org.csource</groupId>
 <artifactId>fastdfs-client-java</artifactId>
 <version>1.29-SNAPSHOT</version>
</dependency>
<!-- apache commons lang3 工具包 -->
<dependency>
 <groupId>org.apache.commons</groupId>
 <artifactId>commons-lang3</artifactId>
 <version>3.11</version>
</dependency>
<!-- junit 單元測試 -->
<dependency>
 <groupId>junit</groupId>
 <artifactId>junit</artifactId>
 <version>4.13</version>
 <scope>test</scope>
</dependency>

編寫配置文件

fdfs_client.conf

# 超時時間
connect_timeout = 10
network_timeout = 30
# 編碼字符集
charset = UTF-8
# tracker 服務(wù)器 HTTP 協(xié)議下暴露的端口
http.tracker_http_port = 8080
# tracker 服務(wù)器的 IP 和端口
tracker_server = 192.168.10.101:22122

工具類

package org.example.client;

import org.apache.commons.lang3.StringUtils;
import org.csource.common.MyException;
import org.csource.common.NameValuePair;
import org.csource.fastdfs.*;

import java.io.*;

/**
 * FastDFS 分布式文件系統(tǒng) Java 客戶端工具類
 * 具體功能:文件上傳、下載、替換、刪除、查詢文件元數(shù)據(jù)、查看文件詳情
 */
public class FastDFSClient {

 // 獲取配置文件地址
 private static final String CONF_FILENAME = Thread.currentThread()
   .getContextClassLoader().getResource("").getPath() + "fdfs_client.conf";
 // Storage 存儲服務(wù)器客戶端
 private static StorageClient storageClient = null;

 static {
  try {
   // 加載配置文件
   ClientGlobal.init(CONF_FILENAME);
   // 初始化 Tracker 客戶端
   TrackerClient trackerClient = new TrackerClient(ClientGlobal.g_tracker_group);
   // 初始化 Tracker 服務(wù)端
   TrackerServer trackerServer = trackerClient.getTrackerServer();
   // 初始化 Storage 服務(wù)端
   StorageServer storageServer = trackerClient.getStoreStorage(trackerServer);
   // 初始化 Storage 客戶端
   storageClient = new StorageClient(trackerServer, storageServer);
  } catch (IOException e) {
   e.printStackTrace();
  } catch (MyException e) {
   e.printStackTrace();
  }
 }

 /**
  * 文件上傳
  *
  * @param inputStream 上傳的文件的字節(jié)輸入流
  * @param fileName 上傳的文件的原始名
  * @return
  */
 public static String[] uploadFile(InputStream inputStream, String fileName) {
  try {
   // 準備字節(jié)數(shù)組
   byte[] fileBuff = null;
   // 文件元數(shù)據(jù)
   NameValuePair[] metaList = null;
   if (inputStream != null) {
    // 查看文件的長度
    int len = inputStream.available();
    // 初始化元數(shù)據(jù)數(shù)組
    metaList = new NameValuePair[2];
    // 第一組元數(shù)據(jù),文件的原始名稱
    metaList[0] = new NameValuePair("file_name", fileName);
    // 第二組元數(shù)據(jù),文件的長度
    metaList[1] = new NameValuePair("file_length", String.valueOf(len));
    // 創(chuàng)建對應(yīng)長度的字節(jié)數(shù)組
    fileBuff = new byte[len];
    // 將輸入流中的字節(jié)內(nèi)容,讀到字節(jié)數(shù)組中
    inputStream.read(fileBuff);
   }
   /*
    上傳文件。
    參數(shù)含義:要上傳的文件的內(nèi)容(使用字節(jié)數(shù)組傳遞),上傳的文件的類型(擴展名),元數(shù)據(jù)
    */
   String[] fileids = storageClient.upload_file(fileBuff, getFileExt(fileName), metaList);
   return fileids;
  } catch (IOException e) {
   e.printStackTrace();
  } catch (MyException e) {
   e.printStackTrace();
  }
  return null;
 }

 /**
  * 文件上傳
  *
  * @param file  上傳的文件
  * @param fileName 上傳的文件的原始名
  * @return
  */
 public static String[] uploadFile(File file, String fileName) {
  try (FileInputStream fis = new FileInputStream(file)) {
   return uploadFile(fis, fileName);
  } catch (FileNotFoundException e) {
   e.printStackTrace();
  } catch (IOException e) {
   e.printStackTrace();
  }
  return null;
 }

 /**
  * 獲取文件后綴名(不帶點)
  *
  * @param fileName
  * @return 如:"jpg" or ""
  */
 private static String getFileExt(String fileName) {
  if (StringUtils.isBlank(fileName) || !fileName.contains(".")) {
   return "";
  }
  return fileName.substring(fileName.lastIndexOf(".") + 1); // 不帶最后的點
 }

 /**
  * 獲取文件詳情
  *
  * @param groupName  組/卷名,默認值:group1
  * @param remoteFileName 文件名,例如:"M00/00/00/wKgKZl9tkTCAJAanAADhaCZ_RF0495.jpg"
  * @return 文件詳情
  */
 public static FileInfo getFileInfo(String groupName, String remoteFileName) {
  try {
   return storageClient.get_file_info(groupName == null ? "group1" : groupName, remoteFileName);
  } catch (IOException e) {
   e.printStackTrace();
  } catch (MyException e) {
   e.printStackTrace();
  }
  return null;
 }

 /**
  * 獲取元數(shù)據(jù)
  *
  * @param groupName  組/卷名,默認值:group1
  * @param remoteFileName 文件名,例如:"M00/00/00/wKgKZl9tkTCAJAanAADhaCZ_RF0495.jpg"
  * @return 文件的元數(shù)據(jù)數(shù)組
  */
 public static NameValuePair[] getMetaData(String groupName, String remoteFileName) {
  try {
   // 根據(jù)組名和文件名通過 Storage 客戶端獲取文件的元數(shù)據(jù)數(shù)組
   return storageClient.get_metadata(groupName == null ? "group1" : groupName, remoteFileName);
  } catch (IOException e) {
   e.printStackTrace();
  } catch (MyException e) {
   e.printStackTrace();
  }
  return null;
 }

 /**
  * 文件下載
  *
  * @param groupName  組/卷名,默認值:group1
  * @param remoteFileName 文件名,例如:"M00/00/00/wKgKZl9tkTCAJAanAADhaCZ_RF0495.jpg"
  * @return 文件的字節(jié)輸入流
  */
 public static InputStream downloadFile(String groupName, String remoteFileName) {
  try {
   // 根據(jù)組名和文件名通過 Storage 客戶端獲取文件的字節(jié)數(shù)組
   byte[] bytes = storageClient.download_file(groupName == null ? "group1" : groupName, remoteFileName);
   // 返回字節(jié)流對象
   InputStream inputStream = new ByteArrayInputStream(bytes);
   return inputStream;
  } catch (IOException e) {
   e.printStackTrace();
  } catch (MyException e) {
   e.printStackTrace();
  }
  return null;
 }

 /**
  * 文件刪除
  *
  * @param groupName  組/卷名,默認值:group1
  * @param remoteFileName 文件名,例如:"M00/00/00/wKgKZl9tkTCAJAanAADhaCZ_RF0495.jpg"
  * @return 0為成功,非0為失敗
  */
 public static int deleteFile(String groupName, String remoteFileName) {
  int result = -1;
  try {
   // 根據(jù)組名和文件名通過 Storage 客戶端刪除文件
   result = storageClient.delete_file(groupName == null ? "group1" : groupName, remoteFileName);
  } catch (IOException e) {
   e.printStackTrace();
  } catch (MyException e) {
   e.printStackTrace();
  }
  return result;
 }

 /**
  * 修改一個已經(jīng)存在的文件
  *
  * @param oldGroupName 舊組名
  * @param oldFileName 舊文件名
  * @param file   新文件
  * @param fileName  新文件名
  * @return
  */
 public static String[] modifyFile(String oldGroupName, String oldFileName, File file, String fileName) {
  // 先上傳
  String[] fileids = uploadFile(file, fileName);
  if (fileids == null) {
   return null;
  }
  // 再刪除
  int delResult = deleteFile(oldGroupName, oldFileName);
  if (delResult != 0) {
   return null;
  }
  return fileids;
 }

}

測試

文件上傳

// 文件上傳
@Test
public void testUploadFile() {
 String[] fileids = FastDFSClient.uploadFile(new File("D:/china.jpg"), "china.jpg");
 for (String fileid : fileids) {
  System.out.println("fileid = " + fileid);
 }
}

返回值

fileid = group1
fileid = M00/00/00/wKgKZl9xMdiAcOLdAADhaCZ_RF0096.jpg

文件詳情

// 查看文件詳情
@Test
public void testGetFileInfo() {
 FileInfo fileInfo = FastDFSClient.getFileInfo("group1", "M00/00/00/wKgKZl9xMdiAcOLdAADhaCZ_RF0096.jpg");
 System.out.println("fileInfo = " + fileInfo);
}

返回值:

fileInfo = fetch_from_server = false, file_type = 1, source_ip_addr = 192.168.10.102, file_size = 57704, create_timestamp = 2020-09-28 08:44:08, crc32 = 645874781

文件元數(shù)據(jù)

// 獲取文件數(shù)據(jù)
@Test
public void testGetMetaData() {
 NameValuePair[] metaDatas = FastDFSClient.getMetaData("group1", "M00/00/00/wKgKZl9xMdiAcOLdAADhaCZ_RF0096.jpg");
 for (NameValuePair metaData : metaDatas) {
  System.out.println(metaData.getName() + "---" + metaData.getValue());
 }
}

返回值:

file_length---57704
file_name---china.jpg

文件下載

// 文件下載
@Test
public void testDownloadFile() {
 InputStream is = FastDFSClient.downloadFile("group1", "M00/00/00/wKgKZl9xMdiAcOLdAADhaCZ_RF0096.jpg");
 try (FileOutputStream fos = new FileOutputStream("D:/wKgKZl9xMdiAcOLdAADhaCZ_RF0096.jpg")) {
  int len = 0;
  byte[] bytes = new byte[1024];
  while ((len = is.read(bytes)) != -1) {
   fos.write(bytes, 0, len);
   fos.flush();
  }
 } catch (FileNotFoundException e) {
  e.printStackTrace();
 } catch (IOException e) {
  e.printStackTrace();
 }
}

文件刪除

// 文件刪除
@Test
public void testDeleteFile() {
 int result = FastDFSClient.deleteFile("group1", "M00/00/00/wKgKZl9xMdiAcOLdAADhaCZ_RF0096.jpg");
 System.out.println("result = " + result);
}

返回值:

result = 0

文件替換

// 文件替換
@Test
public void testModifyFile() {
 String[] fileids = FastDFSClient.modifyFile("group1", "M00/00/00/wKgKZl9xOS2ASdu8AADhaCZ_RF0898.jpg",
            new File("D:/mhw.jpg"), "mhw.jpg");
 for (String fileid : fileids) {
  System.out.println("fileid = " + fileid);
 }
}

返回值:

fileid = group1
fileid = M00/00/00/wKgKZl9xOeaAFO00AACmo7QBGtA298.jpg

至此 Java 客戶端操作 FastDFS 實現(xiàn)文件上傳下載替換刪除等操作就到這里,下一篇我們帶大家搭建 FastDFS 的集群環(huán)境,多 Tracker 多 Storage 然后通過 Nginx 代理。

到此這篇關(guān)于Java 客戶端操作 FastDFS 實現(xiàn)文件上傳下載替換刪除功能的文章就介紹到這了,更多相關(guān)java 文件上傳下載替換刪除內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Spring Security獲取用戶認證信息的實現(xiàn)流程

    Spring Security獲取用戶認證信息的實現(xiàn)流程

    Spring Security是一個能夠為基于Spring的企業(yè)應(yīng)用系統(tǒng)提供聲明式的安全訪問控制解決方案的安全框架。它提供了一組可以在Spring應(yīng)用上下文中配置的Bean,充分利用了Spring IoC,DI和AOP功能,為應(yīng)用系統(tǒng)提供聲明式的安全訪問控制功能
    2022-12-12
  • spring 整合mybatis后用不上session緩存的原因分析

    spring 整合mybatis后用不上session緩存的原因分析

    因為一直用spring整合了mybatis,所以很少用到mybatis的session緩存。什么原因呢?下面小編給大家介紹spring 整合mybatis后用不上session緩存的原因分析,需要的朋友可以參考下
    2017-02-02
  • 初識Java8中的Stream

    初識Java8中的Stream

    lambda表達式是stream的基礎(chǔ),接下來通過實例代碼給大家詳細介紹java8中的stream,感興趣的朋友一起看看吧
    2017-08-08
  • MyBatis控制臺顯示SQL語句的方法實現(xiàn)

    MyBatis控制臺顯示SQL語句的方法實現(xiàn)

    這篇文章主要介紹了MyBatis控制臺顯示SQL語句的方法實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03
  • Maven jar包沖突的解決方案

    Maven jar包沖突的解決方案

    這篇文章主要介紹了Maven jar包沖突的解決方案,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-04-04
  • Java異常詳解_動力節(jié)點Java學(xué)院整理

    Java異常詳解_動力節(jié)點Java學(xué)院整理

    異常是Java語言中的一部分,它代表程序中由各種原因引起的“不正?!币蛩?。下面通過本文給大家介紹java異常的相關(guān)知識,感興趣的朋友一起看看吧
    2017-06-06
  • Java基礎(chǔ)第四篇 封裝與接口

    Java基礎(chǔ)第四篇 封裝與接口

    本文將對介紹Java 的封裝與接口進行介紹,將要封裝(encapsulation)對象的成員(成員包括數(shù)據(jù)成員和方法),從而只允許從外部調(diào)用部分的成員。利用封裝,我們可以提高對象的易用性和安全性。想具體了解的小伙伴請參考下面文章的內(nèi)容
    2021-09-09
  • java編程基礎(chǔ)之模仿用戶登錄代碼分享

    java編程基礎(chǔ)之模仿用戶登錄代碼分享

    這篇文章主要介紹了java編程基礎(chǔ)之模仿用戶登錄代碼分享,小編覺得挺不錯的,這里分享給大家,供需要的朋友參考。
    2017-10-10
  • Java面試之線程通訊方式詳解

    Java面試之線程通訊方式詳解

    線程通信是指多個線程之間通過某種機制進行協(xié)調(diào)和交互,那為什么一個線程等待和通知機制就需要這么多的實現(xiàn)方式呢?別著急,下面小編來和大家仔細聊聊
    2023-08-08
  • Java中File與byte[]的互轉(zhuǎn)方式

    Java中File與byte[]的互轉(zhuǎn)方式

    這篇文章主要介紹了Java中File與byte[]的互轉(zhuǎn)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-05-05

最新評論