Nginx 搭建图片服务器

来自 | ITDragon龙
链接 | cnblogs.com/itdragon/p/7864916.html
本章内容通过Nginx 和 FTP 搭建图片服务器 。在学习本章内容前,请确保您的linux 系统已经安装了Nginx 和 Vsftpd 。
Nginx 安装
http://www.cnblogs.com/itdragon/p/7850985.html
Vsftpd 安装
http://www.cnblogs.com/itdragon/p/7857649.html
 
本章知识点效果图:

Nginx 搭建图片服务器

文章插图
需求:实现图片的上传和批量上传
技术:Nginx,Vsftpd,Spring,SpringMVC,KindEditor,centos
说明:本章节内容主要是实现图片的上传功能 。使用 KindEditer 是为了更好的演示图片的上传,回显,批量效果 。后台代码与KindEditer没有直接关系,放心阅读 。另外源码中有Mybatis的jar,不用理会,本章内容用不到,是为后续内容做准备!
源码:见文章底部
场景:用户将图片上传到 Tomcat 服务器上,再由 tomcat 服务器通过FTP上传到 Nginx 服务器上 。
Nginx 搭建图片服务器

文章插图
项目结构:
Nginx 搭建图片服务器

文章插图
 
单元测试首先要攻破核心技术 。通过单元测试实现图片上传的功能 。
public class PictureFTPTest { // 测试 ftp 上传图片功能 @Test public void testFtpClient throws Exception { // 1. 创建一个FtpClient对象 FTPClient ftpClient = new FTPClient; // 2. 创建 ftp 连接 ftpClient.connect("192.168.0.11", 21); // 3. 登录 ftp 服务器 ftpClient.login("ftpuser", "root"); // 4. 读取本地文件 FileInputStream inputStream = new FileInputStream(new File("F:\hello.png")); // 5. 设置上传的路径 ftpClient.changeWorkingDirectory("/usr/local/nginx/html/images"); // 6. 修改上传文件的格式为二进制 ftpClient.setFileType(FTP.BINARY_FILE_TYPE); // 7. 服务器存储文件,第一个参数是存储在服务器的文件名,第二个参数是文件流 ftpClient.storeFile("hello.jpg", inputStream); // 8. 关闭连接 ftpClient.logout; }}说明:这里的ip地址,端口,ftp用户名,密码,本地文件路径,以及Nginx服务器图片路径等,这些字符串参数都要根据自己实际设置的来填写的 。如果你的Nginx和Vsftpd安装是按照我提供的链接来做的 。那你只需要改ip地址即可 。
 
Maven 的Web 项目搭建Maven的Web 项目,之前有写过 。这里就不过多描述 。
 
项目核心配置文件首先是 Maven 的核心文件 pom.xml,添加下列对应版本的依赖即可,可前去https://mvnrepository.com/tags/maven 查找依赖 。
<junit.version>4.12</junit.version> <spring.version>4.1.3.RELEASE</spring.version> <mybatis.version>3.2.8</mybatis.version> <mybatis.spring.version>1.2.2</mybatis.spring.version> <mybatis.paginator.version>1.2.15</mybatis.paginator.version> <MySQL.version>5.1.6</mysql.version> <slf4j.version>1.6.4</slf4j.version> <jackson.version>2.4.2</jackson.version> <druid.version>1.0.9</druid.version> <httpclient.version>4.3.5</httpclient.version> <jstl.version>1.2</jstl.version> <servlet-api.version>2.5</servlet-api.version> <jsp-api.version>2.0</jsp-api.version> <joda-time.version>2.5</joda-time.version> <commons-lang3.version>3.3.2</commons-lang3.version> <commons-io.version>1.3.2</commons-io.version> <commons-net.version>3.3</commons-net.version> <pagehelper.version>3.4.2</pagehelper.version> <jsqlparser.version>0.9.1</jsqlparser.version> <commons-fileupload.version>1.3.1</commons-fileupload.version> <jedis.version>2.7.2</jedis.version> <solrj.version>4.10.3</solrj.version>说明:和文件上传有直接关系的是:
<dependency> <groupId>commons-fileupload</groupId> <artifactId>commons-fileupload</artifactId></dependency>然后是 Web 项目的核心文件 web.xml


推荐阅读