【后台管理系统】04.node.js

一、node.js是什么?

node.js是一个基于Chrome V8引擎的JavaScript运行时。

node.js是一个环境。

二、commonJs规范(模块化)

规范定义

1.每个文件都是一个模块,都有自己的作用域

2.在模块内部,module变量代表自身

3.module.exports提供对外接口

//b.js想要用a.js的变量test1

//a.js
var test1 = 888;
var test2 = 999;
function fn1(){
    console.log("fn1");
}

module.exports.test1 = test1;
module.exports.f = fn1;

require语法

1./代表绝对路径,./代表相对路径

2.默认后缀:.js .json .node

3.require('http') ==> node_modules

//b.js想要用a.js的变量test1

//b.js
var mod = require('./a.js');
//var mod = require('./a');

console.log(mod.test1);//888
console.log(mod.test2);//undefined
mod.f();//fn1
//在命令行执行node b.js可查看结果

三、global(全局对象)

//b.js想要用a.js的变量test1

//a.js
var test1 = 888;
global.test2 = 999;

module.exports.test1 = test1;

//b.js
var mod = require('./a.js');

console.log(mod.test1);//888
console.log(mod.test2);//undefined
console.log(test2);//999

四、npm

1.npm -v:查看版本

2.初始化项目
npm init        //执行后生成一个package.json文件

3.下载:
npm install xxx:把xxx模块下载到当前目录下
****简写:npm i xxx

4.下载方式:
npm install xxx -g:全局,在哪个目录都能用
npm install xxx -S:局部,生产环境
npm install xxx -D:局部,开发环境

//下载的文件在node_modules文件夹中,并同步在package.json文件中做一个描述。
 

五、package.json

项目的描述文件

可以通过执行npm install命令下载package.json中所描述的环境

六、上传自己的npm包

1.npm官网注册一个账号
官网:npm

2.初始化项目

在相应文件夹下执行命令:npm init
执行完后文件夹下会生成package.json文件

在当前路径下新建一个文件index.js,内容如下

module.exports.sayHello = function(){
    return 123;
}

1.登录:打开终端,在当前路径下输入:npm login
2.上传npm包:登录成功后输入:npm publish
如果报错,可能是因为package.js文件中"name"变量的值为默认的"npms",与别人的名字冲突了,我们需要自己起一个,例如"name": "lingqi"。
+ 代表上传成功
3.下载:npm i lingqi

七、get请求

1.get请求url数据操作

前台发送get请求,后台如何拿到数据并解析数据

//这是一个html文件的一部分
<a href = "http://localhost:8080/content.html?id=2&title=这是文章标题">进入详情页</a>

 1.得到路径:req.url

//server.js
const http = require("http");
const server = http.createServer((req,res)=>{
    console.log(req.url);
    res.end();
})
server.listen(8080);

打开终端,输入:node server.js
点击html网页上的超链接,发现终端拿到了/content.html?id=2&title=这是文章标题
我们发现格式并不是我们想要的,那我们如何拿到正确的内容呢?

//server.js
const http = require("http");
const url = require("url");

const server = http.createServer((req,res)=>{
    console.log(url.parce(req.url));
    res.end();
})
server.listen(8080);

打开终端,输入:node server.js
点击html网页上的超链接,发现终端拿到了query: id=2&title=这是文章标题
我们发现格式还不是我们想要的。

//server.js
const http = require("http");
const url = require("url");

const server = http.createServer((req,res)=>{
    console.log(url.parce(req.url,true).query);
    res.end();
})
server.listen(8080);

打开终端,输入:node server.js
点击html网页上的超链接,发现终端拿到了 {id: '2', title: '这是文章标题' }

//server.js
const http = require("http");
const url = require("url");

const server = http.createServer((req,res)=>{
    console.log(url.parce(req.url,true).query.title);
    res.end();
})
server.listen(8080);

