jjzjj

node.js - 模块化编程和 Node

coder 2023-05-04 原文

更新 1 : 我在这方面取得了很大进展。我几乎放弃了(至少现在,但可能是长期)允许用户上传模块的想法。但是,我正在开发一个结构,以便可以定义和加载多个模块。一个模块将被初始化,设置自己的路由,并为 Javascript 提供一个“公共(public)”目录。我看到的越多,我就越意识到我可以(应该)移动现在系统范围内的调用在一个名为“系统”的模块中。

更新 2 : 我在这方面取得了巨大的进步。我即将在 GitHub 上提交大量代码,这将允许人们使用 Node 和 Express 进行非常非常好的模块化编程(模块暴露客户端和服务器端代码)。敬请期待。

更新 3 :我将这个东西重写为一个系统来注册模块并使它们能够通过事件/钩子(Hook)系统进行通信。进展非常顺利。我已经有大量代码可以使用了——我只是将它移植到新系统中。随意查看GitHub上的项目:https://github.com/mercmobily/hotplate )

更新 4 : 这个不错。事实证明,我关于模块是客户端和服务器的想法确实有效。

更新 5 :模块越来越接近可用的东西。我实现了一个新的加载器,它将考虑 init() 函数将调用的内容 - 并确保首先加载提供该钩子(Hook)的模块。这将电炉打开到了一个全新的水平。

更新 6 : Hotplate 现在接近 12000 行代码。当它完成时,在二月的某个时候,我想它会接近 20000 行代码。它做了很多事情,一切都从 StackOverflow 开始!我需要它来开发我自己的 SaaS,所以我真的需要在 2 月之前完成它(这样我就可以冲刺到 7 月并完成 BookingDojo 的第一个版本)。谢谢大家!

我正在写一些可能会变成一个相当大的软件的东西。简而言之,它是 nodejs + Express + Mongodb/Mongoose + Dojo(客户端)。

注意:本文中的问题标记为 [Q1]、[Q2] 等。

