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

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开始的,具体怎么控制文件名还没实现。

参考资源链接:[Nginx文件上传模块配置指南](https://wenku.csdn.net/doc/6412b739be7fbd1778d49874?utm_source=wenku_answer2doc_content) Nginxupload_module允许用户在HTTP服务器中直接上传文件,而upload_progress_module可以用来监控文件上传的进度。为了实现这一功能,你需要按照以下步骤操作: 首先,确保你下载的Nginx源码是支持第三方模块的版本。接着,下载upload_moduleupload_progress_module的源码,并解压到指定目录。 安装依赖库和工具,比如make、gcc、pcre、zlib等,然后编译Nginx并包含upload_moduleupload_progress_module模块。编译时,需要使用--add-module选项指定第三方模块的路径,例如: ```bash ./configure --add-module=/path/to/upload_module/src --add-module=/path/to/upload_progress_module/src make make install ``` 安装完成后,需要在Nginx的配置文件nginx.conf中添加upload_progress的配置段落,以便能够跟踪上传进度。以下是一个配置样例: ```nginx http { # ... 其他配置 ... # upload_progress模块配置 upload_progress uploads 1m; server { listen 80; server_***; location /upload/ { # 用于文件上传的location块 upload_progress uploads $binary_remote_addr $request_length; upload_store /path/to/uploads 1; upload_pass_form_field ^FILE.*; upload_set_form_field $upload_field_name.name 参考资源链接:[Nginx文件上传模块配置指南](https://wenku.csdn.net/doc/6412b739be7fbd1778d49874?utm_source=wenku_answer2doc_content)
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值