电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

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

瀏覽:2日期:2022-08-22 16:19:22

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

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

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

文中案例已同步至:

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

創建項目

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

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

添加依賴

在項目的 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 = 10network_timeout = 30# 編碼字符集charset = UTF-8# tracker 服務器 HTTP 協議下暴露的端口http.tracker_http_port = 8080# tracker 服務器的 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 分布式文件系統 Java 客戶端工具類 * 具體功能:文件上傳、下載、替換、刪除、查詢文件元數據、查看文件詳情 */public class FastDFSClient { // 獲取配置文件地址 private static final String CONF_FILENAME = Thread.currentThread() .getContextClassLoader().getResource('').getPath() + 'fdfs_client.conf'; // Storage 存儲服務器客戶端 private static StorageClient storageClient = null; static { try { // 加載配置文件 ClientGlobal.init(CONF_FILENAME); // 初始化 Tracker 客戶端 TrackerClient trackerClient = new TrackerClient(ClientGlobal.g_tracker_group); // 初始化 Tracker 服務端 TrackerServer trackerServer = trackerClient.getTrackerServer(); // 初始化 Storage 服務端 StorageServer storageServer = trackerClient.getStoreStorage(trackerServer); // 初始化 Storage 客戶端 storageClient = new StorageClient(trackerServer, storageServer); } catch (IOException e) { e.printStackTrace(); } catch (MyException e) { e.printStackTrace(); } } /** * 文件上傳 * * @param inputStream 上傳的文件的字節輸入流 * @param fileName 上傳的文件的原始名 * @return */ public static String[] uploadFile(InputStream inputStream, String fileName) { try { // 準備字節數組 byte[] fileBuff = null; // 文件元數據 NameValuePair[] metaList = null; if (inputStream != null) { // 查看文件的長度 int len = inputStream.available(); // 初始化元數據數組 metaList = new NameValuePair[2]; // 第一組元數據,文件的原始名稱 metaList[0] = new NameValuePair('file_name', fileName); // 第二組元數據,文件的長度 metaList[1] = new NameValuePair('file_length', String.valueOf(len)); // 創建對應長度的字節數組 fileBuff = new byte[len]; // 將輸入流中的字節內容,讀到字節數組中 inputStream.read(fileBuff); } /* 上傳文件。 參數含義:要上傳的文件的內容(使用字節數組傳遞),上傳的文件的類型(擴展名),元數據 */ 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; } /** * 獲取元數據 * * @param groupName 組/卷名,默認值:group1 * @param remoteFileName 文件名,例如:'M00/00/00/wKgKZl9tkTCAJAanAADhaCZ_RF0495.jpg' * @return 文件的元數據數組 */ public static NameValuePair[] getMetaData(String groupName, String remoteFileName) { try { // 根據組名和文件名通過 Storage 客戶端獲取文件的元數據數組 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 文件的字節輸入流 */ public static InputStream downloadFile(String groupName, String remoteFileName) { try { // 根據組名和文件名通過 Storage 客戶端獲取文件的字節數組 byte[] bytes = storageClient.download_file(groupName == null ? 'group1' : groupName, remoteFileName); // 返回字節流對象 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 { // 根據組名和文件名通過 Storage 客戶端刪除文件 result = storageClient.delete_file(groupName == null ? 'group1' : groupName, remoteFileName); } catch (IOException e) { e.printStackTrace(); } catch (MyException e) { e.printStackTrace(); } return result; } /** * 修改一個已經存在的文件 * * @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; }}

測試

文件上傳

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

返回值

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

文件詳情

// 查看文件詳情@Testpublic 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

文件元數據

// 獲取文件數據@Testpublic 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---57704file_name---china.jpg

文件下載

// 文件下載@Testpublic 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(); }}

文件刪除

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

返回值:

result = 0

文件替換

// 文件替換@Testpublic 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 = group1fileid = M00/00/00/wKgKZl9xOeaAFO00AACmo7QBGtA298.jpg

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

