百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

Nodejs实战篇-上传文件、文件夹 nodejs上传文件有哪几种

bigegpt 2024-10-08 00:53 18 浏览

目标:

上传文件、文件夹

给你三秒钟,思考下可能用到哪些知识点

前期准备

1.1 整体流程

1. index.js模块: 程序入口, 有服务器(server.js)和路由(route.js)和处理(handler.js)模块组成;

2. server.js模块: 专门处理不同路由, 并做相应的处理;

3. route.js模块: 请求的地址, 处理方法, 响应, 请求;

4. handler.js模块: 封装不同的方法,交由路由route.js模块来选择调用;

5. HTML文件: 存在HTML文件; 6. package.json模块: CommonJS规定的规范;

我想这个不同于理论的实践,会慢慢为接下来打下坚实的基础的。

1.2 模块包

formidable是一个用于处理文件、图片、视频等数据上传的模块,支持GB级上传数据处理,支持多种客户端数据提交。有极高的测试覆盖率,非常适合在生产环境中使用。

npm配置安装

npm install formidable@latest

util是一个Node.js核心模块,util模块设计的主要目的是为了满足Node内部API的需求。其中包括:格式化字符串、对象的序列化、实现对象继承等常用方法。要使用util模块中的方法,只需require('util')引入即可。

1.3 package.json文件

package.json:定义了这个项目所需要的各种模块,以及项目的配置信息(比如名称、版本、许可证等元数据)。npm install命令根据这个配置文件,自动下载所需的模块.

1. scripts指定了运行脚本命令的npm命令行缩写,比如start指定了运行npm run start时,所要执行的命令。

2. dependencies字段指定了项目运行所依赖的模块;

3. devDependencies指定项目开发所需要的模块。

指定版本:比如1.2.2,遵循“大版本.次要版本.小版本”的格式规定,安装时只安装指定版本。

波浪号(tilde)+指定版本:比如~1.2.2,表示安装1.2.x的最新版本(不低于1.2.2),但是不安装1.3.x,也就是说安装时不改变大版本号和次要版本号。

插入号(caret)+指定版本:比如?1.2.2,表示安装1.x.x的最新版本(不低于1.2.2),但是不安装2.x.x,也就是说安装时不改变大版本号。

需要注意的是,如果大版本号为0,则插入号的行为与波浪号相同,这是因为此时处于开发阶段,即使是次要版本号变动,也可能带来程序的不兼容。 latest:安装最新版本。

例子如下:

{

"name": "upload",

"version": "1.0.1",

"description": "文件上传下载",

"main": "index.js",

"scripts": {

"start": "node index.js"

},

"author": "hhw",

"license": "ISC"

//依赖模块

"dependencies": {

"formidable":"formidable@1.0.17",

},

}

第二部分 代码实现部分

2.1 服务器server.js代码实现

//引入http utl 模块

var http = require('http');

var url = require('url');

//程序入口, 选择路由, 并做相应的处理

function start(route, handler){

//选择路由

function onRequest(request, response) {

//url.parse(): 输入 URL 字符串,返回一个对象。

//对象中 pathname 所代表的路径

var pathname = url.parse(request.url).pathname;

route(pathname, handler, response, request);

}

//服务器对不同的路由做出不同的响应

http.createServer(onRequest).listen(3000);

}

//导出接口

exports.start = start;

2.2 路由选择代码

//具体处理路由的功能模块

//请求的地址, 处理方法<upload download...>, 响应, 请求

function route(pathname, handler, response, request){

//如果请求的方法是存在的函数就返回交给服务器处理

if (typeof handler[pathname] === 'function'){

return handler[pathname](request, response);

} else{

//否则返回404

response.writeHead(404, {'Content-Type': 'text/html'});

response.write('404 Not Found!');

response.end();

}

}

exports.route = route;

2.3 具体处理不同需求的代码实现

node-formidable

//解析字符串, fs模块, 格式化模块

var fs = require('fs'),

formidable = require('formidable'),

util = require('util'),

http = require('http');

const path = require('path');

//程序入口展示HTML文件

function home(request, response){

//加载本地页面HTML

fs.readFile('./index.html', function(err, data) {

response.writeHead(200, {'Content-Type': 'text/html'});

response.write(data);

response.end();

});

}

//formidable是一个用于处理文件、图片、视频等数据上传的模块,支持GB级上传数据处理,支持多种客户端数据提交。有极高的测试覆盖率,非常适合在生产环境中使用。

function uploads(request, response) {

//form表单

var form = new formidable.IncomingForm();

//保留后缀

form.keepExtensions = true;

form.encoding = 'utf-8';

//上传的数据保存的路径

form.uploadDir = './';

//该方法会转换请求中所包含的表单数据,callback会包含所有字段域和文件信息

// fields 是普通表单数据

// files 是文件数据

form.parse(request, function(err, fields, files) {

response.writeHead(200, {'Content-type': 'text/plain'});

//上传文件的名称

var filename = files.upload.name;

var path = files.upload.path;

//更改名称

fs.rename(path, form.uploadDir + filename);

//响应 格式化打印

response.end(util.inspect(form));

});

}

function show (response, request) {

console.log('show module');

fs.readFile ('/tmp/test.png ', 'binary', function (error, file) {

if (error) {

response.writeHead(200, {'Content-Type': 'text/html'});

response.write(error);

response.end();

} else {

response.writeHead(200, {'Content-Type': 'image/png'});

response.write(file, 'binary');

response.end();

}

});

}

