博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【nodejs】让nodejs像后端mvc框架(asp.net mvc)一样处理请求--请求处理结果适配篇(7/8)...
阅读量:4547 次
发布时间:2019-06-08

本文共 3237 字,大约阅读时间需要 10 分钟。

前情概要

前面一大坨一大坨的代码把route、controller、action、attribute都搞完事儿了,最后剩下一部分功能就是串起来的调用。

那接下就说个说第二个中间件,也是最后一个中间件RequestHandler

RequestHandler 中间件的注册

app.use一下就完事啦。在RouteHandler把路由处理好之后,接着就是RequestHandler真正的来调用我们的处理函数啦,也就是我们的action。

import { RequestHandler, RouteHandler } from 'gd-express-basic'//第二个中间件,拦截所有请求对路由做自动映射RouteHandler(_app, controllers);//第三个中间件,处理请求_app.use(RequestHandler);

RequestHandler 请求处理中间件代码

  1. 从当前请求拿到对应的action描述对象,如果没有就继续往后面的中间件走,比如走到404。
  2. new一个新的controller对象,并把req,res对象传入。
  3. 完成参数的自动解析
  4. 调用action,得到返回结果
  5. 判断返回结果是否view类型,如果是view类型则调用render来渲染页面,如果不是则返回该对象
  6. 判断需要返回的对象是否是jsoncallback调用方式,是的话就适配一下
    7.完事儿
/** * 请求处理中间件 *  * @export * @param {core.Request} req  * @param {core.Response} res  * @param {(core.NextFunction | undefined)} next  */export function RequestHandler(req: core.Request, res: core.Response, next: core.NextFunction | undefined) {//1. 从当前请求拿到对应的action描述对象,如果没有就继续往后面的中间件走,比如走到404。    var desc: ActionDescriptor = res.locals.actionDescriptor    if (!desc) {        return next && next();    }    var cname = desc.ControllerName;    new Promise((reslove, reject) => {        var cType = desc.ControllerType;//*controller class对象        //2. new一个新的controller对象,并把req,res对象传入。        var c = new cType(req, res);//new 一个controller 对象出来        //3. 完成参数的自动解析        var agrs = bindActionParameter(desc.ControllerType, desc.ControllerTypeName, desc.ActionType, desc.ActionName, req)        //4. 调用action,得到返回结果        var actionResult = desc.ActionType.apply(c, agrs)        return reslove(actionResult)    }).then(actionResult => {        if (actionResult instanceof ViewResult) {        //5. 判断返回结果是否view类型,如果是view类型则调用render来渲染页面,如果不是则返回该对象            Promise.resolve(actionResult.data).then(ViewActionResultData => {                var findViewNamePath = actionResult.name[0] === '/' ? actionResult.name.substr(1) : (cname + '/' + actionResult.name)                res.render(findViewNamePath, ViewActionResultData, (err, html) => {                    if (err) {                        next && next(err);                    } else {                        res.send(html);                        res.end();                    }                });            }).catch(function (viewDataError) {                next && next(viewDataError);            });        } else if (typeof actionResult !== 'undefined') {            //process object send response json            //6. 判断需要返回的对象是否是jsoncallback调用方式,是的话就适配一下            let resultData = req.query['callback'] ? req.query['callback'] + '(' + JSON.stringify(actionResult) + ')' : actionResult;            res.send(resultData);            res.end()        } else {            //process not response or origin response.render or response.send.            process.nextTick((_res: any) => {                if (!_res.finished) {                    _res.end();                }            }, res)        }    }).catch(processRequestError => {        next && next(processRequestError);    })}

经过RouteHandler、RequestHandler两个方法的串联调用,就把我们整个零散的功能就完整统一的进行了一次调用。从controller的发现、注册,action的发现、注册,action参数配置,route解析、匹配,action调用,处理结果适配输出。

在编码调试过程中,发现目前dotnet core mvc的中间件的某些思想和实现方式和express的中间件基本一致。果然,思想都是相同的,哈哈哈。

转载于:https://www.cnblogs.com/calvinK/p/nodejs-mvc-process-result-format.html

你可能感兴趣的文章
Laravel 数据库连接, 数据库名,配置文件修改
查看>>
屌丝接盘侠们,孩子可能不是你们亲生的!
查看>>
BZOJ 1854 【SCOI2010】 游戏
查看>>
JavaScript - 匿名函数和闭包
查看>>
负载均衡下的资源文件配置/多站点下的资源文件夹共享(Windows IIS)
查看>>
MySQL firstmatch strategy
查看>>
MS SQL server 2014 创建用户及权限
查看>>
php文件下载
查看>>
asp.net core 读取Appsettings.json 配置文件
查看>>
python 写代码笔记 2017.6.15
查看>>
office很抱歉遇到一些临时服务器问题
查看>>
禁止键盘上的刷新键F5等
查看>>
SAP中对于获取订单的状态
查看>>
oracle PL/SQL块
查看>>
1-JAVA开发环境搭建
查看>>
day01 python基础
查看>>
Python报错[DLL load failed:找不到指定的模块]
查看>>
Web开发框架使用Ajax实现dropdownlist联动
查看>>
Maven 常见知识点整理
查看>>
CF 600 E Lomsat gelral —— 树上启发式合并
查看>>