123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138 |
- /*
- nodejs 业务逻辑使用
- 此文件为nodejs业务逻辑模块
- 上下的注释为业务测试注释
- */
- var us = {}; //注册命名空间。
- //-------------------引入express模块,如果此处出错,请确认express已安装,------------------
- //而且express在环境变量NODE_PATH目录中
- var express = require('express');
- //创建web服务
- var app = express();
- //以当前目录下的demo目录为web应用根目录
- app.use(express.static(__dirname + '/'));
- //显示错误信息,以方便调试
- //app.use(express.errorHandler({
- // showStack: true,
- // dumpExceptions: true
- //}));
- //----------------------------------------引用包含系统模块---------------------------------
- us.http = require('http'); //引用包含http处理类
- us.querystring = require("querystring"); //引用获取参数类
- us.url = require("url"); //引用url地址处理类
- //-----------------------------------------引用包含用户模块---------------------------------
- //us._usdb = require('./us.db.js'); //包含另外一个文件
- us.mongodb = require('./us.mongodb.js'); //引用mongodb数据库文件
- us.mysql = require('./us.mysql.js'); //引用mysql数据库文件,感觉mongodb处理传统数据还是有缺陷
- us.cookie = require('./us.cookie.js'); //javascript处理Cookie.
- //----------------------------------------接受http请求--------------------------------------
- app.all('/', function (req, res) {
- //us.http.createServer(function (req, res) {
- //备注:res.writeHead(200, {'Content-Type': 'text/plain'});//英文编码
- //备注:传递表单需要添加,'application/x-www-form-urlencoded'
- //备注:Access-Control-Allow-Origin解决ie10跨域,还未完全其他跨域,如chrome等,需要进一步完善。
- //备注:"Content-Type": "text/html;charset=utf-8"解决nodejs连接mysql中文编码问题
- //备注:'Access-Control-Allow-Origin': '*' 解决nodejs Access-Control-Allow-Origin不允许跨域调用的问题。现在用端口有这个问题,以后需要移除。
- //console.log("ok");没有调试模式,只能用这个输出错误。
- //res.writeHead(200, { "Content-Type": "text/html;charset=utf-8", "Access-Control-Allow-Origin": "http://d.1473.cn", "access-control-allow-headers": "Origin" });
- //解决Chrome浏览器跨域问题。
- //res.writeHead(200, { "Content-Type": "text/html;application/json;charset=utf-8", 'Access-Control-Allow-Origin': '*', 'Access-Control-Allow-Headers': 'Origin, No-Cache, X-Requested-With, If-Modified-Since, Pragma, Last-Modified, Cache-Control, Expires, Content-Type, X-E4M-With' });
- res.writeHead(200, { "Content-Type": "text/html;application/json;charset=utf-8", 'Access-Control-Allow-Origin': '*', 'Access-Control-Allow-Headers': 'Origin, No-Cache, X-Requested-With, If-Modified-Since, Pragma, Last-Modified, Cache-Control, Expires, Content-Type, X-E4M-With' });
- //console.log(us.querystring.parse(req.headers.cookie)); //前台cookie
- debugger;
- //nodejs接收参数也要异步,编程起来就有点麻烦了,注意产生闭包情况。
- //NodeJS引擎中许多对象都有预定的事件,如用户在发送http请求之后获得的http.ServerRequest对象就有data和end两个事件,
- //其中data指接收到响应信息正文中的一部分时会触发此事件,end指完全接收完信息后都会触发一次。开发人员如果想处理响应,则需要注册回调函数
- //on('data') 事件 只有post 请求才能触发,由于1473都是post,所以研究这一块,传统的get方式是不一样的。
- var params = '';
- //获取参数中
- req.on('data', function (chunk) { params += chunk; });
- //获取参数结束。
- req.on('end', function () {
- //querystring.parse可以把形如mode=select&test=1111的字符串拆分成一个json对象,不过这个对象很奇怪,直接输出这个对象会报错
- var _postJson = us.querystring.parse(params);
- console.log(params);
- if (params == "") { console.log("参数为空!"); res.end(""); return; } //传递参数出错的情况下,保证后台不报错,还真奇怪啊。居然有时候可以有时候不可以,难道跨域检测机制有问题?
- //只能通过以下方式获取其中的值。这就有一定的局限性。。还需要研究。
- var _usparams = _postJson.mode; //前台传递进来的插入删除等模式
- _usparams = _usparams.split(","); //作为一个数组传递,不再拆分,可以让后台极度简化
- var _mode = _usparams[0]; //mode为switch中的路径参数.数组中剩下的为实际参数。暂时没有用处了
- //判断是mysql还是mongodb。分流。mysql是参数0,作为唯一标识。
- if (_usparams[0] == "mysql") {
- // var i; //定义循环变量,对字符串解密
- // for (i = 0; i < _usparams.length; i++) { _usparams[i] = decodeURIComponent(_usparams[i]); } //解密中文字符串。
- // var _mode = _usparams[1];
- // console.log(_mode);
- // switch (_mode) {
- // ////_n名字 _b简介 -i图片 _p价格。
- // case "Add_Develop": us.mysql.usselect("CALL Add_Develop('" + _usparams[2] + "','" + _usparams[3] + "','" + _usparams[4] + "','" + _usparams[5] + "','" + _usparams[6] + "','" + _usparams[7] + "','" + _usparams[8] + "','" + _usparams[9] + "','" + _usparams[10] + "','" + _usparams[11] + "','" + _usparams[12] + "')", function (results) { res.end(results); }); break;
- // case "Select_One": us.mysql.usselect("CALL Select_One('" + _usparams[2] + "')", function (results) { res.end(results); }); break;
- // case "Select_All": us.mysql.usselect("CALL Select_All('" + _usparams[2] + "','" + _usparams[3] + "')", function (results) { res.end(results); }); break;
- // default: res.end("default");
- // }
- //截取掉参数1,因为是mongodb还是mysql的标志。monogdb采用默认的,没有这个参数
- _usparams.splice(0, 1);
- us.mysql.usselect(_usparams, function (results) { res.end(results); });
- }
- else {
- //后台代码简化为一句话。传递req,Cookie处理类,参数数组就可以了。
- us.mongodb.US_CommonPro(req, us.cookie, _usparams, function (results) { res.end(results); });
- }
- // switch (_mode) {
- // case "Select_OneUserByID":
- // //console.log(_usparams[1]);
- // //选取一个用户的树目录
- // //us.mongodb.SelectOneUserByID("SelectOneUserByID", _usparams[1], function (results) { res.end(results); }); break;
- // us.mongodb.US_CommonPro(_usparams, function (results) { res.end(results); }); break;
- // default: break;
- // }
- //nodejs和其他程序语言不一样,在执行选取的过程中,照样会执行后面的代码,结果后面的代码先执行到res.end("false");导致返回false。所以default中不能返回res.end("false");
- //cookie判断,是否有权限做增加删除修改操作。用户id一定是传到第一个参数里面
- // if (us.cookie.IsloginId(req, _usparams[1])) {
- // switch (_mode) {
- // case "Add_Folder":
- // //添加项目或者文件夹,通用一个函数,区分在于节点深度为2的全部是项目,根节点深度为1.其他全部是文件夹。
- // //1为用户id,2为父亲节点id,3为父亲节点深度,4为节点id,5为节点名字。
- // us.mongodb.Add_Folder("Add_Folder", _usparams[1], _usparams[2], _usparams[3], _usparams[4], _usparams[5], function (results) { res.end(results); }); break;
- // case "Add_File":
- // //添加项目或者文件夹,通用一个函数,区分在于节点深度为2的全部是项目,根节点深度为1.其他全部是文件夹。
- // us.mongodb.Add_File("Add_File", _usparams[1], _usparams[2], _usparams[3], _usparams[4], _usparams[5], function (results) { res.end(results); }); break;
- // case "Delete_Folder":
- // us.mongodb.Delete_Folder("Delete_Folder", _usparams[1], _usparams[2], _usparams[3], function (results) { res.end(results); }); break;
- // case "Update_Folder":
- // us.mongodb.Update_Folder("Update_Folder", _usparams[1], _usparams[2], _usparams[3], _usparams[4], function (results) { res.end(results); }); break;
- // case "Update_FileContent":
- // console.log(_usparams[1]); console.log(_usparams[2]); console.log(_usparams[3]); console.log(_usparams[4]);
- // us.mongodb.Update_FileContent("Update_FileContent", _usparams[1], _usparams[2], _usparams[3], _usparams[4], function (results) { res.end(results); }); break;
- // default: break; //默认返回false,以利于前台判断。
- // }
- // }
- //res.end(_mode);
- });
- //备注第一个参数为构建连接字符串,第二个参数为异步查询数据库结束后调用的回调函数
- //_usdb.usselect('SELECT * FROM ' + 'PBDirectory ' + 'limit 10', function (results) {if (results === 'false') { throw Error; } else { res.end(results);}});//加错误处理
- //_usdb.usselect('SELECT * FROM ' + 'PBDirectory ' + 'limit 10', function (results) { res.end(results);});\
- //res.end("\n node js end! ");
- });
- //.listen(1337, "d.1473.cn");
- //console.log('Server running at http://d.1473.cn:1337/');
- //上面2行代码必须转换为域名,否则会跨域错误,或者使用express框架,把整个目录包含进去/// <reference path="us.mongodb.js" />
- app.listen(1337, "d-back.1473.cn"); //启动express web服务,监听1337端口
- console.log('express Server running at http://d-back.1473.cn:1337/');
|