usexpressmain.js 4.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. 
  2. var us = {}; //注册命名空间。
  3. //----------------------------------------引用包含系统模块---------------------------------
  4. us.http = require('http'); //引用包含http处理类
  5. us.querystring = require("querystring"); //引用获取参数类
  6. us.url = require("url"); //引用url地址处理类
  7. //-----------------------------------------引用包含用户模块---------------------------------
  8. //us._usdb = require('./us.db.js'); //包含另外一个文件
  9. //us.mongodb = require('./us.mongodb.js'); //引用mongodb数据库文件
  10. //-------------------引入express模块,如果此处出错,请确认express已安装,------------------
  11. //而且express在环境变量NODE_PATH目录中
  12. var express = require('express');
  13. //创建web服务
  14. var app = express();
  15. //以当前目录下的demo目录为web应用根目录
  16. app.use(express.static(__dirname + '/'));
  17. //显示错误信息,以方便调试
  18. //app.use(express.errorHandler({
  19. // showStack: true,
  20. // dumpExceptions: true
  21. //}));
  22. app.all("*", function (req, res) {
  23. //备注:res.writeHead(200, {'Content-Type': 'text/plain'});//英文编码
  24. //备注:传递表单需要添加,'application/x-www-form-urlencoded'
  25. //备注:Access-Control-Allow-Origin解决ie10跨域,还未完全其他跨域,如chrome等,需要进一步完善。
  26. //备注:"Content-Type": "text/html;charset=utf-8"解决nodejs连接mysql中文编码问题
  27. //备注:'Access-Control-Allow-Origin': '*' 解决nodejs Access-Control-Allow-Origin不允许跨域调用的问题。现在用端口有这个问题,以后需要移除。
  28. //console.log("ok");没有调试模式,只能用这个输出错误。
  29. //下面的头查了大概1周时间,必须这样写。
  30. 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' });
  31. debugger;
  32. //nodejs接收参数也要异步,编程起来就有点麻烦了,注意产生闭包情况。
  33. //NodeJS引擎中许多对象都有预定的事件,如用户在发送http请求之后获得的http.ServerRequest对象就有data和end两个事件,
  34. //其中data指接收到响应信息正文中的一部分时会触发此事件,end指完全接收完信息后都会触发一次。开发人员如果想处理响应,则需要注册回调函数
  35. //on('data') 事件 只有post 请求才能触发,由于1473都是post,所以研究这一块,传统的get方式是不一样的。
  36. var params = '';
  37. //获取参数中
  38. req.on('data', function (chunk) { params += chunk; });
  39. //获取参数结束。
  40. req.on('end', function () {
  41. //querystring.parse可以把形如mode=select&test=1111的字符串拆分成一个json对象,不过这个对象很奇怪,直接输出这个对象会报错
  42. var _postJson = us.querystring.parse(params);
  43. console.log(_postJson);
  44. //只能通过以下方式获取其中的值。这就有一定的局限性。。还需要研究。
  45. var _mode = _postJson.mode; //前台传递进来的插入删除等模式
  46. var _usjson = _postJson.usjson; //前台传递进来的参数
  47. switch (_mode) {
  48. case "select":
  49. //访问mysql数据库
  50. us._usdb.aaaaaa(function (results) { res.end(results); });
  51. //us._usdb.usproselect("CALL PB_Select();", function (results) { res.end(results); });
  52. //访问mongodb数据库
  53. //us.mongodb.select("aaaaatest", function (results) { res.end(results); });
  54. //访问mongodb存储过程
  55. //us.mongodb.pro("test", function (results) { res.end(results); });
  56. //us.mongodb.testparam("ttt", function (results) { res.end(results); });
  57. break;
  58. case "insert": res.end(_usjson); break;
  59. default: res.end("default 1473"); break;
  60. }
  61. //res.end(_mode);
  62. });
  63. //备注第一个参数为构建连接字符串,第二个参数为异步查询数据库结束后调用的回调函数
  64. //_usdb.usselect('SELECT * FROM ' + 'PBDirectory ' + 'limit 10', function (results) {if (results === 'false') { throw Error; } else { res.end(results);}});//加错误处理
  65. //_usdb.usselect('SELECT * FROM ' + 'PBDirectory ' + 'limit 10', function (results) { res.end(results);});\
  66. //res.end("\n node js end! ");
  67. });
  68. //启动express web服务,监听8080端口
  69. app.listen(1337);
  70. console.log('UseStudio Nodejs Express is Listening on http://nodejs.1473.cn:1337/:'); //提示