FastDFS--3.使用java客户端

1      Java客户端:

1.1    Jar包

由于中央仓库没有,

1.只能使用jar包

 

1.2    Maven配置

2.Maven环境:通过maven工程导入私服

 

得到依赖

<dependency>
    <groupId>fastdfs_client</groupId>
    <artifactId>fastdfs_client</artifactId>
    <version>1.25</version>
</dependency>
 

2      测试--上传图片

 

2.1    上传步骤

1、加载配置文件,配置文件中的内容就是tracker服务的地址。

配置文件内容:tracker_server=192.168.25.133:22122

2、创建一个TrackerClient对象。直接new一个。

3、使用TrackerClient对象创建连接,获得一个TrackerServer对象。

4、创建一个StorageServer的引用,值为null

5、创建一个StorageClient对象,需要两个参数TrackerServer对象、StorageServer的引用

6、使用StorageClient对象上传图片。

7、返回数组。包含组名和图片的路径。

 

2.2    配置文件client.conf

tracker_server=192.168.25.133:22122

  

2.3    测试类

import org.csource.fastdfs.ClientGlobal;
import org.csource.fastdfs.StorageClient;
import org.csource.fastdfs.StorageServer;
import org.csource.fastdfs.TrackerClient;
import org.csource.fastdfs.TrackerServer;
import org.junit.Test;

public class FastDfsTest {

   @Test
   public void testUpload() throws Exception {
      //创建一个配置文件。文件名任意。内容就是tracker服务器的地址。
      //使用全局对象加载配置文件。
      ClientGlobal.init("F:\\javaeg\\1_test\\e3\\e3-manager-web\\src\\main\\resources\\conf\\client.conf");
      //创建一个TrackerClient对象
      TrackerClient trackerClient = new TrackerClient();
      //通过TrackClient获得一个TrackerServer对象
      TrackerServer trackerServer = trackerClient.getConnection();
      //创建一个StrorageServer的引用,可以是null
      StorageServer storageServer = null;
      //创建一个StorageClient,参数需要TrackerServer和StrorageServer
      StorageClient storageClient = new StorageClient(trackerServer, storageServer);
      //使用StorageClient上传文件。
      String[] strings = storageClient.upload_file("G:\\1.jpg", "jpg", null);
      for (String string : strings) {
         System.out.println(string);
      }
   }
   
}

2.4    访问图片

http://192.168.25.133/group1/M00/00/00/wKgZhVp5YguAXg4WAABzYPo_8lg792.jpg

 

3      使用工具类上传

3.1    工具类

 

import org.csource.common.NameValuePair;
import org.csource.fastdfs.ClientGlobal;
import org.csource.fastdfs.StorageClient1;
import org.csource.fastdfs.StorageServer;
import org.csource.fastdfs.TrackerClient;
import org.csource.fastdfs.TrackerServer;

public class FastDFSClient {

   private TrackerClient trackerClient = null;
   private TrackerServer trackerServer = null;
   private StorageServer storageServer = null;
   private StorageClient1 storageClient = null;
   
   public FastDFSClient(String conf) throws Exception {
      if (conf.contains("classpath:")) {
         conf = conf.replace("classpath:", this.getClass().getResource("/").getPath());
      }
      ClientGlobal.init(conf);
      trackerClient = new TrackerClient();
      trackerServer = trackerClient.getConnection();
      storageServer = null;
      storageClient = new StorageClient1(trackerServer, storageServer);
   }
   
   /**
    * 上传文件方法
    * <p>Title: uploadFile</p>
    * <p>Description: </p>
    * @param fileName 文件全路径
    * @param extName 文件扩展名,不包含(.)
    * @param metas 文件扩展信息
    * @return
    * @throws Exception
    */
   public String uploadFile(String fileName, String extName, NameValuePair[] metas) throws Exception {
      String result = storageClient.upload_file1(fileName, extName, metas);
      return result;
   }
   
   public String uploadFile(String fileName) throws Exception {
      return uploadFile(fileName, null, null);
   }
   
   public String uploadFile(String fileName, String extName) throws Exception {
      return uploadFile(fileName, extName, null);
   }
   
   /**
    * 上传文件方法
    * <p>Title: uploadFile</p>
    * <p>Description: </p>
    * @param fileContent 文件的内容,字节数组
    * @param extName 文件扩展名
    * @param metas 文件扩展信息
    * @return
    * @throws Exception
    */
   public String uploadFile(byte[] fileContent, String extName, NameValuePair[] metas) throws Exception {
      
      String result = storageClient.upload_file1(fileContent, extName, metas);
      return result;
   }
   
   public String uploadFile(byte[] fileContent) throws Exception {
      return uploadFile(fileContent, null, null);
   }
   
   public String uploadFile(byte[] fileContent, String extName) throws Exception {
      return uploadFile(fileContent, extName, null);
   }
}

3.2    测试

 

@Test
public void testFastDfsClient() throws Exception {
   FastDFSClient fastDFSClient = new FastDFSClient("F:\\javaeg\\1_test\\e3\\e3-manager-web\\src\\main\\resources\\conf\\client.conf");
   String string = fastDFSClient.uploadFile("G:\\1.jpg");
   System.out.println(string);
}

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值