Ionică Bizău

Upload files using NodeJS

In this article I will describe how to upload files using Lien and Formidable, after creating a NodeJS HTTP server.

Lien is a tiny high-level framework for creating HTTP servers, being one of the libraries which power Bloggify.

Formidable is a NodeJS module for parsing form data and file uploads. We will use it to create a file upload interface in a Lien server.


First of all, create the directory structure:

# Create the project directory
$ mkdir file-upload

# Enter in the project directory
$ cd file-upload

# Create the public and uploads directories
$ mkdir -p public/uploads

Next, we have to install the dependencies:

$ npm i formidable@1.0.17 lien@0.0.8

Create the index.html file into the public directory:

<!DOCTYPE html>
<html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>File upload</title>
    </head>
    <body>
        <form action="/upload" method="post" enctype="multipart/form-data">
            <input name="file" type="file">
            <button>Submit</button>
        </form>
        <iframe src="/upload/list" frameborder="0"></iframe>
    </body>
</html>

This is a HTML page containing a file upload form and an <iframe> element which will list the uploaded files (/upload/list).

And now the server side: index.js

// Dependencies
var Lien = require("lien")
  , Fs = require("fs")
  , Formidable = require("formidable")
  ;

// Constants
const DIR_UPLOADS = __dirname + "/public/uploads/";

// Init lien server
var server = new Lien({
    host: "localhost"
  , port: 9000
});

// Add page
server.page.add("/", function (lien) {
    lien.file("/index.html");
});

// Upload
server.page.add("/upload$", function (lien) {
    var form = new Formidable.IncomingForm(
        { uploadDir: DIR_UPLOADS }
    );
    form.parse(lien.req, function (err, fields, files) {

        if (!files.file) {
            return lien.end("File is missing.", 400);
        }

        Fs.rename(files.file.path, DIR_UPLOADS + files.file.name, function (err) {
            if (err) {
                return lien.end(err, 400);
            }
            lien.redirect("/");
        });
    });
});

// List
server.page.add("/upload/list", function (lien) {
    Fs.readdir(DIR_UPLOADS, function (err, files) {
        if (err) { return lien.end(err, 500); }
        files = files.filter(function (c) {
            return c !== ".gitignore";
        });

        var list = ["<ul>", files.map(function (c) {
            return ["<li>", "<a target='blank' href='/uploads/", c, "'>", c, "</a></li>"].join("");
        }).join(""), "</ul>"].join("");

        lien.end(list);
    });
});

And that's it. The server will run on localhost:9000:

$ node index.js

Open localhost:9000 and there you can upload files and see a list with the previous uploads:

Browse the code here.

Have feedback on this article? Let @IonicaBizau know on Twitter.

Have any questions? Feel free to ping me on Twitter.