Popush代码学习报告

Popush代码学习报告

为了在Popush源代码上更好地进行二次开发,我们在之前这几天分别对其代码进行了学习和研究。

整体架构

Popush的后端采用js开发,Node.js作为运行环境,数据库为MongoDB,MVC的架构,socket.io作为数据传输。

Model

相关代码在/static/js/models下,其中包括user、file、expression。

user

即用户,包含name、avatar、online、owner属性,其中name为主键。

file

文件模型包含path、type、owner、members、createTime、modifyTime、permission属性,和路径的编码解码等函数,其中createTime为主键。

expression

此为调试时的表达式,包含expression(表达式)、value(值)、notnew属性。

View

相关代码在/static/js/views下,包含各个事件处理视图,是前端和逻辑的连接点。其中包括注册、登录、分享、调试等视图,在此不再赘述。

Controller

room

控制器room是Popush的一个特色,它描述的是一个被打开的文件,其中包括编辑器、聊天室、控制台、语音等。其中break表示断点与调试,chat表示聊天室和控制台,data表示room的数据,editor表示编辑器,room表示关于进出房间的事务,run表示运行,voice表示语音。

具体事务逻辑流程举例——登录

1.      在login-view.js的login函数中,取得文本框中的帐号和密码,在非空和attch判断后,用socket将输入的帐号、密码发送出去。

2.      在根目录的app.js中,包含socket的各种事务处理。在socket.on(‘login’, function(data){..})中,通过userDAO将帐号和密码与数据库中的比对。值得一提的是,userDAO是一个封装好的面向对象的数据库接口,其余各种xxxDAO一样。

3.      在userDAO中可以看到,帐号和密码用md5进行了多重加密,然后查询数据库的user数据进行判断并返回判断结果。

4.      若错误,则重新登录,否则登录成功并将用户放进session,表示当前的登录用户。

总结

从上述事务逻辑中可以发现,程序中事务的处理非常规范高效,严格按照mvc的模式执行,有很好的封装性和安全性。其中对可能出现的异常、内部错误也进行判断,使得整个程序有很好的鲁棒性。

这周开始,我们将开始写代码,按照之前提出的功能需求,一步两步一步两步地完成优化和增加功能。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值