FastDFS实现文件上传下载实战
正好,淘淘商城讲这一块的时候,我又想起来当时老徐让我写过一个关于实现FastDFS实现文件上传下载的使用文档,当时结合我们的ITOO的视频系统和毕业论文系统,整理了一下,有根据网上查到的知识,总结了一点东西,下面分享一下
一、FastDFS简介:
参见博客:http://blog.csdn.NET/liweizhong193516/article/details/53234486
二、FastDFS使用流程介绍:
我们在itoo的dobbu+zk框架中使用fastdfs+nginx+MySQL实现上传附件的功能,主要原理就是将附件上传到fastdfs得到一个文件的链接路径url,我们获取到这个url将他以字符串形式保存到我们的mysql中,下载的时候获取到这个url直接打开或者下载附件。(url内容参见博客:http://blog.csdn.Net/liweizhong193516/article/details/52556526)
默认的,我们就知道fastdfs后面还有一个nginx服务器,当我们进行存储文件的时候,我们要通过fastdfs给我们生成一个保存地址,也就是grounpID 和保存地址,然后将文件已key-value方式存进nginx服务器中;当我们进行读取文件的时候,我们要通过获取mysql里面的相应文件的存储地址去nginx服务器中通过key,去取出我们的文件进行展示。(所以下载图,有点问题,在这里解释一下)
三、实现流程:
1、配置依赖:因为我们使用的maven来管理工程,所以,我们需要去陪pom文件
- <project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
- <modelVersion>4.0.0</modelVersion>
- <groupId>com.leech</groupId>
- <artifactId>fastdfs-demo</artifactId>
- <version>0.0.1-SNAPSHOT</version>
- <packaging>jar</packaging>
- <name>fastdfs-demo</name>
- <url>http://maven.apache.org</url>
- <properties>
- <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
- </properties>
- <dependencies>
- <dependency>
- <groupId>junit</groupId>
- <artifactId>junit</artifactId>
- <version>4.11</version>
- <scope>test</scope>
- </dependency>
- <dependency>
- <groupId>org.csource</groupId>
- <artifactId>fastdfs-client-java</artifactId>
- <version>1.25</version>
- </dependency>
- <dependency>
- <groupId>commons-io</groupId>
- <artifactId>commons-io</artifactId>
- <version>2.4</version>
- </dependency>
- </dependencies>
- </project>
当然,更多时候我们利用maven的继承特性,直接配置在父工程中,然后继承下来就o了。
2、新建fdfs_client.conf文件,在我们的itoo中,我们建立在(src/main/resources底下)
- connect_timeout = 2
- network_timeout = 30
- charset = UTF-8
- http.tracker_http_port = 80
- #没什么用
- http.anti_steal_token = no
- http.secret_key = FastDFS1234567890
- tracker_server = 192.168.17.112:22122
- #tracker_server = 192.168.0.119:22122
3、实现文件上传:
- public void save(HttpServletRequest request,HttpServletResponse response){
- String videoName=request.getParameter("videoName");
- String videoType=request.getParameter("videoType");
- String videoDesc=request.getParameter("videoDesc");
- String videoPath=request.getParameter("videoPath");
- String picturePath=request.getParameter("picturePath");
- SimpleDateFormat formatter = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
- Date uploadTime=null;
- try {
- uploadTime = formatter.parse(formatter.format(new Date()));
- } catch (ParseException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- JacksonJsonUntil jackJsonUtil =new JacksonJsonUntil ();
- String dataBaseName = "itoo_video";
- Video video=new Video();
- video.setUserName("why");
- video.setUserID("why");
- video.setVideoName(videoName);
- video.setVideoPath(videoPath);
- video.setVideoType(videoType);
- video.setVideoDesc(videoDesc);
- video.setDataBaseName(dataBaseName);
- video.setPicturePath(picturePath);
- video.setUploadTime(uploadTime);
- uploadFileService.save(video);
- jackJsonUtil.beanToJson(response,video);
- }
- /*
- * 上传文件
- */
- @RequestMapping(value={"/upload"})
- @ResponseBody
- public void upload( MultipartFile file, HttpServletRequest request,HttpServletResponse response){
- String ext_Name = file.getOriginalFilename().split("\\.")[1];
- String videoName=file.getOriginalFilename().split("\\.")[0];
- byte[] bytes = null;
- try {
- bytes = file.getBytes();
- } catch (IOException e) {
- e.printStackTrace();
- }
- String videoPath=uploadFile(bytes,ext_Name);
- JacksonJsonUntil jackJsonUtil =new JacksonJsonUntil ();
- Video video=new Video();
- video.setVideoPath(videoPath);
- video.setVideoName(videoName);
- jackJsonUtil.beanToJson(response,video);
- }
- public String uploadFile(byte[] byteFile, String ext_file) {
- // 拼接服务区的文件路径
- StringBuffer sbPath = new StringBuffer();
- sbPath.append("http://192.168.22.252");
- try {
- // 初始化文件资源
- ClientGlobal
- .init("C:\\Users\\alsr\\Desktop\\ITOO-5.0\\itoo-video-Test\\dmsd-itoo-video-parent\\dmsd-itoo-video-web\\src\\main\\resources\\fdfs_client.conf");
- // 链接FastDFS服务器,创建tracker和Stroage
- TrackerClient trackerClient = new TrackerClient();
- TrackerServer trackerServer = trackerClient.getConnection();
- StorageServer storageServer = null;
- StorageClient storageClient = new StorageClient(trackerServer,
- storageServer);
- //利用字节流上传文件
- String[] strings = storageClient.upload_file(byteFile, ext_file, null);
- for (String string : strings) {
- sbPath.append("/" + string);
- System.out.println(string);
- }
- // 全路径
- System.out.println(sbPath);
- } catch (IOException | MyException e) {
- e.printStackTrace();
- }
- return sbPath.toString();
- }
只要我们能正常接收到一个json类型的字符串(url地址),就证明我们已经上传成功了,如果不信,可以直接用浏览器去验证一下,看看能不能得到文件展示。
4、FastDFS实现文件下载:
- public void testDownload() {
- try {
- ClientGlobal.init(conf_filename);
- TrackerClient tracker = new TrackerClient();
- TrackerServer trackerServer = tracker.getConnection();
- StorageServer storageServer = null;
- StorageClient storageClient = new StorageClient(trackerServer, storageServer);
- byte[] b = storageClient.download_file("group1", "M00/00/00/wKgRcFV_08OAK_KCAAAA5fm_sy874.conf");
- System.out.println(b);
- IOUtils.write(b, new FileOutputStream("D:/"+UUID.randomUUID().toString()+".conf"));
- }
- catch (Exception e) {
- e.printStackTrace();
- }
- }
5、FastDFS获取将上传文件信息:
- public void testGetFileInfo(){
- try {
- ClientGlobal.init(conf_filename);
- TrackerClient tracker = new TrackerClient();
- TrackerServer trackerServer = tracker.getConnection();
- StorageServer storageServer = null;
- StorageClient storageClient = new StorageClient(trackerServer, storageServer);
- FileInfo fi = storageClient.get_file_info("group1", "M00/00/00/wKgRcFV_08OAK_KCAAAA5fm_sy874.conf");
- System.out.println(fi.getSourceIpAddr()); System.out.println(fi.getFileSize());
- System.out.println(fi.getCreateTimestamp()); System.out.println(fi.getCrc32());
- }
- catch (Exception e) {
- e.printStackTrace();
- }
- }
6、FastDFS获取文件名称:
- public void testGetFileMate(){
- try {
- ClientGlobal.init(conf_filename);
- TrackerClient tracker = new TrackerClient();
- TrackerServer trackerServer = tracker.getConnection();
- StorageServer storageServer = null;
- StorageClient storageClient = new StorageClient(trackerServer,
- storageServer);
- NameValuePair nvps [] = storageClient.get_metadata("group1", "M00/00/00/wKgRcFV_08OAK_KCAAAA5fm_sy874.conf");
- for(NameValuePair nvp : nvps){
- System.out.println(nvp.getName() + ":" + nvp.getValue());
- }
- }
- catch (Exception e) {
- e.printStackTrace();
- }
- }
7、FastDFS实现删除文件:
- public void testDelete(){
- try {
- ClientGlobal.init(conf_filename);
- TrackerClient tracker = new TrackerClient();
- TrackerServer trackerServer = tracker.getConnection();
- StorageServer storageServer = null;
- StorageClient storageClient = new StorageClient(trackerServer,storageServer);
- int i = storageClient.delete_file("group1", "M00/00/00/wKgRcFV_08OAK_KCAAAA5fm_sy874.conf");
- System.out.println( i==0 ? "删除成功" : "删除失败:"+i);
- }
- catch (Exception e) {
- e.printStackTrace();
- }
- }
转载于:https://www.cnblogs.com/DoubleEggs/p/6083465.html
FastDFS实现文件上传下载实战相关推荐
- springboot文件上传下载实战 ——文件上传、下载、在线打开、删除
springboot文件上传下载实战 文件上传 文件上传核心 UserFileController 文件上传测试 文件下载与在线打开 文件下载.在线打开核心 UserFileController 文件 ...
- springboot文件上传下载实战 —— 登录功能、展示所有文件
springboot文件上传下载实战 创建项目 pom.xml 数据库建表与环境准备 建表SQL 配置文件 application.properties 整体架构 前端页面 登录页面 login.ht ...
- fastdfs实现文件上传下载的通用方法
首先这里依赖的是: <dependency><groupId>net.oschina.zcx7878</groupId><artifactId>fast ...
- SpringMVC整合fastdfs-client-java实现web文件上传下载
为什么80%的码农都做不了架构师?>>> 版权声明:本文为博主原创文章,转载请标明出处(http://blog.csdn.net/wlwlwlwl015)Thanks. 目录( ...
- Django实战之文件上传下载
项目介绍 最近学习django,通过文件上传下载这个小项目,总结下常用的知识点. 做这个案例我有以下需求: 1.要支持一次上传多个文件 2.支持上传后记录上传的数据以及列表展示 3.支持下载和删除文件 ...
- centos nfs java_CentOS下安装配置NFS并通过Java进行文件上传下载
1:安装NFS (1)安装 yum install nfs-utils rpcbind (2)启动rpcbind服务 systemctl restart rpcbind.service 查看服务状态 ...
- 渗透测试-文件上传/下载/包含
渗透测试-文件上传/下载/包含 概述 一.常见校验上传文件的方法 客户端校验 服务器端校验 1.校验请求头 content-type字段 2. 正则匹配来判断文件幻数(文件头)内容是否符合要求 3. ...
- 项目_功能模块_基于Spring Boot的文件上传下载功能的设计与实现
文章目录 基于Spring Boot的文件上传下载功能模块的设计与实现 1.前言 2.技术栈 3.关键源码 4.实现效果 4.1.登录 4.2.文件列表 4.3.上传文件测试 4.3.1.测试图片 4 ...
- 【Java编程系列】Minio实现文件上传下载
热门系列: [Java编程系列]Amazon S3实现文件上传下载 目录 热门系列: 1.前言 2.Minio实战代码 2.1 Minio环境部署 2.2 Minio的Sdk对接实现 2.2.1 Mi ...
最新文章
- 会员管理scrm系统精细化运营更好促进成交
- python3语法错误-python-使用Python 3打印时出现语法错误
- 初等数论--同余--MILLER-RABIN素性检测算法
- GPTEE中定义的RSA的Algorithm Identifier详解
- SQLite 3 一些基本的使用
- 最近工程师怎么都在写公众号?这玩意到底能赚多少钱?
- 单片机中断机制对日常生活的启示_单片机原理部分课后习题解
- mysql innodb row_format_INNODB物理行结构(ROW_FORMAT=COMPACT) | 学步园
- Codeforces Round #381 (Div. 2) D. Alyona and a tree 树上二分+前缀和思想
- (Windows) CodeBlocks 下载
- 视频教程 C语言全套视频教程(已更新完毕
- 计算机bios设置翻译,bios设置中文翻译的操作教程
- rabbitmq,stomp.js,rabbitmq-auth-backend-http,消息调研,消息设计
- FLUKE高端时域反射OTDR OFP-100-Q上线
- 开源电子书项目FBReader初探(一)
- 天大、中南、中山、北师、中科院地图学与地理信息系统GIS及遥感RS专业推免夏令营面试经历与题目汇总
- 揪心!河南极端暴雨突袭,多地受灾严重!加油,河南
- 走近“领域特定语言”(Domain-Specific Languages)
- ZooKeeper知识点整理
- 西瓜播放器xgplayer设置自动播放
热门文章
- 前端性能优化-CSS性能优化
- maven依赖循环引用_maven-2 – Maven命令在本地安装远程依赖项
- java 项目 q a 表设计_《JAVA程序设计项目案例训练》期末试卷(A卷)..doc
- Maven父工程(统一管理依赖)
- 半导体物理载流子浓度计算思考(统计物理的重要应用)
- 《打开量化投资的黑箱》 阅读笔记
- 一维非稳态对流扩散——显示格式+QUICK格式,左、右边界定壁温的Python程序
- python读取数据方法
- Opencv边缘检测、轮廓发现、绘制轮廓
- C++:团体程序设计天梯赛( 谁先倒)