来自 Drupal 背景(并且知道它是如何发展的,这是我想避免的),我有点模块怪胎。目前,我已经完成了应用程序的样板(热板: https://github.com/mercmobily/hotplate )。它完成了所有无聊的事情(用户、工作区、密码提醒等),但它缺少很多部分。

我想提出一种设计,允许以与 Drupal 类似的方式(但可能更好)的模块。那是:

  • 模块可以定义新的路由,并处理它们
  • 模块在系统范围内安装,然后每个工作区都可以启用它们的一组列表

  • 最初的架构可能是这样的:
  • “modules”目录,其中每个模块有一个目录
  • 每个模块都有一个目录,用于存放 Javascript 方面的“公共(public)”文件
  • 每个模块都会有 public/startup.js,它将包含在应用程序的 javascript
  • 每个模块都有 server/node.js,如果/在需要时由服务器动态包含
  • 将定义一个路由,例如/app/:workspaceid/modules/MODULE_NAME/.* 带有一个中间件,用于检查该工作区是否启用了 MODULE_NAME -- 如果启用,则使用传递的参数
  • 调用模块的函数

    [Q1]:这是否有些模糊?

    问题:
  • 我想让这个动态。我希望在现场需要时需要模块。这应该很容易做到,因为需要动态处理。
  • server/node.js 会调用一个函数,但该函数感觉/看起来非常像路由器本身

  • [Q2] 你对这个有什么具体的提示吗?

    这些似乎都不是什么大问题。但是,当您谈论安全性时,真正的问题就来了。
  • 隐私。这是一个讨厌的。目前,所有调用都会对 mongoDb 过滤的 workspaceId 进行正确的查询。我想强制执行某种方式,以便模块无法明确访问数据库,从而使每个模块无法访问属于其他工作区的数据
  • 用户定义的模块。我很乐意让用户能够上传他们自己的模块(并可能将它们提供给其他用户)。但是,这实际上意味着允许人们上传将由 Node 本身执行的代码!你会怎么做?

  • [Q3] 你会如何处理这些隐私/安全问题?例如,有没有办法在某种 Node 沙箱中运行用户上传的代码?如何访问文件系统等?

    谢谢!

    最佳答案

    最后,我自己回答了这个问题——艰难的方式。
    答案:电炉,https://github.com/mercmobily/hotplate

    它完成了我上面描述的大部分工作。更重要的是,使用 hotPlate(使用 hotPage 和 hotClientPages,默认可用),您可以编写一个模块

  • 定义一些路由
  • 使用 UI
  • 定义“公共(public)”目录
  • 定义加载该模块时必须加载的特定 CSS 和 JS 文件
  • 如果需要,可以添加特定于路由的 JS

  • 状态 :
    我正在接受这个答案,因为我已经完成了 Hotplate 的“核心”的开发,这是这个答案的重点。我仍然需要“做”一些事情(例如,一旦我编写了文档,我将确保“hotplate”是模块中唯一的目录,那里没有示例服务器)。然而,基础是存在的。就“核心”而言,它只是真正缺少故事的“身份验证”方面(这需要大量思考,因为我想让它与数据库无关并且与护照接口(interface))。 Dojo 小部件是一个很大的好处,尽管这个框架可以用于任何东西(实际上特定于主干的代码会很甜蜜)。

    什么电炉不做 :

    什么是热板不做,是让用户能够上传模块,然后将加载到应用程序中。这是非常棘手的。客户端不会那么糟糕(用户可以定义要上传的 Javascript,并且可以有一个模块来做到这一点,不用担心)。然而,服务器端充其量是棘手的。可能出错的事情太多了(客户端可能会上传一段阻塞代码,或者他们可以开始读取文件系统,他们可以访问完整的数据库,等等)。
    这些问题的解决方案是可能的,但它们都不是一件容易的事(例如,您可以限制用户的 Node 环境并使其在不同的端口上运行,等等),但一些问题仍然存在。但是,总有希望。

    关于node.js - 模块化编程和 Node ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12229180/

    有关node.js - 模块化编程和 Node的更多相关文章

    1. ruby - 在 Ruby 中使用匿名模块 - 2

      假设我做了一个模块如下:m=Module.newdoclassCendend三个问题:除了对m的引用之外,还有什么方法可以访问C和m中的其他内容?我可以在创建匿名模块后为其命名吗(就像我输入“module...”一样)?如何在使用完匿名模块后将其删除,使其定义的常量不再存在? 最佳答案 三个答案:是的,使用ObjectSpace.此代码使c引用你的类(class)C不引用m:c=nilObjectSpace.each_object{|obj|c=objif(Class===objandobj.name=~/::C$/)}当然这取决于

    2. ruby-on-rails - Ruby net/ldap 模块中的内存泄漏 - 2

      作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代

    3. ruby-on-rails - 在混合/模块中覆盖模型的属性访问器 - 2

      我有一个包含模块的模型。我想在模块中覆盖模型的访问器方法。例如:classBlah这显然行不通。有什么想法可以实现吗? 最佳答案 您的代码看起来是正确的。我们正在毫无困难地使用这个确切的模式。如果我没记错的话,Rails使用#method_missing作为属性setter,因此您的模块将优先,阻止ActiveRecord的setter。如果您正在使用ActiveSupport::Concern(参见thisblogpost),那么您的实例方法需要进入一个特殊的模块:classBlah

    4. ruby - 当使用::指定模块时,为什么 Ruby 不在更高范围内查找类? - 2

      我刚刚被困在这个问题上一段时间了。以这个基地为例:moduleTopclassTestendmoduleFooendend稍后,我可以通过这样做在Foo中定义扩展Test的类:moduleTopmoduleFooclassSomeTest但是,如果我尝试通过使用::指定模块来最小化缩进:moduleTop::FooclassFailure这失败了:NameError:uninitializedconstantTop::Foo::Test这是一个错误,还是仅仅是Ruby解析变量名的方式的逻辑结果? 最佳答案 Isthisabug,or

    5. ruby - 获取模块中定义的所有常量的值 - 2

      我想获取模块中定义的所有常量的值:moduleLettersA='apple'.freezeB='boy'.freezeendconstants给了我常量的名字:Letters.constants(false)#=>[:A,:B]如何获取它们的值的数组,即["apple","boy"]? 最佳答案 为了做到这一点,请使用mapLetters.constants(false).map&Letters.method(:const_get)这将返回["a","b"]第二种方式:Letters.constants(false).map{|c

    6. ruby - 模块嵌套代码风格偏好 - 2

      我的假设是moduleAmoduleBendend和moduleA::Bend是一样的。我能够从thisblog找到解决方案,thisSOthread和andthisSOthread.为什么以及什么时候应该更喜欢紧凑语法A::B而不是另一个,因为它显然有一个缺点?我有一种直觉,它可能与性能有关,因为在更多命名空间中查找常量需要更多计算。但是我无法通过对普通类进行基准测试来验证这一点。 最佳答案 这两种写作方法经常被混淆。首先要说的是,据我所知,没有可衡量的性能差异。(在下面的书面示例中不断查找)最明显的区别,可能也是最著名的,是你的

    7. ruby - 寻找通过阅读代码确定编程语言的ruby gem? - 2

      几个月前,我读了一篇关于ruby​​gem的博客文章,它可以通过阅读代码本身来确定编程语言。对于我的生活,我不记得博客或gem的名称。谷歌搜索“ruby编程语言猜测”及其变体也无济于事。有人碰巧知道相关gem的名称吗? 最佳答案 是这个吗:http://github.com/chrislo/sourceclassifier/tree/master 关于ruby-寻找通过阅读代码确定编程语言的rubygem?,我们在StackOverflow上找到一个类似的问题:

    8. ruby-on-rails - 使用 config.threadsafe 时从 lib/加载模块/类的正确方法是什么!选项? - 2

      我一直致力于让我们的Rails2.3.8应用程序在JRuby下正确运行。一切正常,直到我启用config.threadsafe!以实现JRuby提供的并发性。这导致lib/中的模块和类不再自动加载。使用config.threadsafe!启用:$rubyscript/runner-eproduction'pSim::Sim200Provisioner'/Users/amchale/.rvm/gems/jruby-1.5.1@web-services/gems/activesupport-2.3.8/lib/active_support/dependencies.rb:105:in`co

    9. 网络编程套接字 - 2

      网络编程套接字网络编程基础知识理解源`IP`地址和目的`IP`地址理解源MAC地址和目的MAC地址认识端口号理解端口号和进程ID理解源端口号和目的端口号认识`TCP`协议认识`UDP`协议网络字节序socket编程接口`sockaddr``UDP`网络程序服务器端代码逻辑:需要用到的接口服务器端代码`udp`客户端代码逻辑`udp`客户端代码`TCP`网络程序服务器代码逻辑多个版本服务器单进程版本多进程版本多线程版本线程池版本服务器端代码客户端代码逻辑客户端代码TCP协议通讯流程TCP协议的客户端/服务器程序流程三次握手(建立连接)数据传输四次挥手(断开连接)TCP和UDP对比网络编程基础知识

    10. ruby-on-rails - Controller 中的 Rails 辅助模块 - 2

      我有一个Controller,我想为这个Controller创建一个助手,我可以在不包含它的情况下使用它。我尝试像这样创建一个与Controller同名的助手classCars::EnginesController我创建的助手是moduleCars::EnginesHelperdefcheck_fuellogger.debug("chekingfuel")endend我得到的错误是undefinedlocalvariableormethod`check_fuel'for#有没有我遗漏的约定? 最佳答案 如果你真的想在Controll

    随机推荐