【nodejs】让nodejs像后端mvc框架(asp.net mvc)一样处理请求--请求处理结果适配篇(7/8)

简介: 文章目录前情概要前面一大坨一大坨的代码把route、controller、action、attribute都搞完事儿了,最后剩下一部分功能就是串起来的调用。那接下就说个说第二个中间件,也是最后一个中间件RequestHandlerRequestHandler 中间件的注册app.use一下就完事啦。

文章目录

前情概要

前面一大坨一大坨的代码把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的中间件基本一致。果然,思想都是相同的,哈哈哈。

目录
相关文章
|
3月前
|
存储 缓存 JavaScript
node 框架
Node 框架以其独特的优势和广泛的应用场景,成为了现代 Web 开发中不可或缺的一部分。掌握 Node 框架的开发技能,对于开发者来说具有重要的意义。
158 59
|
3月前
|
Web App开发 JavaScript 前端开发
深入浅出Node.js后端框架
【10月更文挑战第34天】在数字化时代,后端开发如同一座桥梁,连接着用户界面与数据处理的两端。本文将通过Node.js这一轻量级、高效的平台,带领读者领略后端框架的魅力。我们将从基础概念出发,逐步深入到实战应用,最后探讨如何通过代码示例来巩固学习成果,使读者能够在理论与实践之间架起自己的桥梁。
|
4月前
|
JavaScript 前端开发 中间件
探索后端技术:Node.js与Express框架的完美融合
【10月更文挑战第7天】 在当今数字化时代,Web应用已成为日常生活不可或缺的一部分。本文将深入探讨后端技术的两大重要角色——Node.js和Express框架,分析它们如何通过其独特的特性和优势,为现代Web开发提供强大支持。我们将从Node.js的非阻塞I/O和事件驱动机制,到Express框架的简洁路由和中间件特性,全面解析它们的工作原理及应用场景。此外,本文还将分享一些实际开发中的小技巧,帮助你更有效地利用这些技术构建高效、可扩展的Web应用。无论你是刚入门的新手,还是经验丰富的开发者,相信这篇文章都能为你带来新的启发和思考。
|
3月前
|
Web App开发 缓存 监控
如何解决Node框架中内存管理的挑战?
解决 Node 框架中内存管理的挑战需要综合运用多种方法,并且需要在开发过程中保持谨慎和细心,不断优化和改进代码。同时,定期进行内存管理的检查和维护也是非常重要的。
131 63
|
3月前
|
安全 前端开发 JavaScript
Node框架的优缺点
Node 框架的优点使其在现代 Web 开发中具有重要地位,但同时也需要开发者在使用过程中注意其缺点,合理选择和应用,以充分发挥其优势,避免潜在问题的出现。随着技术的不断发展和完善,Node 框架也在不断改进和优化,以更好地适应各种应用需求。
113 47
|
2月前
|
监控 前端开发 API
一款基于 .NET MVC 框架开发、功能全面的MES系统
一款基于 .NET MVC 框架开发、功能全面的MES系统
|
2月前
|
JSON 数据格式
.net HTTP请求类封装
`HttpRequestHelper` 是一个用于简化 HTTP 请求的辅助类,支持发送 GET 和 POST 请求。它使用 `HttpClient` 发起请求,并通过 `Newtonsoft.Json` 处理 JSON 数据。示例展示了如何使用该类发送请求并处理响应。注意事项包括:简单的错误处理、需安装 `Newtonsoft.Json` 依赖,以及建议重用 `HttpClient` 实例以优化性能。
89 2
|
3月前
|
缓存 负载均衡 JavaScript
构建高效后端服务:Node.js与Express框架实践
在数字化时代的浪潮中,后端服务的重要性不言而喻。本文将通过深入浅出的方式介绍如何利用Node.js及其强大的Express框架来搭建一个高效的后端服务。我们将从零开始,逐步深入,不仅涉及基础的代码编写,更会探讨如何优化性能和处理高并发场景。无论你是后端新手还是希望提高现有技能的开发者,这篇文章都将为你提供宝贵的知识和启示。
|
3月前
|
存储 JavaScript 搜索推荐
Node框架的安装和配置方法
安装 Node 框架是进行 Node 开发的第一步,通过正确的安装和配置,可以为后续的开发工作提供良好的基础。在安装过程中,需要仔细阅读相关文档和提示,遇到问题及时解决,以确保安装顺利完成。
194 2
|
3月前
|
JavaScript 中间件 API
Node.js进阶:Koa框架下的RESTful API设计与实现
【10月更文挑战第28天】本文介绍了如何在Koa框架下设计与实现RESTful API。首先概述了Koa框架的特点,接着讲解了RESTful API的设计原则,包括无状态和统一接口。最后,通过一个简单的博客系统示例,详细展示了如何使用Koa和koa-router实现常见的CRUD操作,包括获取、创建、更新和删除文章。
96 4

热门文章

最新文章