function downloads(requset, response){

//node官网图标

var URL = "http://nodejs.cn/static/images/logos/nodejs-green.png";

//request

request

.get(URL)

//监听response

.on('response', function(res) {

console.log(res.statusCode); // 200

console.log(res.headers['content-type']); // 'image/png'

console.log(res.headers['content-length']);

//打印接受的数据大小

res.on('data', function(data){

console.log('接受到数据' + data.length )

})

})

//监听错误信息

.on('error', function(error){

consloe.log(error);

})

//以流的形式写入创建的test.png文件

.pipe(fs.createWriteStream('test.png'));

response.writeHead(200);

response.write('请前往同级目录下查看下载内容');

response.end();

}

exports.home = home;

exports.upload = uploads;

exports.download = downloads;

2.4 程序入口调用<待补充>

//引用模块

var server = require('./server');

var router = require('./router');

var handler = require('./handler');

var formidable = require('formidable');

//调用具体方法

var method = {};

method['/'] = handler.home;

method['/home'] = handler.home;

method['/upload'] = handler.upload;

//交给服务器模块处理

server.start(router.route, method);

2.5 首页中上传模块HTML文件 <待补充>

最早的HTTP协议中是不支持文件上传的,在1995年制定的rfc1867规范中,在HTTP POST请求的内容类型Content-Type

中扩展了multipart/form-data

类型,该类型用于向服务器发送二进制数据,以便支持文件的上传。

<html>

<head>

<meta charset="UTF-8">

<title>Document</title>

</head>

<body>

//上传文件时需要通过enctype

属性将编码方式设置为multipart/form-data

<form action="/upload", enctype="multipart/form-data" method="post">

<input type="file" name="upload" multiple="multipart">

<input type="submit" value="提888交">

</form>

<form action="/download", enctype="multipart/form-data" method="get">

<input type="submit" value='下载'>

</form>

</body>

</html>

相关推荐

pyproject.toml到底是什么东西?(py trim)

最近,在Twitter上有一个Python项目的维护者,他的项目因为构建失败而出现了一些bug(这个特别的项目不提供wheel,只提供sdist)。最终,发现这个bug是由于这个项目使用了一个pypr...

BDP服务平台SDK for Python3发布(bdp数据平台)

下载地址https://github.com/imysm/opends-sdk-python3.git说明最近在开发和bdp平台有关的项目,用到了bdp的python的sdk,但是官方是基于p...

Python-for-Android (p4a):(python-for-android p4a windows)

一、Python-for-Android(p4a)简介Python-for-Android(p4a),一个强大的开发工具,能够将你的Python应用程序打包成可在Android设备上运行...

Qt for Python—Qt Designer 概览

前言本系列第三篇文章(QtforPython学习笔记—应用程序初探)、第四篇文章(QtforPython学习笔记—应用程序再探)中均是使用纯代码方式来开发PySide6GUI应用程序...

Python:判断质数(jmu-python-判断质数)

#Python:判断质数defisPrime(n):foriinrange(2,n):ifn%i==0:return0re...

为什么那么多人讨厌Python(为什么python这么难)

Python那么棒,为什么那么多人讨厌它呢?我整理了一下,主要有这些原因:用缩进替代大括号许多人抱怨Python完全依赖于缩进来创建代码块,代码多一点就很难看到函数在哪里结束,那么你就需要把一个函数拆...

一文了解 Python 中带有 else 的循环语句 for-else/while-else

在本文中,我们将向您介绍如何在python中使用带有else的for/while循环语句。可能许多人对循环和else一起使用感到困惑,因为在if-else选择结构中else正常...

python的numpy向量化语句为什么会比for快?

我们先来看看,python之类语言的for循环,和其它语言相比,额外付出了什么。我们知道,python是解释执行的。举例来说,执行x=1234+5678,对编译型语言,是从内存读入两个shor...

开眼界!Python遍历文件可以这样做

来源:【公众号】Python技术Python对于文件夹或者文件的遍历一般有两种操作方法,一种是至二级利用其封装好的walk方法操作:import osfor root,d...

告别简单format()!Python Formatter类让你的代码更专业

Python中Formatter类是string模块中的一个重要类,它实现了Python字符串格式化的底层机制,允许开发者创建自定义的格式化行为。通过深入理解Formatter类的工作原理和使用方法,...

python学习——038如何将for循环改写成列表推导式

在Python里,列表推导式是一种能够简洁生成列表的表达式,可用于替换普通的for循环。下面是列表推导式的基本语法和常见应用场景。基本语法result=[]foriteminite...

详谈for循环和while循环的区别(for循环语句与while循环语句有什么区别)

初九,潜龙勿用在刚开始使用python循环语句时,经常会遇到for循环和while循环的混用,不清楚该如何选择;今天就对这2个循环语句做深入的分析,让大家更好地了解这2个循环语句以方便后续学习的加深。...

Python编程基础:循环结构for和while

Python中的循环结构包括两个,一是遍历循环(for循环),一是条件循环(while循环)。遍历循环遍历循环(for循环)会挨个访问序列或可迭代对象的元素,并执行里面的代码块。foriinra...

学习编程第154天 python编程 for循环输出菱形图

今天学习的是刘金玉老师零基础Python教程第38期,主要内容是python编程for循环输出菱形※。(一)利用for循环输出菱形形状的*号图形1.思路:将菱形分解为上下两个部分三角形图案,分别利用...

python 10个堪称完美的for循环实践

在Python中,for循环的高效使用能显著提升代码性能和可读性。以下是10个堪称完美的for循环实践,涵盖数据处理、算法优化和Pythonic编程风格:1.遍历列表同时获取索引(enumerate...