Node.js基础学习四之注册功能
前言:在Node.js学习(二)和(三)中介绍了如何在Node.js 中获取登录的用户名和密码与数据库进行验证并返回数据给客户端
需求:实现注册功能
为了区分登录和注册是两个不同的请求,在端口后面加上/login表示登录,/register表示注册,交给后台处理
前端代码还是和之前的一样,控制好请求的URL即可
Node.js 服务端代码如下:
1、监听端口的node-post.js(Controller层)
/**
* Created by LB on 2017/10/27.
*/
var http = require('http');
var url = require('url');
// 路由
var Router = require('./node-router'); http.createServer(function (req, res) {
var parms = url.parse(req.url,true);
console.log(parms); var router = new Router(parms);
router.loginOrRegister(function (result) {
console.log("最终回调:" + result.msg);
res.writeHead(200,{'Content-type':'text/plain;charset=utf-8'});
res.end('callback('+JSON.stringify(result)+')');
}); }).listen(8082);
这里多了一个路由的概念,目前我的项目中并没有很好的运用它,请不要在意,这个js代码有点像Java服务端开发中的Control层,接收客户端请求并获取参数交给服务层处理,将服务层回调的数据传递给客户端
2、逻辑处理层 node-router.js(Server层)
// 获取user模块
var User = require('./model-user');
// 获取CURD模块
var CURD = require('./node-sql');
// 构造
var curd = new CURD(); var Router = function (parms) {
this.pathname = parms.pathname;
this.user = new User(null,parms.query.userName,parms.query.userPsw);
}; Router.prototype.loginOrRegister = function (callback) {
var user = this.user;
if(this.pathname == "/login"){
console.log("登录验证请求");
curd.check(user, function (result) {
callback(result);
});
}else if (this.pathname == "/register"){
console.log("注册请求");
curd.check(user, function (res1) {
if (res1.status != 200) {
curd.add(user,function (res2) { // 这里不能用 this.user,此时this并不指向 Router
callback(res2);
})
}else {
res1.msg = "该用户名已存在,请重新输入";
callback(res1);
}
});
}
}; module.exports = Router;
主要做的事有,构造User实例,判断URL如果是登录则调用check() ,如果是注册则先调用check() 判断能否注册,能注册在调用add()新增
3、数据node-sql.js(Dao层)
//增
CURD.prototype.add = function(obj,callback){
sql = " INSERT INTO user VALUES(?,?,?)";
console.log("---" +obj.getUserName()+ "---" +obj.getUserPsw());
var addParams = [obj.getId(),obj.getUserName(),obj.getUserPsw()];
connection.query(sql,addParams, function (error,result) {
if (error){
console.log("[INSERT ERROR] - ",error.message);
return;
}
console.log("----------------------------INSERT----------------------------");
console.log("INSERT ID:" + result.insertId);
console.log(JSON.stringify(result));
console.log("--------------------------------------------------------------\n\n"); if(result.insertId) {
resData.status = 200;
resData.msg = "注册成功!";
}else {
resData.status = 203;
resData.msg = "注册失败!"
}
callback(resData);
})
};
// 查
CURD.prototype.check = function(obj,callback){
sql = "SELECT COUNT(*) FROM `user` AS u where u.userName = ? AND u.userPsw = ?";
console.log(obj.getUserName() + "====" + obj.getUserPsw());
var addParams = [obj.getUserName(),obj.getUserPsw()];
if(obj){
connection.query(sql,addParams, function (error, result) {
if(error){
console.log("[SELECT ERROR] - ",error.message);
return;
}
console.log("----------------------------SELECT----------------------------");
console.log(result);
console.log(result[0]);
console.log(result[0]["COUNT(*)"]);
console.log("--------------------------------------------------------------\n\n");
if (result[0]["COUNT(*)"] == 0){
resData.status = 203;
resData.msg = "用户名或密码有误";
}else{
resData.status = 200;
resData.msg = "验证成功";
}
resData.data = {
count:result[0]["COUNT(*)"]
};
callback(resData);
}); }else{
// 返回所有对象
}
};
这里需要主要就给出新增和查询两个,以及回调的数据格式,我是按照我们公司的文档规定来写的.
目前为止基础篇就这么多了,→点击源码下载
所以从下一篇开始,我会按照以下路线来学习探索
1、Express 框架重写登录注册,(这里并不介绍Express框架,请参考其他文献)
2、表格数据、分页、带条件搜索
3、表格数据的导入导出
4、上传大头贴
5、webSocket推送
目前能想到的就这么多,其实我现在都不知道服务端这些东西该怎么写,毕竟我只是个前端小菜鸟而已
如有不足之处,请指教,谢谢!
Node.js基础学习四之注册功能的更多相关文章
- Node.js基础学习三之登录功能
本篇介绍Node.js访问数据库并返回数据给客户端 需求基于Node.js学习(二) 数据库请下载:user.sql 1.创建user 实体类(model-user.js) function User ...
- node.js 基础学习笔记2
Module和Package是Node.js最重要的支柱. Node.j 提供require函数来调用其他模块,而且模块都是基于文件.模块和包区别是透明的,因此常常不作区分. 1.模块和文件一一对应. ...
- node.js 基础学习笔记1
1. node -v 查看版本 node -e --js代码 node --进入编辑模式 Ctrl+C 退出编译模式 var http=require('http') http.createServe ...
- Node.js基础学习二之POST请求
本篇介绍下 Node.js post 请求 需求: 用户登录,前端界面输入用户名和密码,点击登录请求后台验证,根据后台反馈的信息做出响应 前端: (1)使用form表单 (2)使用ajax异步请求 服 ...
- Node.js基础学习一之Get请求
本人从事的是前端开发,这段时间公司开发项目比较少所以就想着学点东西,然后就想到了Node.js ,跟着菜鸟教程学了点,不过我觉得最好的学习方法是带着需求来学习. 其实和服务端打交道无非就是能有一个可以 ...
- node.js 基础学习笔记3 -http
http模块,其中封装了一个高效的HTTP服务器和一个建议的HTTP客户端 http.server是一个基于事件的HTTP服务器 http.request则是一个HTTP客户端工具,用户向服务器发送请 ...
- node.js 基础学习 express安装使用
安装好nodeJs,我们需要使用命令行中安装express. 我这里默认将Node.js安装在C:\Program Files\nodCejs\盘中. 在保持联网的状态下,依次输入如下命令. npm ...
- node.js 基础学习
node.js 是一个 javaScript 运行环境,可以让 js 运行在服务端. 在 nodejs 环境下,可以运行 javascript 基本语法,可以在nodejs 中执行一些无法在浏览器端执 ...
- node.js 基础学习笔记3 -express
1.工作原理 当通过app.js建立的服务器时,会看到一个简单的页面.返回页面时,浏览器会向服务器发送请求.app会解析请求的路径,调用相应的逻辑,调用对应的视图模板,传递对象数值,最终生成HTML页 ...
随机推荐
- Spring-day03
Spring集成JDBC:提供了一些方便我们使用JDBC的工具类; query(String,ResultSetHandler handler,Object..parm){ Connection co ...
- SQL - 2.基础语法
一.SQL分类: DDL—数据定义语言(CREATE,ALTER,DROP,DECLARE) DML—数据操纵语言(SELECT,DELETE,UPDATE,INSERT) DCL—数据控制语言(GR ...
- python3 Django集成Ueditor富文本编辑器
1.下载 python3: https://github.com/twz915/DjangoUeditor3/ (直接下载zip) 2.解压,解压打开后找到DjangoUeditor将DjangoUe ...
- python之str字符串
字符串是python非常重要的数据类型,它是一个序列(列表和元组也是序列),有下标,可以通过下标遍历字符串序列:同时字符串也是一个不可变数据类型,每次使用"+"拼接字符串时都会产生 ...
- mysql 字符集
mysql -u root -p 输入密码进入mysql show variables like 'character%'; --显示字符集,像这样 \q退出mysql, 更改mysql配置文件 vi ...
- VUE-007-通过路由 router.push 传递 query 参数(路由 name 识别,请求链接显示参数传递)
在前端页面表单列表修改时,经常需要在页面切换的时候,传递需要修改的表单内容,通常可通过路由进行表单参数的传递. 首先,配置页面跳转路由.在 router/index.js 中配置相应的页面跳转路由,如 ...
- 完美脱离Windows!! Linux发行版第一系统 Manjaro 开箱教程 :)
没兴趣? 来几张图敌敌畏(kai kai wei) !! 0x00 预览(zhuangbi) 0x01 引言(feihua) 当我们想用ssh工具时,不像telnet那样是系统自带的软件,需要额外安装 ...
- awk 实战
awk 一些好玩的用法.有什么不错的点子可以留言,发挥出awk牛逼功能 分离mac地址 ifconfig wlan0 | grep eth | awk '{n=split($2,arr,": ...
- JavaScript 里 var a =a ||{}
首先,搞明白||的意思. 1.在js里面,||运算符,比如(A||B)有个很有意思的用处: 2.系统先判断A表达式的布尔值,是真是假.如果为真,直接返回A.如果为假,直接返回B(不会判断B是什么类型) ...
- 爬取豆瓣电影排行top250
功能描述V1.0: 爬取豆瓣电影排行top250 功能分析: 使用的库 1.time 2.json 3.requests 4.BuautifulSoup 5.RequestException 上机实验 ...