搭建一个文件服务器的方式有很多,本文介绍笔者曾经用过的两种:

  • 使用nginx
  • 使用java服务,通过controller提供

一、使用nginx搭建

在nginx.conf中直接配置server即可,示例代码如下:

user felice felice;
worker_processes auto;
master_process on;
pid log/nginx.pid; error_log log/error.log warn;
error_log log/info.log info; events {
worker_connections ;
} http {
server_tokens off; client_header_buffer_size 8k;
client_max_body_size 130m;
proxy_buffer_size 64k;
proxy_buffers 64k; log_format access '$remote_addr $host $remote_user [$time_local] $status $request_length $body_bytes_sent $request_time 0 0 0 - "-" "$request" "$http_referer" "$http_user_agent" $http_cookie $bytes_sent';
access_log log/access.log access; keepalive_requests ;
keepalive_timeout ; server {
listen ;
server_name localhost;
charset utf-; location / {
default_type 'application/octet-stream';
add_header Content-disposition "attachment";
root /User/sonofelice/mm;
}
} }

启动nginx之后,通过请求下面的url就可以下载/User/sonofelice/mm目录下的文件了:

http://127.0.0.1:8123/fileName

在host:port/后面直接跟对应目录下的文件名称即可。

如果强制浏览器下载文件,而不是进行json解析后直接显示内容,需要设置header选项

add_header Content-disposition "attachment";

注意,在nginx.conf中需要设置用户以及用户组,否则可能对本地目录没有操作权限,可以通过ls -ld命令查看当前用户以及用户组:

我的有用户名为baidu,用户组为staff

二、使用java服务

使用java的controller提供文件下载也非常简单,可以用下面的几行代码搞定:

@RestController
@RequestMapping("/")
@Slf4j
public class FileDownloadController { @RequestMapping(method = RequestMethod.GET, value = "/{fileName}")
public void downloadFile(@PathVariable String fileName, HttpServletResponse response) {
Path file = Paths.get(fileName);
if (Files.exists(file)) {
response.setContentType("application/zip");
try {
response.addHeader("Content-Disposition", "attachment; filename=" + URLEncoder.encode(fileName, "UTF-8"));
Files.copy(file, response.getOutputStream());
} catch (IOException e) {
log.error("File download error:", e);
}
}
}
}

在启动java服务之后,也可以通过第一节中的方式请求url进行文件的下载。

只传入文件名即可。当然,上面的contentType设置的是zip,如果不确定文件的格式,可以使用

application/octet-stream

HTTP Content-type常用对照表参考: http://tool.oschina.net/commons

使用nginx搭建文件下载服务器的更多相关文章

  1. Nginx 搭建图片服务器

    Nginx 搭建图片服务器 本章内容通过Nginx 和 FTP 搭建图片服务器.在学习本章内容前,请确保您的Linux 系统已经安装了Nginx和Vsftpd. Nginx 安装:http://www ...

  2. Varnish,Nginx搭建缓存服务器

    Varnish,Nginx搭建缓存服务器 一. varnish 1.安装pcre库,兼容正则表达式 # tar -zxvf pcre-8.10.tar.gz # cd pcre-8.10 # ./co ...

  3. Nginx搭建图片服务器

    Nginx搭建图片服务器 标签(空格分隔): linux,nginx Nginx常用命令 ./nginx 启动 ./nginx -s reload 重载配置文件 ./nginx -s stop|sta ...

  4. windows环境下基于nginx搭建rtmp服务器

    基于nginx搭建rtmp服务器需要引入rtmp模块,引入之后需重新编译nginx linux环境几个命令行就能实现编译,笔者未尝试,网上有很多教程. windows环境还需要安装一系列的编译环境,例 ...

  5. nginx 搭建图片服务器(windows 下,linux 下原理应该一样)

    作者的心声:很多知道的.用过的东西,不写下来,下次还要百度查询,浪费时间和精力,故本次写下学习笔记,方便下次查阅. 题外话:如有读者通过我这篇博客解决了工作上的难题,可以给个评论,让我一起分享你的喜悦 ...

  6. Nginx,Nginx 搭建图片服务器

    Nginx Nginx 概述 反向代理 工作流程 优点 1:保护了真实的web服务器,保证了web服务器的资源安全 2:节约了有限的IP地址资源 3:减少WEB服务器压力,提高响应速度 4:其他优点 ...

  7. 轻松使用Nginx搭建web服务器

    如果读者以前做过web开发的话,就应该知道如何去搭建一个web服务器来跑你的web站点,在windows下你可能会选择去用IIS,十分的快捷,在linux下,你可能首先会想到apache,“一哥”( ...

  8. ubuntu下使用nginx搭建流媒体服务器,实现视频点播

    首先我们看如何实现视频点播,视频点播支持flv文件及H264编码视频,ACC编码音频的mp4文件: 第一步,创建单独的目录(因为软件较多,容易混乱),下载需要的软件: 我们需要下载nginx,pcre ...

  9. Windows环境下用jwplayer+Nginx搭建视频点播服务器

    flv视频可以采用两种方式发布: 一.普通的HTTP下载方式 二.基于Flash Media Server或Red5服务器的rtmp/rtmpt流媒体方式. 多数知名视频网站都采用的是前一种方式. 两 ...

随机推荐

  1. C#使用SendMessage传递字符串

    来源:http://www.cnblogs.com/sizzle/archive/2007/08/29/874796.html 正文: 在C#中使用SendMessage,原本以为很简单的事,却处处碰 ...

  2. [gpio]Linux GPIO简单使用方式1-sysfs

    转自:http://blog.csdn.net/drivermonkey/article/details/20132241 1.1.References 1.2.GPIO Usage from a L ...

  3. eclipse不能自动编译生成class文件的解决办法

    最近在项目项目开发过程中遇到eclipse不能自动编译生成class文件,当时很纳闷,每次修改代码后运行都是修改前的效果,没辙了,只好反编译原来的class文件,结果发现,class文件里并没有看到修 ...

  4. 一种基于匹配回朔的 css3 选择器引擎实现

    介绍 CSS 选择器是一种应用于 DOM 节点查找场景的特定微型语法, 本质上和正则表达式一样都是一种模式匹配语言,灵活使用可以方便得获取指定位置的节点集合. 目前 W3C 推荐标准为 Selecto ...

  5. 【BZOJ】1637: [Usaco2007 Mar]Balanced Lineup(前缀和+差分+特殊的技巧)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1637 很神思想.. 前缀和应用到了极点... 我们可以发现当数量一定时,这个区间最前边的牛的前边一个 ...

  6. Leetcode_num4_Reverse Integer

    题目: Reverse digits of an integer. Have you thought about this? Here are some good questions to ask b ...

  7. html的a标签的 href 和 onclick。

    主要用于给超链接添加点击事件. aa.html <html> <body> <span>this si</span> </body> < ...

  8. remote指令添加远程数据库

    git remote add <name> <url> git remote add origin https://[your_space_id].backlogtool.co ...

  9. Node.js的全局对象和全局变量

    http://blog.csdn.net/leftfist/article/details/41877279

  10. 去除 \ufeff

    语言:python 编程工具:pycharm 硬件环境:win10 64位 读取文件过程中发现一个问题:已有记事本文件(非空),转码 UTF-8,复制到pycharm中,在开始位置打印结果会出现  \ ...