Springboot集成fastDFS配置過程解析
配置文件
配置fdfs_client.conf配置文件
# 連接超時(shí)時(shí)間,針對(duì)socket套接字函數(shù)connect,默認(rèn)為30秒
connect_timeout=30000
# 網(wǎng)絡(luò)通訊超時(shí)時(shí)間,默認(rèn)是60秒
network_timeout=60000
tracker_server = 47.98.159.15:22122
導(dǎo)入依賴
<dependency>
<groupId>org.csource</groupId>
<artifactId>fastdfs-client-java</artifactId>
<version>1.27-SNAPSHOT</version>
</dependency>
配置客戶端
package panda.data.Utils;
import org.csource.common.MyException;
import org.csource.fastdfs.*;
import org.slf4j.LoggerFactory;
import org.springframework.core.io.ClassPathResource;
import org.springframework.web.multipart.MultipartFile;
import java.io.IOException;
import java.util.stream.Stream;
/**
* @Auther: 羅羅
* @Description:
*/
public class FastDFSClient {
private static org.slf4j.Logger logger = LoggerFactory.getLogger(FastDFSClient.class);
public static String uploadImage(MultipartFile multipartFile) throws IOException, MyException {
// 1、初始化全局配置。加載一個(gè)配置文件。
String filePath = new ClassPathResource("fdfs_client.conf").getFile().getAbsolutePath();
ClientGlobal.init(filePath);
// 2、創(chuàng)建一個(gè)TrackerClient對(duì)象。
TrackerClient trackerClient = new TrackerClient();
// 3、創(chuàng)建一個(gè)TrackerServer對(duì)象。
TrackerServer trackerServer = trackerClient.getConnection();
// 4、聲明一個(gè)StorageServer對(duì)象,null。
StorageServer storageServer = null;
// 5、獲得StorageClient對(duì)象。
StorageClient storageClient = new StorageClient(trackerServer, storageServer);
byte[] bytes = multipartFile.getBytes();// 獲得上傳的二進(jìn)制對(duì)象
String[] strings = storageClient.upload_file(bytes, "jpg", null);
Stream.of(strings).forEach(System.out::println);
String imagurl = "http://47.98.159.35/"+strings[0]+"/"+strings[1];
//返回值0代表刪除成功
//int result = storageClient.delete_file("group1", "M00/00/00/wKgAaFyM3fSANCgXAABMnNm0e54098.jpg");
//System.out.println("result="+result);
return imagurl;
}
}
package panda.data.controller;
import org.csource.common.MyException;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.multipart.MultipartFile;
import panda.data.ResultData.ImgAttr;
import panda.data.ResultData.ResultData;
import panda.data.Utils.FastDFSClient;
import java.io.IOException;
import java.util.ArrayList;
@Controller
public class ImgController {
@Autowired
private ResultData resultData;
//必須是post方式
@PostMapping("/fileUpload")
@ResponseBody
public ResultData fileUpload(@RequestParam("file") MultipartFile multipartFile) throws IOException, MyException {
String url = FastDFSClient.uploadImage(multipartFile);
if (url.contains("group")){
resultData.setCode(0);
ImgAttr imgAttr = new ImgAttr(url);
ArrayList<Object> list = new ArrayList<>();
list.add(imgAttr);
resultData.setData(list);
}else {
resultData.setCode(0);
resultData.setData(null);
}
return resultData;
}
}
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
spring boot使用logback實(shí)現(xiàn)多環(huán)境日志配置詳解
這篇文章主要介紹了spring boot使用logback實(shí)現(xiàn)多環(huán)境日志配置詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2018-08-08
使用nacos實(shí)現(xiàn)自定義文本配置的實(shí)時(shí)刷新
我們都知道,使用Nacos時(shí),如果將Bean使用@RefreshScope標(biāo)注之后,這個(gè)Bean中的配置就會(huì)做到實(shí)時(shí)刷新,本文給大家介紹了如何使用nacos實(shí)現(xiàn)自定義文本配置的實(shí)時(shí)刷新,需要的朋友可以參考下2024-05-05
Java程序?qū)崿F(xiàn)導(dǎo)出Excel的方法(支持IE低版本)
下面小編就為大家?guī)硪黄狫ava程序?qū)崿F(xiàn)導(dǎo)出Excel的方法(支持IE低版本)。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-07-07
SpringBoot @Autowired注入為空的情況解讀
這篇文章主要介紹了SpringBoot @Autowired注入為空的情況解讀,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-03-03
Flink自定義Sink端實(shí)現(xiàn)過程講解
這篇文章主要介紹了Flink自定義Sink端實(shí)現(xiàn)過程,在Fink官網(wǎng)中sink端只是給出了常規(guī)的write api.在我們實(shí)際開發(fā)場(chǎng)景中需要將flink處理的數(shù)據(jù)寫入kafka,hbase kudu等外部系統(tǒng)2023-01-01
springboot集成普羅米修斯(Prometheus)的方法
這篇文章主要介紹了springboot集成普羅米修斯(Prometheus)的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08