到此這篇關于Java 客戶端操作 FastDFS 實現文件上傳下載替換刪除功能的文章就介紹到這了,更多相關java 文件上傳下載替換刪除內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Java
相關文章:
主站蜘蛛池模板: 儿童语言障碍训练-武汉优佳加感统文化发展有限公司 | 馋嘴餐饮网_餐饮加盟店火爆好项目_餐饮连锁品牌加盟指南创业平台 | 高速龙门架厂家_监控杆_多功能灯杆_信号灯杆_锂电池太阳能路灯-鑫世源照明 | 防火窗_耐火窗_防火门厂家_防火卷帘门-重庆三乐门业有限公司 | 软瓷_柔性面砖_软瓷砖_柔性石材_MCM软瓷厂家_湖北博悦佳软瓷 | 淄博不锈钢无缝管,淄博不锈钢管-鑫门物资有限公司 | 生鲜配送系统-蔬菜食材配送管理系统-连锁餐饮订货配送软件-挪挪生鲜供应链管理软件 | 筒瓦厂家-仿古瓦-寺庙-古建琉璃瓦-宜兴市古典园林建筑陶瓷厂有限公司 | 接地电阻测试仪[厂家直销]_电缆故障测试仪[精准定位]_耐压测试仪-武汉南电至诚电力设备 | 集菌仪_智能集菌仪_全封闭集菌仪_无菌检查集菌仪厂家-那艾 | 冷轧机|两肋冷轧机|扁钢冷轧机|倒立式拉丝机|钢筋拔丝机|收线机-巩义市华瑞重工机械制造有限公司 | 水质传感器_水质监测站_雨量监测站_水文监测站-山东水境传感科技有限公司 | 铁盒_铁罐_马口铁盒_马口铁罐_铁盒生产厂家-广州博新制罐 | 防弹玻璃厂家_防爆炸玻璃_电磁屏蔽玻璃-四川大硅特玻科技有限公司 | 电池挤压试验机-自行车喷淋-车辆碾压试验装置-深圳德迈盛测控设备有限公司 | 高铝砖-高铝耐火球-高铝耐火砖生产厂家-价格【荣盛耐材】 | ◆大型吹塑加工|吹塑加工|吹塑代加工|吹塑加工厂|吹塑设备|滚塑加工|滚塑代加工-莱力奇塑业有限公司 | 创客匠人-让IP变现不走弯路 | 水冷散热器_水冷电子散热器_大功率散热器_水冷板散热器厂家-河源市恒光辉散热器有限公司 | 破碎机锤头_合金耐磨锤头_郑州宇耐机械工程技术有限公司 | 玻纤土工格栅_钢塑格栅_PP焊接_单双向塑料土工格栅_复合防裂布厂家_山东大庚工程材料科技有限公司 | 一路商机网-品牌招商加盟优选平台-加盟店排行榜平台 | 高压贴片电容|贴片安规电容|三端滤波器|风华电容代理南京南山 | 运动木地板厂家,篮球场木地板品牌,体育场馆木地板安装 - 欧氏运动地板 | 塑料瓶罐_食品塑料瓶_保健品塑料瓶_调味品塑料瓶–东莞市富慷塑料制品有限公司 | 苏州注册公司_苏州代理记账_苏州工商注册_苏州代办公司-恒佳财税 | 电采暖锅炉_超低温空气源热泵_空气源热水器-鑫鲁禹电锅炉空气能热泵厂家 | 博莱特空压机|博莱特-阿特拉斯独资空压机品牌核心代理商 | 智能风向风速仪,风速告警仪,数字温湿仪,综合气象仪(气象五要素)-上海风云气象仪器有限公司 | ◆大型吹塑加工|吹塑加工|吹塑代加工|吹塑加工厂|吹塑设备|滚塑加工|滚塑代加工-莱力奇塑业有限公司 | 杭州成人高考_浙江省成人高考网上报名 | 紧急切断阀_气动切断阀_不锈钢阀门_截止阀_球阀_蝶阀_闸阀-上海上兆阀门制造有限公司 | 保温杯,儿童婴童奶瓶,运动水壶「广告礼品杯定制厂家」超朗保温杯壶 | 右手官网|右手工业设计|外观设计公司|工业设计公司|产品创新设计|医疗产品结构设计|EMC产品结构设计 | 土壤养分检测仪_肥料养分检测仪_土壤水分检测仪-山东莱恩德仪器 大型多片锯,圆木多片锯,方木多片锯,板材多片锯-祥富机械有限公司 | 小区健身器材_户外健身器材_室外健身器材_公园健身路径-沧州浩然体育器材有限公司 | 长沙一级消防工程公司_智能化弱电_机电安装_亮化工程专业施工承包_湖南公共安全工程有限公司 | 磨煤机配件-高铬辊套-高铬衬板-立磨辊套-盐山县宏润电力设备有限公司 | 数码听觉统合训练系统-儿童感觉-早期言语评估与训练系统-北京鑫泰盛世科技发展有限公司 | 常州减速机_减速机厂家_常州市减速机厂有限公司 | 超声波成孔成槽质量检测仪-压浆机-桥梁预应力智能张拉设备-上海硕冠检测设备有限公司 |