zoukankan      html  css  js  c++  java
  • Express服务器开发

    Express简介:

    让我们来创建Express应用程序,Express是一个Node.js Web应用框架,它很强大,可以为用户创建各种Web应用和HTTP工具,使用Express框架可以搭建一个完整功能的网站。

    Express框架的优点:

    可以用中间件来响应HTTP请求,可以定义路由表用于执行不同的HTTP请求,可以向模板传参数来动态渲染html页面。

    命令行安装Express框架:

    cnpm install express --save
    

    Express框架安装在node_modules目录中,然后需要一起安装如下模块:

    body-parser是node.js的中间件,可以处理JSON,Raw,Text,URL编码的数据,cookie-parser是一个解析Cookie的中间件,然后通过req.cookies可以获取传过来的Cookie,并转为对象。

    multer是node.js的中间件,用于处理enctype="multipart/form-data"的表单数据。

    cnpm install body-parser --save
    cnpm install cookie-parse --save
    cnpm install multer --save
    

    让我们来看看express框架的版本号:

    cnpm list express
    

    创建第一个Express框架实例

    目的为了输出:“hello”,命名:express_demo.js文件

    // 引入node模块
    const express = require('express');
    
    // 创建express程序
    const app = express();
    
    // 添加HTTP路由
    app.get('/', function(request, response){
     // 输出响应消息
     response.send('hello express');
    });
    
    // 启动HTTP服务器
    app.listen(8080, function(){
     console.log('express app');
    });
    

    执行项目:

    node express_demo.js
    

    然后就可以用http://127.0.0.1:8080

    express框架使用request对象和response对象来处理请求和响应的数据:

    app.get('/', function(req,res){
    })

    request对象为HTTP请求

    req.app

    为callback,回调函数外部文件,利用req.app访问express的实例

    req.baseUrl

    获取当前安装的URL路径

    req.body/req.cookies

    为获得“请求主体”

    req.hostname/req.ip

    获取主机名,ip地址

    req.originalUrl

    获取原始请求URL

    req.params

    获取路由的参数

    req.path

    获取请求路径

    req.protocol

    获取协议类型

    req.query

    获取URL的查询参数

    req.route

    获取当前匹配的express路由

    req.subdomains

    获取子域名

    req.accepts()

    检查可接受请求的文档类型

    req.get()

    获取指定的HTTP请求头

    req.is()

    判断请求头Content-Type的Mime类型

    response对象为HTTP响应

    res.app

    为callback,回调函数外部文件,利用res.app访问express的实例

    res.append()

    追加指定HTTP请求头

    res.set()

    在res.append()后重置之前设置的请求头

    res.clearCookie()

    清除Cookie

    res.download()

    传送指定路径的文件

    res.get()

    返回指定的HTTP请求头

    res.json()

    传送json响应

    res.jsonp 传送jsonp响应

    res.location() 只设置响应的LocationHTTP请求头,不设置状态码或者close response

    res.redirect() 设置响应的LocationHTTP请求头,并且设置状态码302

    res.send() 传送HTTP响应

    res.status() 设置HTTP状态码

    res.type() 设置Content-Type的MIME类型

    广州设计公司https://www.houdianzi.com 我的007办公资源网站https://www.wode007.com

    express路由

    express路由,由URI,HTTP请求和若干个句柄组成。

    // 引入node模块
    const express = require('express');
    
    // 创建express程序
    const app = express();
    
    // 添加http路由
    app.get('/',function(request,response) {
     // 输出响应消息
     response.send('hello dashucoding');
    });
    
    app.get('/users', function(req,res) {
     // req , res
     res.send('user');
    });
    
    // 启动HTTP服务器
    app.listen(8080, function(){
     console.lo('express app');
    });
    

    GET 请求一个指定资源的表示形式,只用于获取数据

    POST 用于将尸体提交到指定的资源

    HEAD 请求一个与GET相同的响应,但没有响应体

    PUT 用于请求有效载荷替换目标资源的所有当前表示

    DELETE 删除指定的资源

    CONNECT 建立一个由目标资源标识的服务器的隧道

    OPTIONS 用于描述目标资源的通信选项

    PATCH 用于对资源应用部分修改

    app.get('/about',function(req,res){
    res.send('about');
    });
    
    app.get('/ab?cd',function(req,res){
    res.send('ab?cd');
    }
    
    app.get('/ab(cd)?e',function(req,res){
    res.send('ab(cd)?e');
    });
    

    路由句柄,为请求处理提供多个回调函数,next('route')方法

    let d1 = function(req,res,next){
     console.log('1');
     next();
    };
    
    let d2 = function(req,res,next){
     console.log('2');
     next();
    });
    
    let d3 = function(req,res,next){
     console.log('3');
     next();
     });
     
     app.get('/', [d1,d2]);
    

    next用于执行下一个回调函数,next('route')用于执行下一个相同路由。

    // 引入node模块
    const express = require('express');
    // 创建express程序
    const app = express();
    // 添加http路由
    app.get('/', function(request, response){
    // 输出响应消息
    response.send('hello');
    });
    app.get('/users', function(req,res){
    res.send('user');
    });
    
    // 动态
    app.get('/users/id', function(req,res){
    let id = req.params.id;
    // 返回响应
    res.send('id='+id);
    });
    
    // 启动HTTP服务器
    app.listen(8080,function(){
    console.log('expresss app');
    });
    
    const express = require('express');
    const app = express();
    app.get('/', function(request, response){
    response.send('hello');
    });
    app.get('/users',function(req,res){
    res.send('users');
    });
    app.param('id',(req,res,next)=>{
     console.log('hello');
     if(req.params.id==='1'){
     next();
     }else{
     res.sendStatus(404);
     }
     });
     
     app.get('/users/:id',(req,res)=>{
     res.send('hello');
     });
     
     // 启动服务器
     app.listen(8080,function(){
      console.log('express');
     });
    

    pug视图模板

    命令行下载:

    npm install pug
    

    pug.compile()将pug代码编译成一个JavaScript函数。

    app.js
    
    const express = require('express');
    
    const app = express();
    
    // 配置视图模板
    app.set('view engine', 'pug');
    app.set('views', './views');
    
    // 添加HTTP路由
    app.get('/', function(request, response){
    response.render('index.pug');
    // 输出响应消息,加载并解析index.pug文件
    });
    
    app.get('/users',function(req,res){
    res.render('users.pug',{
    title:'user',
    users:[
    {id:1,name:'张三',age:18}
    ]
    });
    });
    // 启动HTTP服务器
    app.listen(8080,function(){
    console.log('express');
    });
    

    users.pug:

    doctype html
    html
    head
    meta(charset="utf-8")
    title #{title}
    body
    #app
     for user in users
     div
     p id=#{user.id}
     p name=#{user.name}
     p age=#{user.age}
    
    pug.render()模板函数:
    
    const pug = require('pug');
    
    console.log(pug.renderFile('template.pug',{
    name:'dada'
    });
    

    执行pug.renderFile()函数,会把编译出来的函数自动储存到内部缓存中

  • 相关阅读:
    javaScript 闭包
    Netty入门1之----认识Netty
    浅谈 @RequestParam 和@PathVariable
    分布式事务的解决方案
    java实现哈弗曼树和哈夫曼树压缩
    深入理解mysql的底层实现
    深入理解http协议的特点
    char和varchar的区别
    详解聚簇索引
    解决nginx: [error] open() "/usr/local/nginx/logs/nginx.pid" failed错误
  • 原文地址:https://www.cnblogs.com/xiaonian8/p/13831071.html
Copyright © 2011-2022 走看看