news 2026/4/22 15:51:40

nginx服务器实现上传文件功能_使用nginx-upload-module模块

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
nginx服务器实现上传文件功能_使用nginx-upload-module模块
目录
  • conf文件内容如下
  • html文件内容如下
  • 上传文件功能展示

conf文件内容如下

#user nobody; worker_processes 1; error_log /usr/logs/error.log; #error_log /usr/logs/error.log notice; #error_log /usr/logs/error.log info; #pid /usr/logs/nginx.pid; events { worker_connections 1024; } http { include mime.types; default_type application/octet-stream; sendfile on; keepalive_timeout 65; server { listen 80; server_name localhost; client_max_body_size 100m; location / { root /root/nginxShare; index uploadfile.html uploadfile.htm; # 这会使得在访问根目录时默认展示 uploadfile.html } error_page 405 =200 @405; # 配置上传位置 location /upload { if ($request_method = 'GET'){ root /root/nginxShare; } if ($request_method = 'POST'){ upload_pass @test; # 指定上传完成后请求的处理位置 # upload_store /root/nginxShare/upload 1; # 数字1表示启用了一种特殊的文件存储机制,即分散存储 upload_store /root/nginxShare/upload; upload_store_access user:rw; #上传文件的权限,rw表示读写 r只读 #这里写入http报头,pass到后台页面后能获取这里set的报头字段 upload_set_form_field "${upload_field_name}_name" $upload_file_name; upload_set_form_field "${upload_field_name}_content_type" $upload_content_type; upload_set_form_field "${upload_field_name}_path" $upload_tmp_path; #Upload模块自动生成的一些信息,如文件大小与文件md5值 upload_aggregate_form_field "${upload_field_name}_md5" $upload_file_md5; upload_aggregate_form_field "${upload_field_name}_size" $upload_file_size; upload_pass_form_field "^submit$|^description$"; upload_cleanup 400 404 499 500-505; #如果pass页面是以下状态码,就删除此次上传的临时文件 } } # 处理上传完成后的请求 location @test { # 这里可以配置代理到后端服务,或者直接返回响应 # 例如,返回一个简单的文本响应 return 200 'File uploaded successfully!20241104'; # 或者代理到某个后端服务处理上传后的逻辑 # proxy_pass http://localhost:7123;; } } server { listen 9000; server_name localhost; client_max_body_size 100m; charset gbk,utf-8; root /root/nginxShare; location / { auth_basic "Restricted"; autoindex on; autoindex_exact_size on; autoindex_localtime on; } } }

html文件在/root/nginxShare目录下。
上传的文件存放在/root/nginxShare/upload目录下。
上传成功会返回一个文本响应,文本内容为:File uploaded successfully!20241104

html文件内容如下

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>文件上传测试</title> </head> <body> <h2>文件上传</h2> <form action="/upload" method="post" enctype="multipart/form-data"> <input type="file" name="file" required> <br> <input type="submit" value="上传"> </form> </body> </html>

上传文件功能展示

运行nginx服务器

mkdir -p /var/log/nginx /var/tmp/nginx ./sbin/nginx -c /etc/nginx/nginx.conf

在浏览器输入:192.168.61.61::80
显示页面如下:

点击选择文件,选择本地文件,点击上传后,会弹出如下页面:

下载该文件后,查看文件内容:

可以看到,文本内容符合预期,接着我们查看/root/nginxShare/upload目录

可以看到,文件已上传成功,不过文件的名字是从1开始的,具体怎么控制文件名还没实现。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 9:45:20

嵌入式开发中arm64编译x64应用手把手教程

在ARM64上编译x64程序&#xff1a;一场跨越架构的工程实践你有没有遇到过这样的场景&#xff1f;手头只有一台基于Apple M1芯片的工作站&#xff0c;或者一块树莓派5开发板——它们都是ARM64架构。但你要构建的应用却必须运行在x86_64服务器上&#xff0c;比如要打包一个只能在…

作者头像 李华
网站建设 2026/4/18 11:17:52

u8g2中自定义字体嵌入的实战案例

让你的嵌入式界面“有颜有料”&#xff1a;u8g2自定义字体实战全解析你有没有遇到过这样的情况&#xff1f;项目快上线了&#xff0c;老板看了一眼OLED屏幕上的显示效果&#xff0c;皱着眉头说&#xff1a;“这字太普通了&#xff0c;不像我们品牌调性。” 或者用户反馈&#x…

作者头像 李华
网站建设 2026/4/18 1:34:01

在GIS中使用ggplot2绘制坐标点和Shapefile

在地理信息系统(GIS)中,常见的一个需求是将坐标点绘制在地图上。这不仅可以帮助我们可视化数据分布,也能对数据进行空间分析。本文将通过一个具体的实例,展示如何在R语言中使用ggplot2包结合sf包,将坐标数据点绘制在Shapefile之上。 背景介绍 假设我们有以下情况: 坐标…

作者头像 李华
网站建设 2026/4/18 11:32:34

深度解析:AI提示系统技术架构中的多轮对话管理设计

深度解析&#xff1a;AI提示系统技术架构中的多轮对话管理设计 摘要/引言 在当今人工智能飞速发展的时代&#xff0c;AI提示系统广泛应用于聊天机器人、智能客服等诸多场景。多轮对话管理作为AI提示系统技术架构的关键组成部分&#xff0c;直接影响着用户体验和系统的实用性。本…

作者头像 李华
网站建设 2026/4/22 6:42:36

基于云平台的手机远程控制LED屏系统构建

手机远程控制LED屏&#xff1f;这套云架构方案让运维效率翻倍&#xff01;你有没有遇到过这样的场景&#xff1a;城市多处的广告大屏需要紧急更换内容&#xff0c;但每块屏幕都得派人现场操作&#xff1b;或是连锁门店的滚动字幕想统一更新促销信息&#xff0c;却因为分布太广而…

作者头像 李华