package cn.saiz.drkms.task.crack.utils;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map; import org.csource.common.NameValuePair;
import org.csource.fastdfs.ClientGlobal;
import org.csource.fastdfs.FileInfo;
import org.csource.fastdfs.StorageClient;
import org.csource.fastdfs.StorageClient1;
import org.csource.fastdfs.StorageServer;
import org.csource.fastdfs.TrackerClient;
import org.csource.fastdfs.TrackerServer;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory; public class FastDFSUtil { public static Logger log = LoggerFactory.getLogger(FastDFSUtil.class); static {
try {
String path = System.getProperty("user.dir") + "/fdfs_client.conf";
File file = new File(path);
if(file == null || !file.exists()){
path = FastDFSUtil.class.getClassLoader()
.getResource("fdfs_client.conf").getPath();
file = new File(path);
if(file == null || !file.exists()){
path = Thread.currentThread().getContextClassLoader().
getResource("fdfs_client.conf").getPath();
}
}
// 读取配置文件
ClientGlobal.init(path);
} catch (Exception e) {
log.error("Init fastdfs error:{}",e.getMessage());
throw new RuntimeException(e);
}
} public static StorageClient1 getClient() throws IOException {
return new StorageClient1(new TrackerClient().getConnection(), null);
} public static StorageClient1 getClient(TrackerServer trackerServer,StorageServer storageServer){
return new StorageClient1(trackerServer, storageServer);
} public static TrackerServer getTrackerServer() throws IOException{
return new TrackerClient().getConnection();
} public static void releaseServerResource(TrackerServer trackerServer,StorageServer storageServer) throws IOException{
if(trackerServer != null) trackerServer.close();
if(storageServer != null) storageServer.close();
}
///////////////////上传文件////////////////
public static String uploadFile(String filePath)
throws IOException {
return uploadFile(null, new File(filePath));
} public static String uploadFile(String groupName, String filePath)
throws IOException {
return uploadFile(groupName, new File(filePath));
} public static String uploadFile(String groupName, File file)
throws IOException {
if (file == null) return null;
return uploadFile(groupName, new FileInputStream(file), file.getName(), file.length());
} public static String uploadFile(File file) throws IOException {
return uploadFile(null, file);
} public static String uploadFile(InputStream input,String fileName, long fileLength)
throws IOException {
return uploadFile(null, input, fileName, fileLength);
} public static String uploadFile(String groupName, InputStream inStream,
String uploadFileName, long fileLength) throws IOException {
return uploadByteFile(groupName, uploadFileName, fileLength, getFileBuffer(inStream, fileLength));
} public static String uploadByteFile(String groupName,
String fileName, long fileLength, byte[] fileBuff)
throws IOException {
String fileId = null;
String fileExtName = null;
if (fileName.contains(".")) {
fileExtName = fileName.substring(fileName
.lastIndexOf(".") + 1);
} else {
log.warn("Fail to upload file, because the format of filename is illegal.");
return fileId;
} // 建立连接
TrackerServer trackerServer = getTrackerServer();
StorageServer storageServer = null;
StorageClient1 client = getClient(trackerServer, storageServer); // 设置元信息
NameValuePair[] metaList = new NameValuePair[3];
metaList[0] = new NameValuePair("fileName", fileName);
metaList[1] = new NameValuePair("fileExtName", fileExtName);
metaList[2] = new NameValuePair("fileLength",
String.valueOf(fileLength)); // 上传文件
try {
fileId = client.upload_file1(groupName, fileBuff, fileExtName,
metaList);
log.info("upload success. file id is: " + fileId);
} catch (Exception e) {
log.warn("Upload file \"" + fileName + "\"fails");
throw new RuntimeException(e);
} finally {
releaseServerResource(trackerServer, storageServer);
}
return fileId;
}
//////////////////上传文件END///////////////// /////////////////下载文件////////////////////
public static byte[] downloadFile(String groupName, String filepath)
throws Exception {
if(filepath == null || "".equals(filepath)) return null;
TrackerServer trackerServer = null;
StorageServer storageServer = null;
try {
TrackerClient tracker = new TrackerClient();
trackerServer = tracker.getConnection();
StorageClient storageClient = new StorageClient(trackerServer,
storageServer);
// StorageClient1 storageClient1 = new StorageClient1(trackerServer,
// storageServer);
return storageClient.download_file(groupName, filepath);
} finally {
releaseServerResource(trackerServer, storageServer);
}
} public static byte[] downloadFile(String fileId) throws Exception {
TrackerServer trackerServer = null;
StorageServer storageServer = null;
try {
trackerServer = getTrackerServer();
StorageClient1 storageClient1 = getClient(trackerServer, storageServer);
return storageClient1.download_file1(fileId);
} finally {
releaseServerResource(trackerServer, storageServer);
}
} public static void downloadFile(String fileId, OutputStream out)
throws Exception {
if(fileId != null && out != null){
try {
byte[] b = downloadFile(fileId);
out.write(b);
out.flush();
} finally {
out.close();
}
}
} public static void downloadFile(String groupName, String filepath,
OutputStream out) throws Exception {
if(filepath != null && out != null){
try {
byte[] b = downloadFile(groupName, filepath);
out.write(b);
out.flush();
} finally {
out.close();
}
}
} public static void downloadFile(String groupName, String filepath,
File descFile) throws Exception {
OutputStream out = null;
try {
out = new FileOutputStream(descFile);
downloadFile(groupName, filepath, out);
} finally {
if(out != null)
out.close();
}
} public static List<Map<String,String>> getFileMate(String groupName, String filepath)
throws Exception {
if(filepath == null) return null;
TrackerServer trackerServer = getTrackerServer();
StorageServer storageServer = null;
StorageClient storageClient = getClient(trackerServer, storageServer);
NameValuePair nvps[] = storageClient.get_metadata(groupName, filepath);
List<Map<String,String>> list = new ArrayList<Map<String,String>>();
for (NameValuePair nvp : nvps) {
Map<String,String> map = new HashMap<String,String>();
map.put(nvp.getName(), nvp.getValue());
list.add(map);
}
return list;
} /**
* 删除文件
* @return 0:删除成功 其他数值失败
*/
public static int deleteFile(String groupName, String filepath)
throws Exception {
if(filepath == null) return -1;
TrackerServer trackerServer = getTrackerServer();
StorageServer storageServer = null;
StorageClient storageClient = new StorageClient(trackerServer,
storageServer);
return storageClient.delete_file(groupName, filepath);
} /**
* 删除文件
*
* @param groupName
* @param filepath
* @throws Exception
*/
public static int deleteFile(String fileId) throws Exception {
if(fileId == null) return -1;
TrackerServer trackerServer = null;
StorageServer storageServer = null;
try {
trackerServer = getTrackerServer();
StorageClient1 storageClient1 = getClient(trackerServer, storageServer);
return storageClient1.delete_file1(fileId);
} finally {
releaseServerResource(trackerServer, storageServer);
}
} /**
* 通过fileID查询上传的文件信息
*
* @param fileId
* eg:group1/M00/00/00/wKi3glS_XEaAVL3DAAwdkYUdoP8278.gif
* @return
* @throws Exception
*/
public static FileInfo getFileInfo(String fileId) throws Exception {
if (fileId == null) return null;
TrackerServer trackerServer = getTrackerServer();
StorageServer storageServer = null;
try {
StorageClient1 client = new StorageClient1(trackerServer, storageServer);
return client.get_file_info1(fileId);
} finally {
releaseServerResource(trackerServer, storageServer);
}
} private static byte[] getFileBuffer(InputStream inStream, long fileLength)
throws IOException {
byte[] buffer = new byte[256 * 1024];
byte[] fileBuffer = new byte[(int) fileLength]; int count = 0;
int length = 0; while ((length = inStream.read(buffer)) != -1) {
for (int i = 0; i < length; ++i) {
fileBuffer[count + i] = buffer[i];
}
count += length;
}
return fileBuffer;
} public static void main(String[] args) throws Exception {
List<Map<String, String>> fileMate = getFileMate("group1","M00/98/73/CgMEwVh5M62AQnf-ABa36R1PUuY660.pdf");
System.out.println(fileMate.toString());
}
}