打开终端,输入:node server.js
点击html网页上的超链接,发现终端拿到了 这是文章标题,后面的undefined是有关于图标的,这里我们不用管。

 2.url模块

方式一:
const url = require("url");
url.parce(req.url,true).query

方式二:
const url = require("url");
const querystring = require('querystring');
const queryUrl = url.parce(req.url).query;
querystring.parse(queryUrl)

2.get请求表单数据操作

//index.html
<form method = "get" action = 'http://localhost:8080'>
    <input type = "text" name = "userName">
    <input type = "password" name = "userPwd">
    <input type = "submit" value = "登录">
</form>

打开浏览器,userName中输入aaa,userPwd输入bbb,点击登录。
在浏览器的url上会显示localhost:8080/?userName=aaa&userPwd=bbb

如果把html文件中input标签的name删掉,再进行相同的操作,会发现
在浏览器的url上会显示localhost:8080/?
说明name属性是尤为重要的。

//server.js
const http = require("http");
const url = require("url");

const server = http.createServer((req,res)=>{
    console.log(url.parce(req.url,true).query);
    res.end();
})
server.listen(8080);

打开终端,输入:node server.js
打开浏览器,userName中输入aaa,userPwd输入bbb,点击登录。
发现终端拿到了{ userName: 'aaa', userPwd: 'bbb' }

//server.js
const http = require("http");
const url = require("url");

const server = http.createServer((req,res)=>{
    res.writeHead(200,{"Content-Type":"text/html;charset=utf8"})//解决汉字乱码问题
    const formVal = url.parce(req.url,true).query;
    console.log(formVal.userName, formVal.userPwd);//终端上会显示
    res.end("用户名:"+formVal.userName+"---->"+"密码:"+formVal.userPwd);//跳转的网页上会显示
})
server.listen(8080);

八、post请求

1.post请求表单数据操作

//index.html
<form method = "post" action = "http://localhost:8080">
    <input type = "text" name = "userName">
    <input type = "password" name = "userPwd">
    <input type = "submit" value = "登录">
</form>

 post是事件接收:
req.on('data'):每次发送的数据
req.on('end'):数据发送完成

//server.js
const http = require("http");//引入http模块

const server = http.createServer((req,res)=>{
    let postVal = "";
    req.on("data",(chunk)=>{
        postVal += chunk;//postVal为全部内容,chunk为单次内容
    })
    req.on("end",()=>{
        console.log(postVal);
        res.end();
    })
})
server.listen(8080);

打开终端,输入:node server.js
打开浏览器,userName中输入aaa,userPwd输入bbb,点击登录。
发现终端拿到了userName=aaa&userPwd=bbb

//server.js
const http = require("http");//引入http模块
const querystring = require('querystring');

const server = http.createServer((req,res)=>{
    let postVal = "";
    req.on("data",(chunk)=>{//过程
        postVal += chunk;//postVal为全部内容,chunk为单次内容
    })
    req.on("end",()=>{//结果
        console.log(querystring.parse(postVal));
        res.end();
    })
})
server.listen(8080);

打开终端,输入:node server.js
打开浏览器,userName中输入aaa,userPwd输入bbb,点击登录。
发现终端拿到了{ userName: 'aaa', userPwd: 'bbb' }

九、Node连接MySQL

1.在当前文件夹下下载mysql包:npm install mysql,执行完后会在当前文件夹下生成node_modules文件夹

2.引入mysql

//server.js
const mysql = require("mysql");

3.配置mysql信息

//server.js
const mysql = require("mysql");

const connection = mysql.createConnection({
    host:"localhost",//主机名
    user:"root",//用户名
    password:"123456",//密码
    database:"xxx",//库名称
    port:"3306"//端口号,可以不配置,默认为3306
});

connection.connect();

connection.query("select * from user",(err,results,fields){//数据库里有一张user表
    if(err) throw err;
    console.log(results);
})

connection.end();

打开终端,输入node server.js,查询出结果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
这个系统其实是出于学习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进行登录,并使用这个系统了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值