实时聊天:利用Modulus和Node.js实现

在本教程中,我将向您展示如何使用 node.JS、socket.io 和 mongodb 实现一个实时聊天应用程序,然后我们将该应用程序一起部署到 modulus。

首先,让我向您展示我们将在文章末尾看到的应用程序的最终外观。

实时聊天:利用Modulus和Node.js实现

node.js 将成为应用程序的核心,express 作为 mvc,MongoDB 作为数据库,Socket。 IO用于实时通信。完成后,我们将把应用程序部署到 Modulus。 MongoDB 部分实际上存在于 Modulus 内部。

1. 场景

  1. John 想要使用我们的应用程序,并在浏览器中打开它。
  2. 在第一页上,他选择聊天期间使用的昵称,然后登录聊天。
  3. 他在文本区域中写了一些内容,然后按 Enter。
  4. 文本将发送至 restful 服务 (Express),并将该文本写入 MongoDB。
  5. 在 MongoDB 中写入之前,相同的文本将广播给当前登录聊天应用的用户。

如您所见,这是一个非常简单的应用程序,但它几乎涵盖了 Web 应用程序的所有内容。该应用程序中没有频道系统,但您可以fork源代码并实现频道模块进行练习。

2.从头开始进行项目设计

我将尝试先解释该项目的各个小部分,然后在最后将它们组合起来。我将从后端开始到前端。那么,让我们从域对象(MongoDB 模型)开始。

2.1。型号

对于数据库抽象,我们将使用 Mongoose。在这个项目中,我们只有一个模型,名为 Message 这个消息模型只包含 text, createDate, 和 作者作者没有像User这样的模型,因为我们不会完全实现用户注册/登录系统。将会有一个简单的昵称提供页面,并且该昵称将被保存到Cookie中。这将在 Message 模型中用作 author 字段中的文本。您可以在下面看到一个示例 json 模型:

{      text: "Hi, is there any Full Stack Developer here?"      author: "john_the_full_stack",      createDate: "2015.05.15"  } 

为了创建这样的文档,您可以使用下面的 Mongoose 函数来实现模型:

var mongoose = require('mongoose')    var Message = new mongoose.Schema({      author: String,      message: String,      createDate: {          type: Date,          default: Date.now      }  });    mongoose.model('Message', Message) 

只需导入 Mongoose 模块,使用 JSON 格式的字段和字段属性定义模型,然后创建名为 Message 的模型。该模型将包含在您要使用的页面中。

也许您有疑问,当我们已经在同一频道中向用户广播此消息时,为什么我们要将消息存储在数据库中。确实,您不必存储聊天消息,但我只是想解释一下数据库集成层。不管怎样,我们将在我们的项目中的控制器中使用这个模型。控制器?

2.2。控制器

正如我之前所说,我们将在 MVC 部分使用 Express。而C 这里代表的是Controller。对于我们的项目,只有两个消息传递端点。其中之一是加载最近的聊天消息,第二个是处理发送的聊天消息存储在数据库中,然后广播到频道中。

.....  app.get('/chat', function(req, res){      res.sendFile(__dirname + '/index.html');  });    app.get('/login', function(req, res){      res.sendFile(__dirname + '/login.html');  });    app.post('/messages', function(req, res, next) {      var message = req.body.message;      var author = req.body.author;      var messageModel = new Message();      messageModel.author = author;      messageModel.message = message;      messageModel.save(function (err, result) {         if (!err) {             Message.find({}).sort('-createDate').limit(5).exec(function(err, messages) {                 io.emit("message", messages);             });             res.send("Message Sent!");         } else {             res.send("Technical error occurred!");         }      });  });    app.get('/messages', function(req, res, next) {      Message.find({}).sort('-createDate').limit(5).exec(function(err, messages) {          res.json(messages);      });  });  ..... 

第一个和第二个控制器仅用于为聊天和登录页面提供静态 HTML 文件。第三个用于处理对 /messages  端点的发布请求,以创建新消息。在该控制器中,首先将请求正文转换为 Message 模型,然后使用 Mongoose 函数 save.  

我不会深入研究 Mongoose – 您可以查看文档以了解更多详细信息。你可以为save函数提供一个回调函数来检查是否有问题。如果成功,我们将按 createDate 降序获取最后 5 条记录,并向频道中的客户端广播 5 条消息。

好的,我们已经完成了 MC。 让我们切换到 View 部分。

2.3。查看

一般来说,Express 中可以使用 Jade、EJS、Handlebars 等模板引擎。然而,我们只有一个页面,那就是一条聊天消息,所以我将静态地提供它。实际上,正如我上面所说,还有两个控制器来服务这个静态 HTML 页面。您可以看到以下内容用于提供静态 HTML 页面。

app.get('/chat', function(req, res){      res.sendFile(__dirname + '/index.html');  });    app.get('/login', function(req, res){      res.sendFile(__dirname + '/login.html');  }); 

此端点仅使用 res.sendFile 提供 index.html 和 login.html。  index.html 和 login.html 与 server.js 位于同一文件夹中,这就是我们在 HTML 文件名之前使用 __dirname 的原因。

2.4。前端

在前端页面中,我已经使用了bootstrap,无需解释我是如何做到这一点的。简单来说,我将一个函数绑定到一个文本框,每当您按下Enter键或发送按钮时,消息就会发送到后端服务。

该页面还有一个必需的Socket.IO js文件,用于监听名为message的频道。 Socket.IO 模块已在后端导入,当您在服务器端使用此模块时,它会自动添加一个端点来提供 Socket.IO js 文件,但我们使用由 cdn 。每当有新消息进入此频道时,都会自动检测到该消息,并且消息列表将刷新为最后 5 条消息。

