【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的中间件基本一致。果然,思想都是相同的,哈哈哈。

目录
相关文章
|
Web App开发 JavaScript 前端开发
Node.js 是一种基于 Chrome V8 引擎的后端开发技术,以其高效、灵活著称。本文将介绍 Node.js 的基础概念
Node.js 是一种基于 Chrome V8 引擎的后端开发技术,以其高效、灵活著称。本文将介绍 Node.js 的基础概念,包括事件驱动、单线程模型和模块系统;探讨其安装配置、核心模块使用、实战应用如搭建 Web 服务器、文件操作及实时通信;分析项目结构与开发流程,讨论其优势与挑战,并通过案例展示 Node.js 在实际项目中的应用,旨在帮助开发者更好地掌握这一强大工具。
440 1
|
10月前
|
前端开发 Java 数据库连接
Spring MVC 扩展和SSM框架整合
通过以上步骤,我们可以将Spring MVC扩展并整合到SSM框架中。这个过程包括配置Spring MVC和Spring的核心配置文件,创建控制器、服务层和MyBatis的Mapper接口及映射文件。在实际开发中,可以根据具体业务需求进行进一步的扩展和优化,以构建更加灵活和高效的企业级应用程序。
269 5
|
12月前
|
C# Android开发 iOS开发
2025年全面的.NET跨平台应用框架推荐
2025年全面的.NET跨平台应用框架推荐
570 23
|
消息中间件 开发框架 监控
NET任务调度框架Hangfire使用指南
Hangfire 是一个用于 .NET 应用程序的开源任务调度框架,支持长时间运行任务、定时任务等。通过简单的安装配置,即可将任务从主线程分离,提升应用性能。支持多种数据库,提供丰富的任务类型如立即执行、延迟执行和周期性任务,并有可视化管理界面 Hangfire Dashboard。还支持安全性配置及扩展插件,如 Hangfire.HttpJob,适合各种复杂场景下的任务调度需求。
1304 1
NET任务调度框架Hangfire使用指南
|
监控 前端开发 API
一款基于 .NET MVC 框架开发、功能全面的MES系统
一款基于 .NET MVC 框架开发、功能全面的MES系统
418 5
|
存储 JavaScript 前端开发
深入浅出Node.js后端开发
在数字化时代的浪潮中,后端开发作为连接用户与数据的桥梁,扮演着至关重要的角色。本文将以Node.js为例,深入探讨其背后的哲学思想、核心特性以及在实际项目中的应用,旨在为读者揭示Node.js如何优雅地处理高并发请求,并通过实践案例加深理解。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供新的视角和思考。
|
Web App开发 开发框架 JavaScript
深入浅出Node.js后端开发
在这篇文章中,我们将一起探索Node.js的奇妙世界。无论你是刚接触后端开发的新手,还是希望深化理解的老手,这篇文章都适合你。我们将从基础概念开始,逐步深入到实际应用,最后通过一个代码示例来巩固所学知识。让我们一起开启这段旅程吧!
|
Web App开发 开发框架 JavaScript
深入浅出Node.js后端开发
本文将带你领略Node.js的魅力,从基础概念到实践应用,一步步深入理解并掌握Node.js在后端开发中的运用。我们将通过实例学习如何搭建一个基本的Web服务,探讨Node.js的事件驱动和非阻塞I/O模型,以及如何利用其强大的生态系统进行高效的后端开发。无论你是前端开发者还是后端新手,这篇文章都会为你打开一扇通往全栈开发的大门。
|
JavaScript 前端开发 API
深入理解Node.js事件循环及其在后端开发中的应用
本文旨在揭示Node.js的核心特性之一——事件循环,并探讨其对后端开发实践的深远影响。通过剖析事件循环的工作原理和关键组件,我们不仅能够更好地理解Node.js的非阻塞I/O模型,还能学会如何优化我们的后端应用以提高性能和响应能力。文章将结合实例分析事件循环在处理大量并发请求时的优势,以及如何避免常见的编程陷阱,从而为读者提供从理论到实践的全面指导。
|
Web App开发 JavaScript 前端开发
深入浅出Node.js后端开发
本文将带你走进Node.js的世界,从基础到进阶,逐步解析Node.js在后端开发中的应用。我们将通过实例来理解Node.js的异步特性、事件驱动模型以及如何利用它处理高并发请求。此外,文章还会介绍如何搭建一个基本的Node.js服务器,并探讨如何利用现代前端框架与Node.js进行交互,实现全栈式开发。无论你是初学者还是有一定经验的开发者,这篇文章都将为你提供新的视角和深入的理解。
464 4