zoukankan      html  css  js  c++  java
  • nodejs 之express web服务器搭建

      搭建web服务

            let express=require('express')
            let app=express()
            let app.listen(端口,地址,回调)

    静态资源托管

        app.use(express.static('./www'));

        app.all('/index/*',(req,res,next)=>{

        //TODO

        next();

        }))

    all匹配路径 处理所有HTTP

    next 延续后续

     

    use

      app.use([地址],中间件|路由|函数体);

      中间件封装过程,req,res,next,被作为参数传递给中间件,req等就被带上了中间件的方法,作为流传递下去了

      app.use("/",(req,res,next)=>{ })

    req请求

        req.query //获取地址栏的数据
        req.body //获取非地址栏的数据 依赖中间件

        req.params //获取动态接口名
        req.method //获取前端提交方式

        req.body依赖中间件

    中间件使用:body-parser

    1. npm install body-parser

    2. let bodyParser = require('body-parser')

    3. app.use(bodyParser ())

      •   req.app:当callback为外部文件时,用req.app访问express的实例

      •   req.baseUrl:获取路由当前安装的URL路径

      •   req.cookies:Cookies

      •   req.fresh / req.stale:判断请求是否还「新鲜」

      •   req.hostname / req.ip:获取主机名和IP地址

      •   req.originalUrl:获取原始请求URL

      •   req.path:获取请求路径

      •   req.protocol:获取协议类型

      •   req.route:获取当前匹配的路由

      •   req.subdomains:获取子域名

      •   req.accepts():检查可接受的请求的文档类型

      •   req.acceptsCharsets / req.acceptsEncodings / req.acceptsLanguages:返回指定字符集的第一个可接受字符编码

      •   req.get():获取指定的HTTP请求头

      •   req.is():判断请求头Content-Type的MIME类型

    res响应

      res.send(any) //对等 res.write + end
      res.end(string|buffer)
      res.json(json) //返回json
      res.status(404).send({error:1,msg:"Sorry can't find that!"}) //返回一个404

      res.jsonp(响应数据) //调用请求时的回调函数并传递响应数据
      res.sendFile(path.resolve('public/error.html'))//渲染纯 HTML 文件

      •   res.app:同req.app一样

      •   res.append():追加指定HTTP头

      •   res.set()在res.append()后将重置之前设置的头

      •   res.cookie(name,value [,option]):设置Cookie

      •   opition: domain / expires / httpOnly / maxAge / path / secure / signed

      •   res.clearCookie():清除Cookie

      •   res.download():传送指定路径的文件

      •   res.get():返回指定的HTTP头

      •   res.location():只设置响应的Location HTTP头,不设置状态码或者close response

      •   res.render(view,[locals],callback):渲染一个view,同时向callback传递渲染后的字符串,如果在渲染过程中有错误发生next(err)将会被自动调用。callback将会被传入一个可能发生的错误以及渲染后的页面,这样就不会自动输出了。

      •   res.sendFile(path [,options] [,fn]):传送指定路径的文件 -会自动根据文件extension设定Content-Type

      •   res.set():设置HTTP头,传入object可以一次设置多个头

      •   res.status():设置HTTP状态码

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

    jsonp响应

      app.set('jsonp callback name','cb')//默认callback
      app.get('/jsonp接口',(req,res,next)=>res.jsonp(数据))//只需写返回的数据,回调函数不需考虑。

      get发送地址为http://localhost:7755/jsonp?a=1&b=2&cb=jsonp_0010423157583412168时可以看到响应体是

      /**/ typeof jsonp_0010423157583412168 === 'function' && jsonp_0010423157583412168({"a":1,"b":2});

    后端跳转

      res.redirect(url)      指向一个地址

    let express=require('express');
    let bodyParser=require('body-parser');
    let path=require('path');
    let app=express();
    
    app.listen(7755,console.log("启动服务"));
    app.use(express.static('./public'));
    app.use(bodyParser.urlencoded({
        limit: 100
      }));
    
    app.all('/*',(req,res,next)=>{
    
        //公共处理部分
    next();
    })
    
    app.get('/get',(req,res,next)=>{
        res.end();
    })
    
    app.post('/post',(req,res,next)=>{
        console.log(req.body);//请求体携带内容。但是form-data格式收不到。
        res.send();
    })
    
    //jsonp
    app.get('/jsonp',(req,res,next)=>{
        app.set('jsonp callback name','cob')//默认callback
        res.jsonp({a:1,b:2});
    })
    //重定向
    app.get("/re",(req,res)=>{
         res.redirect("http://www.baidu.com");   
    })
    
    app.get('*',(res,req,next)=>{
        //404处理
        req.sendFile(path.resolve('./404.html'))
    })
  • 相关阅读:
    WKWebView和WebView与JS的交互方式
    iOS 同一个workspace下创建多个项目编程
    换个视角来看git命令与代码库发生网络交互报错事件
    java 排序的几篇好文章
    Kafka学习资料
    Linux IO模型(同步异步阻塞非阻塞等)的几篇好文章
    "PECS原则"几篇好文章
    mac定时任务
    如何在idea中调试spring bean
    配置多个 git 账号的 ssh密钥
  • 原文地址:https://www.cnblogs.com/anin/p/13368408.html
Copyright © 2011-2022 走看看