<script>          var socket = io();          socket.on("message", function (messages) {              refreshMessages(messages);          });            function refreshMessages(messages) {              $(".media-list").html("");              $.each(messages.reverse(), function(i, message) {                  $(".media-list").append('<li class="media"><div class="media-body"><div class="media"><div class="media-body">'                  + message.message + '<br/><small class="text-muted">' + message.author + ' | ' + message.createDate + '<hr/>');              });          }            $(function(){                if (typeof $.cookie("realtime-chat-nickname") === 'undefined') {                  window.location = "/login"              } else {                  $.get("/messages", function (messages) {                      refreshMessages(messages)                  });                    $("#sendMessage").on("click", function() {                      sendMessage()                  });                    $('#messageText').keyup(function(e){                      if(e.keyCode == 13)                      {                          sendMessage();                      }                  });              }                function sendMessage() {                  $container = $('.media-list');                  $container[0].scrollTop = $container[0].scrollHeight;                  var message = $("#messageText").val();                  var author = $.cookie("realtime-chat-nickname");                  $.post( "/messages", {message: message, author: author}, function( data ) {                      $("#messageText").val("")                  });                  $container.animate({ scrollTop: $container[0].scrollHeight }, "slow");              }          })      </script>

上面的代码中还有一项检查:cookie 部分。如果您没有选择任何聊天昵称,则表示该昵称没有设置cookie,您将自动重定向到登录页面。

如果没有,最后五条消息将通过对 /messages 端点的简单 ajax 调用来获取。同样,每当您点击发送按钮或按Enter键时,都会从文本框中提取短信,并从文本框中提取昵称。 cookie,这些值将通过 post 请求发送到服务器。这里没有严格检查昵称,因为我想关注实时部分,而不是用户身份验证部分。

正如你所看到的,项目的整体结构非常简单。让我们进入部署部分。正如我之前所说,我们将使用 Modulus,它是用您选择的语言部署、扩展和监控应用程序的最佳 paas 之一。

3.部署

3.1。先决条件

我首先想到的是向您展示如何部署,但为了成功部署,我们需要一个工作数据库。我们来看看如何在Modulus上创建数据库,然后进行部署。

创建帐户后转至 Modulus 仪表板。点击左侧的数据库菜单,然后点击创建数据库。

实时聊天:利用Modulus和Node.js实现

在弹出表单中填写必填字段,如下所示。

实时聊天:利用Modulus和Node.js实现

当您填写必填字段并点击创建时,它将创建一个 MongoDB 数据库您将在屏幕上看到您的数据库 URL。我们将使用 MONGO URI 因此请复制该 URI。

实时聊天:利用Modulus和Node.js实现

在我们的项目中,Mongo URI是从环境变量MONGO_URI中获取的,您需要在仪表板中设置该环境变量。转到信息中心,点击项目菜单,在列表中选择您的项目,然后点击左侧菜单中的管理。在此页面中,向下滚动页面时您将看到环境变量部分,如下所示。

实时聊天:利用Modulus和Node.js实现

您可以通过两种方式部署到 Modulus:

  • 使用仪表板上传项目 ZIP 文件
  • 使用 Modulus CLI 从命令行进行部署

我将继续使用命令行选项,因为另一个很容易做到。首先,安装 Modulus CLI:

npm install -g modulus 

转到您的项目文件夹并执行以下命令以登录 Modulus。

modulus login 

当您执行上述命令时,系统会提示您输入用户名和密码:

实时聊天:利用Modulus和Node.js实现

如果您已使用 github 创建帐户,则可以使用 –github 选项.

modulus login --github 

现在您已登录 Modulus,可以创建项目了。使用以下命令创建项目:

modulus project create "Realtime Chat" 

当您运行此函数时,系统会询问您运行时。选择第一个选项,即 Node.js,第二个选项将询问您伺服器的大小,您可以保留默认值。

实时聊天:利用Modulus和Node.js实现

我们已经创建了一个项目,这次我们将把当前项目部署到Modulus中。执行以下命令将当前项目发送到Modulus端的Realtime Chat项目中。

modulus deploy 

它将部署您的项目,并且您将在成功部署消息的末尾获得正在运行的项目 URL:

Realtime Chat running at realtime-chat-46792.onmodulus.net 

如您所见,部署到 Modulus 非常简单!

Modulus CLI 具有非常有用的命令,可在项目部署或运行​​时使用。例如,为了跟踪正在运行的项目的日志,您可以使用 modulus 项目日志 tail,创建 MongoDB 数据库使用 modulus mongo create ,要设置环境变量,请使用 modulus env set 等。您可以使用 Modulus 帮助查看完整的命令列表。

结论

本教程的主要目的是向您展示如何使用 Node.js、Socket.IO 和 MongoDB 创建实时聊天应用程序。为了在生产中运行项目,Modulus 被用作 PaaS 提供商。 Modulus 的部署步骤非常简单,而且它还为我们的项目提供了一个内部数据库(MongoDB)。除此之外,您还可以在 Modulus 仪表板中使用非常有用的工具,例如日志、通知、自动缩放、数据库管理等。

要注册 Modulus,请点击此处,成为 Tuts+ 读者即可额外获得 10 美元。使用促销代码ModulusChat10

有关 Modulus 企业产品的更多信息,请点击此处。

© 版权声明
THE END
喜欢就支持一下吧
点赞7 分享