Express notes

Introduction to the

What is the Express framework

Express is a Web application development framework based on the Node platform. It provides a series of powerful features to help you create a variety of Web applications. We can download it using the NPM install Express commandCopy the code

Express Framework Features

Provides a convenient and concise route definition method. 2. Simplifies the process of obtaining HTTP request parameters. High support for template engine, easy to render dynamic HTML pages 4. Provide middleware mechanism to effectively control HTTP requests 5. There is a lot of third-party middleware to extend the functionalityCopy the code

The basic use

Basic operation

NPM install Express start project Nodefilene. js stop CTRL + CCopy the code

Basic usage in js files

// Introduce the Express framework
const express = require('express');
// Create a web server
const app = express();

// Create routes and receive requests......
/ / such as:
app.use('/'.(request, response) = > {
    // send()
    // 1. The send method detects the type of response content internally
    // 2. The send method automatically sets the HTTP status code
    // 3. The send method automatically sets the content type and encoding of the response
    response.send('Hello Express!!! ');
});

// Listen on port 3000
app.listen(3000);
console.log('Website server started successfully!! - http://localhost:3000');
Copy the code

The middleware

What is middleware

Middleware is a collection of methods that accept requests from clients, respond to them, or pass them on to the next middleware. Middleware mainly consists of two parts, middleware methods and request processing functions. Middleware methods are provided by Express to intercept requests, and request handlers are provided by developers to process requests. Multiple middleware can be set up to handle the same request for the same request. By default, requests are matched to the middleware from top to bottom, and once a match is successful, the match is terminated. The next method can be called to give control of the request to the next middleware until the middleware that ends the request is encountered./ / sample
app.get('/'.(request, response, next) = > {
    request.name = 'Sketchy';
    next();
});

app.get('/'.(request, response) = > {
    response.send(request.name);
});
Copy the code

App. use Middleware usage

App.use matches all request modes and can be passed directly to the request handler to receive all requests./ / such as
function fn() {
    return function (request, response, next) {
        console.log(request.method);
        next();
    };
}

app.use(fn());

// Receive the request
app.get('/'.(request, response) = > {
    response.send('Hello!!! ');
});


// Parameter selection
/ / such as
app.use((request, response, next) = > {
    console.log(request.url);
})

//app.use The first parameter can also be passed to the request address, indicating that the request will be received regardless of the request type as long as the request address.
app.use('/'.(request, response, next) = > {
    console.log(request.url);
})
Copy the code

Middleware Application Scenarios

1.Routing protection: When the client accesses the page to be logged in, the middleware can be used to determine the login status of the user. If the user does not log in, the client intercepts the request and responds directly to prohibit the page to be logged in.2.Website maintenance bulletin, at the top of all routes to define the middleware to receive all requests, respond directly to the client, the website is being maintained.3.The custom404page/ / sample
app.use((request, response, next) = > {
    // The user is not logged in
    let isLogin = true;
    / / determine
    if (isLogin) {
        // Request to continue down
        next();
    }
    else {
        response.send('Not logged in yet, cannot access!! ');
    }
})

app.get('/'.(request, response, next) = > {
    request.name = 'Sketchy';
    next();
});

app.get('/'.(request, response) = > {
    response.send(request.name);
});
Copy the code

Error handling middleware

In the process of program execution, it is inevitable that there will be some unexpected errors, such as file reading failure, database connection failure. Error handling middleware is a centralized place to handle errors./ / sample
app.get('/'.(request, response, next) = > {
    throw new Error('Unknown error in program!! ');
});

app.use((error, request, response, next) = > {
    response.status(500).send(error.message); When an error occurs in the program, call the next() method and pass the error message to the next() method as a parameter to trigger the error-handling middleware.// For example: next(err)
Copy the code

Capture the error

In Node.js, the error information of the asynchronous API is obtained through the callback function, and the error of the asynchronous API that supports the Promise object can be caught through the catch method. How do you catch errors in asynchronous function execution? Try catch can catch errors that occur during the execution of asynchronous functions and other synchronous code, but cannot catch errors that occur in other types of apis.Copy the code

Express Request Handling

Building modular routing

app.js
// Introduce the Express framework
const express = require('express');
// Create a web server
const app = express();

// Import routes
const home = require('./home');
const about = require('./about');

// Match the route with the request path
app.use('/', home);
app.use('/', about);

// Listen on port 3000
app.listen(3000);
console.log('Website server started successfully!! - http://localhost:3000');
Copy the code
home.js
// Introduce the Express framework
const express = require('express');
// Create a routing object
const home = express.Router();

home.get('/home'.(request, response) = > {
    response.send('I was home');
})

module.exports = home;
Copy the code
about.js
// Introduce the Express framework
const express = require('express');
// Create a routing object
const about = express.Router();

about.get('/about'.(request, response) = > {
    response.send('I'm about);
})

module.exports = about;
Copy the code

GET Gets the parameter

The Express framework uses request.query to GET the GET argument, which is internally converted into an object and returned.// For example: http://localhost:3000/? Name =' slightly '&age=20
app.get('/'.(request, response) = > {
    response.send(request.query);
});
Copy the code

Get the POST parameter

NPM I Body-Parser is installed to receive POST request parameters using the third-party package Body-Parser// Introduce the body-parser module
const bodyParser = require('body-parser');
// Configure the body-parser module
// Extended: When false, the argument format is processed inside the method using QueryString
// Extended: When true, the third-party module QS will be used to process the parameter format
app.use(bodyParser.urlencoded({extended: false}));
// Receive the request
app.post('/'.(request, response) = > {
    response.send(request.body);
});

/** HTML code */
<form action="http://localhost:3000" method="POST">
    <input type="text" name="username" />
    <input type="password" name="password" />
    <input type="submit" />
</form>
Copy the code

Express Routing Parameters

app.get('/:id/:name'.(request, response) = > {
    response.send(request.params);
});
// In the url: localhost:3000/123456/ omitted
Copy the code

Processing of static resources

Express's built-in Express. static makes it easy to host static files, such as IMG, CSS, JavaScript files, etc./ / sample
const path = require('path');
app.use(express.static(path.join(__dirname, 'public'))); The files under the public directory are now accessible. Such as:http://localhost:3000/images/index.jpg
http://localhost:3000/html/index.html
http://localhost:3000/css/index.css
http://localhost:3000/js/index.js.Copy the code