FastDFS java 辅助类的更多相关文章

  1. 关于FastDFS Java客户端源码中的一个不太明白的地方

    下面代码是package org.csource.fastdfs下TrackerGroup.java文件中靠近结束的一段代码,我下载的这个源码的版本是1.24. /** * return connec ...

  2. 使用Java辅助类(CountDownLatch、CyclicBarrier、Semaphore)并发编程

    在java 1.5中,提供了一些非常有用的辅助类来帮助我们进行并发编程,比如CountDownLatch,CyclicBarrier和Semaphore,今天我们就来学习一下这三个辅助类的用法 一.C ...

  3. FastDfs java客户端上传、删除文件

    #配置文件 connect_timeout = 2 network_timeout = 30 charset = UTF-8 http.tracker_http_port = 9090 http.an ...

  4. fastdfs java client error

    tracker,storage运行正常,利用fdfs_test程序做测试,可以正常上传下载文件. tracker的端口配置 # HTTP port on this tracker server htt ...

  5. Java辅助类持续汇总~

    /** * 01 * 描述:List<String>集合去除重复数据 * [时间 2019年3月5日下午3:54:09 作者 陶攀峰] */ public static List<S ...

  6. fastDFS 上传 java源码

    要想搭建fastDFS网上有相近的文章: 分布式文件系统 - FastDFS 在 CentOS 下配置安装部署 分布式文件系统 - FastDFS 配置 Nginx 模块及上传测试 首先下载fastd ...

  7. 分享知识-快乐自己:FastDFS 上传 java 源码

    FastDFS 上传 java 源码:点我下载源码 首先导入 POM 文件:解决 maven 不能下载 fastdfs-client-java JAR <dependency> <g ...

  8. Java 客户端操作 FastDFS 实现文件上传下载替换删除

    FastDFS 的作者余庆先生已经为我们开发好了 Java 对应的 SDK.这里需要解释一下:作者余庆并没有及时更新最新的 Java SDK 至 Maven 中央仓库,目前中央仓库最新版仍旧是 1.2 ...

  9. 网站文件系统发展&&分布式文件系统fastDFS

    网站文件系统发展 1.单机时代的图片服务器架构 初创时期由于时间紧迫,开发人员水平也很有限等原因.所以通常就直接在website文件所在的目录下,建立1个upload子目录,用于保存用户上传的图片文件 ...

