ホームページ > ウェブフロントエンド > フロントエンドQ&A > Nodejsでデータをアップロードする方法

Nodejsでデータをアップロードする方法

PHPz
リリース: 2023-05-24 10:57:36
オリジナル
921 人が閲覧しました

Node.js は、高性能、スケーラブル、拡張可能な Web アプリケーションを構築するために一般的に使用される効率的なサーバーサイド JavaScript インタープリターです。 Node.js では、データのアップロードは一般的なタスクの 1 つであり、主に HTTP リクエストとファイルのアップロードを通じて実現されます。

この記事では、ファイルのアップロードやフォームデータのアップロードなど、Node.js でデータをアップロードするメソッドの実装方法を紹介します。

1. Node.js アップロード ファイル

Node.js では、multipart/form-data フォームを介してファイルをアップロードするのが一般的な方法です。このアプローチにより、さまざまなタイプやサイズのファイルをアップロードし、サーバー側に保存することができます。ファイルをアップロードする簡単な例を次に示します。

const http = require('http');
const fs = require('fs');
const formidable = require('formidable');

http.createServer(function (req, res) {
    if (req.url == '/upload' && req.method.toLowerCase() == 'post') {
        var form = new formidable.IncomingForm();
        form.parse(req, function (err, fields, files) {
            var oldpath = files.filetoupload.path;
            var newpath = 'C:/Users/Username/' + files.filetoupload.name;
            fs.rename(oldpath, newpath, function (err) {
                if (err) throw err;
                res.write('File uploaded and moved!');
                res.end();
            });
        });
    } else {
        res.writeHead(200, {'Content-Type': 'text/html'});
        res.write('<form action="upload" method="post" enctype="multipart/form-data">');
        res.write('<input type="file" name="filetoupload"><br>');
        res.write('<input type="submit">');
        res.write('</form>');
        return res.end();
    }
}).listen(8080);
ログイン後にコピー

上記のコードは、アップロードされたファイルの処理に役立つ Node.js の強力なモジュールを使用しています。このコードでは、サーバーを作成してアドレスをリッスンし、ファイルをアップロードするときに、formidable の IncomingForm() メソッドを呼び出し、parse() メソッドを通じてアップロードされたデータを解析します。

アップロードが成功したら、ファイルの一時パス (oldpath) を新しいパス (newpath) に移動し、エラーが発生した場合は例外をスローします。

2. Node.js でフォーム データをアップロードする

Node.js では、ファイルをアップロードする必要がなく、フォーム データのみをアップロードする必要がある場合は、次のメソッドを使用できます。 ##

const http = require('http');

http.createServer(function (req, res) {
    if (req.url == '/upload' && req.method.toLowerCase() == 'post') {
        var body = '';
        req.on('data', function (data) {
            body += data;
        });
        req.on('end', function () {
            var post = qs.parse(body);
            console.log(post);
            res.writeHead(200, {'Content-Type': 'text/plain'});
            res.end('ok');
        });
    } else {
        res.writeHead(200, {'Content-Type': 'text/html'});
        res.write('<form action="upload" method="post">');
        res.write('<input type="text" name="name"><br>');
        res.write('<input type="text" name="age"><br>');
        res.write('<input type="submit">');
        res.write('</form>');
        return res.end();
    }
}).listen(8080);
ログイン後にコピー
上記のコードは、Node.js の http および querystring 組み込みモジュールを使用します。この例では、サーバーを作成し、アドレスをリッスンしてフォーム データのリクエストを処理します。フォーム データを送信すると、リクエストがサーバーに送信され、サーバーは on() メソッドを通じてリクエスト データのイベントをリッスンし、クエリ文字列モジュールを使用してリクエスト データを解析します。

この例では、フォーム データを単純に解析し、結果をコンソールに出力します。実際のアプリケーションでは、これらのデータをデータベースに保存したり、処理のために他の場所に送信したりする必要がある場合があります。

概要

この記事では、ファイルのアップロードやフォームデータのアップロードなど、Node.js でデータをアップロードする方法を主に紹介します。ファイルをアップロードする場合は、multipart/form-data フォームを使用する必要があります。フォーム データをアップロードする場合は、ファイルをアップロードする必要はありません。リクエスト データにフォームのフィールド名とフィールド値を含める必要があるだけです。これらの方法を学ぶことで、Node.js でデータをアップロードする必要性をより適切に処理できるようになります。

以上がNodejsでデータをアップロードする方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート