node.js+mysql+html实现简易数据库管理系统

程序入口是app.js。通过signin.js与mysql数据库取得连接。controller.js的作用是扫描controller目录下的各个js文件,并将这些文件处理过的URL记录到map里面,这个map是映射的意思,可以简单理解为哈希表,浏览器在工作时遇到post或get请求可以迅速在这个映射表中找到相应文件的url并执行。在本proj中我们只要用到post和get两种请求就可以(实际上还有put和delete两种请求,只不过我们没用到)。以上是程序的最外层。

controller目录下的所有js模块都是URL处理函数的集合。每个模块处理相应的URL,生成对应的post和get请求,在module.export中暴露出来,以便addmapping处理。get请求是浏览器的主动获取,当我们在浏览器上输入get请求的url“代号”,浏览器会主动抓取这个代号所指向的url,获取文件的所有内容。我们这次程序中,每个get请求的url代号都指向一个html文件,于是浏览器就执行html文件。唯一不同的就是image.js文件,这个文件是用来处理两张背景图的url,也是生成get请求。

views目录下是html+css+js,主要用于页面效果的展示。css文件就是样式表,没什么可讲的。每个html文件中都包括一个处理该页面数据的script脚本链接。我们这里用的是最流行也是最好用的jquery,于是要接入jquery的js模块。同时,我们是通过views目录下的各个与html同名的js文件来做中介处理前端和后台之间的联系。于是html文件中还要加上这个js模块的脚本链接。

还是在views目录下。讲完了html,我们来讲讲views目录下的各个js模块。这个js模块是为了响应与它同名的html文件中的事件,处理html中用户输入的数据。模块用到了.ajax方法。解释一下ajax各个参数的意义。data是发送到服务器(不是浏览器)的数据。datatype是预期服务器会返回的数据类型,(不指定的话似乎好像也会自动判断?)我们这里设置成json格式,因为这是轻量级数据交互格式,后面会讲到。async参数是true或false,我们这里是同步请求,所以设置成false,这样一来,同步请求将锁住浏览器,用户其它操作必须等待请求完成才可以执行。success参数是请求成功后的回调函数,它的参数是由服务器根据datatype参数进行处理过并返回的数据。url参数是发送请求的地址。type参数是请求的方式。

接下来就是最重要的前端数据处理了。controller目录下的各个js文件里除了生成get请求的url地址,还有一个重要的工作就是将各个处理数据的模块各自生成post请求的url地址。通过views目录下的js文件将前端数据调用post请求对应的url进行处理,处理的数据再发送到前端。交互过程主要是再上文所述的views目录下的各个js文件,不再赘述。

整个程序实现的核心在于async函数。这个函数需要node.js 7.6及以上的版本才能支持(我目前用的是7.8)。这个函数专门用于处理异步请求,函数有两个参数(ctx,next)。函数是以中间件的形式实现。(然而我还不是很理解这个概念orz)。ctx对象可以访问前台的数据,通过ctx.request,也可以将处理完的数据返回到前台,通过ctx.response。尤其要注意的是async要配合await使用,一个async里面一定要出现await才能将这个函数加入到中间件里面,否则程序运行到这里后会中断,无法再访问后续的中间件成员。async函数其实是高度格式化的一个东西,使用时遵循这些格式,就不会发生奇怪的错误。

从三月下旬开始学习js和html,今天下午通过了春学期数据库proj验收,这次proj我受到了黄雨生大佬在git上的项目很大的启发,前后台交互的一些东西是学习他的,后台的实现则是自己写的,html和css是队友们调的。这里一并感谢他们。

转载于:https://www.cnblogs.com/KRCheung/p/6703012.html

这个系统其实是出于学习nodejs的目的而改写的系统。 原来的系统前端使用了extjs4.2.1,后端使用了PHP5.4和ZEND框架开发,后台数据库是用mongodb2.2.2。 我抽离出了原来系统中的账户管理,角色管理,菜单管理,权限管理这4个部分, 我想这4个部分,基本上所有的系统都会用到。具有一定的普遍性。所以将这4个部分用nodejs重新改写了。 该系统目前使用模块有express,ejs,connect-mongo,mongodb,express-partials,connect-flash,fibers,wind等 其实wind模块这次系统中没有使用。可以将它排除出去。我是出于学习wind的目的,才加入这个模块的。 本来准备使用wind模块,是为了实现同步的目的,由于后来改用了fibers模块之后,就没有使用它。这里说明一下 不是fibers要比wind好,而是我暂时不能理解wind,或则是说对wind的研究不够吧。 众所周知nodejs是推崇异步模式。但是这个系统是从php过来的,而php的代码是同步模式的写法,所以为了在改写的过程中 希望 1是代码改动最少 2是同步写法更加适合思维习惯。而且代码可读性高的目的,用到了fibers。 这个系统的源代码中有些js文件里保留了一些原来的PHP代码,这是出于代码对比的目的。 是让大家了解原来的php代码是怎么实现的,用nodejs之后是如何改写的。通过对比,大家会发现 其实通过使用fibers之后,几乎两者是一模一样的。 还有源代码中还保留了一些被注释掉的函数,有些是用到了wind,有些是用到了fibers,有些是直接异步的写法。 这些内容都是在开发过程中我不断尝试后的产物。我花了1周的时间才实现了一个递归的调用,而且还是同步的方式。 到目前为止,我还不能理解在异步模式下实现递归调用函数。比如说源代码中有个函数getMenuTree,菜单下面可能有子菜单, 子菜单的下面可能还有菜单。所以是一个递归的过程。我现在是同步的写法实现了这个函数,如果有人能够提供异步写法实现的递归函数并 emai给我,我不胜荣幸。 在使用本系统之前,必须要安装nodejs 0.10.10,mongodb2.2.2,python2.7.5至于安装的方法请googel解决。 将源代码下载之后,解压到某个目录下,比如说d:\nodejs\umav4simple目录。 进入到那个目录, a)运行以下命令 npm install express npm install ejs npm install connect-mongo npm install mongodb npm install express-partials npm install connect-flash npm install fibers npm install wind 尽管在源代码中已包含了这些模块,但是最好还是要重新运行一遍。 因为有些模块可能需要重新的编译。 比如说fibers模块,我在window下运行npm install fibers的时候编译了一个win32-ia32-v8-3.14 而在linux下重新编译了linux-ia32-v8-3.14。所以说根据操作系统的不同,可能会有一些不同。 以免造成想不到的错误。 b)打开settings.js,并且将你的mongodb的设置改写并保存。 c)运行node app.js或则node cluster.js 如果没有提示错误的话,那么就说明环境配置成功了。 d)通过以下的URL可以在mongodb中追加一些数据,不过只能运行一次。否则会重复追加数据。 浏览器上输入 http://localhost:3000/admin/index/install 做完之后, 浏览器上输入http://localhost:3000/ 就通过用户名admin 密码adminadmin进行登录,并使用这个系统了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值