随机推荐

  1. 「DP」区间dp

    区间dp? 状态设计为描述一段区间的dp. eg:f[i][j]表示从 i 到 j 这个区间上的最优值.

  2. [WC 2006] 水管局长

    [题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=2594 [算法] 首先离线 , 将删边操作转化为倒序加边 假设我们已经维护出了一棵最小 ...

  3. Flask-SQLAlchemy配置

    下面是 Flask-SQLAlchemy 中存在的配置值.Flask-SQLAlchemy 从您的 Flask 主配置中加载这些值. 注意其中的一些在引擎创建后不能修改,所以确保尽早配置且不在运行时修 ...

  4. MongoDB复制集高可用选举机制(三)

    复制集高可用选举机制 在上一章介绍了MongoDB的架构,复制集的架构直接影响着故障切换时的结果.为了能够有效的故障切换,请确保至少有一个节点能够顺利升职为主节点.保证在拥有核心业务系统的数据中心中拥 ...

  5. UNP总结 Chapter 11 名字与地址转换

    本章讲述在名字和数值地址间进行转换的函数:gethostbyname和gethostbyaddr在主机名字与IP地址间进行转换,getservbyname和getservbyport在服务器名字和端口 ...

  6. Cobbler安装配置简单使用

    安装Cobbler [root@linux-node3 ~]# yum -y install epel-release [root@linux-node3 ~]# yum -y install cob ...

  7. sublime 设置像IDE一样的 ctrl+鼠标左键 跳转到定义方法

    鼠标点击菜单栏的Preferences,选择Browse Packages ,进入文件加之后,选择User 点击进入User,在User里面添加文件名为 Default (Windows).subli ...

  8. HTML5.与JQUERY与AJAX常见面试题

    1. HTML5 1.1.简要描述 HTML5中的本地存储 参考答案: 很多时候我们会存储用户本地信息到电脑上,例如:比方说用户有一个填充了一半的长表格,然后突然网络连接断开了,这样用户希望你能存储这 ...

  9. java 内存管理机制

    垃圾收集算法 1.标记清理算法:效率不高(标记和清理过程效率都不高).会形成内存碎片 2.复制算法:把内存分为两部分,当进行回收时,把使用部分的存活对象复制到未使用部分,然后两部分内存角色互换(一个为 ...

  10. 使用命令把类打成jar包

    测试用类 public class Hello { public static void main(String[] args) { System.out.println("hello wo ...