本篇介绍Node.js访问数据库并返回数据给客户端

需求基于Node.js学习(二)

数据库请下载:user.sql

1、创建user 实体类(model-user.js)

function User(id,userName,userPsw){
this.id = id;
this.userName = userName;
this.userPsw = userPsw;
}
// getter
User.prototype.getUserName = function () {
return this.userName;
};
User.prototype.getUserPsw = function () {
return this.userPsw;
}; module.exports = User; // 模块化

2、创建node-sql.js,对user表进行CURD

var mySql = require('mysql');
// 数据库属性
var connection = mySql.createConnection({
host:"localhost", //主机
user:"",// 字符串内写数据库用户名
password:"", //数据库连接密码
database:"", // 数据库名
port:3306 // 端口
});
// 连接
connection.connect();
// 数据库执行语句
var sql;
//
function CURD(){}
//增
CURD.prototype.add = function(obj){ };
// 删
CURD.prototype.del = function(id){ };
// 改
CURD.prototype.update = function(obj){ };
// 查
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");
callback(result[0]["COUNT(*)"]);
}); }else{
// 返回所有对象
}
};
module.exports = CURD;

这里提下var mySql = require('mysql'); 加载mysql 模块,安装的node.js 中没有这个模块,需要手动下载,推荐一篇不错的文章,不过请看完再装

3、node-post.js 监听端口

var http = require('http');
var qs = require('querystring');
var url = require('url');
// 获取user模块
var User = require('./model-user');
// 获取CURD模块
var CURD = require('./node-sql');
// 构造
var curd = new CURD(); http.createServer(function (req, res) {
var parms = url.parse(req.url,true);
var userName = parms.query.userName;
var userPsw = parms.query.userPsw;
console.log(userName + "<---||--->" + userPsw);
//构造
var user = new User(null,userName,userPsw);
curd.check(user, function (result) {
console.log("回调数据是:" + result);
var resData = {
msg:result
};
res.writeHead(200,{'Content-type':'text/plain;charset=utf-8'});
res.end('callback('+JSON.stringify(resData)+')');
});
}).listen(8082);

这里注意check()使用了回调 callback,在connection.query()中发起回调,Node.js 大部分方法都是异步回调处理.

前端界面和之前的一样,这里就截图看看吧

如有不足之处请指出,谢谢

Node.js基础学习三之登录功能的更多相关文章

  1. Node.js基础学习四之注册功能

    前言:在Node.js学习(二)和(三)中介绍了如何在Node.js 中获取登录的用户名和密码与数据库进行验证并返回数据给客户端 需求:实现注册功能 为了区分登录和注册是两个不同的请求,在端口后面加上 ...

  2. Node.js基础学习二之POST请求

    本篇介绍下 Node.js post 请求 需求: 用户登录,前端界面输入用户名和密码,点击登录请求后台验证,根据后台反馈的信息做出响应 前端: (1)使用form表单 (2)使用ajax异步请求 服 ...

  3. Node.js基础学习一之Get请求

    本人从事的是前端开发,这段时间公司开发项目比较少所以就想着学点东西,然后就想到了Node.js ,跟着菜鸟教程学了点,不过我觉得最好的学习方法是带着需求来学习. 其实和服务端打交道无非就是能有一个可以 ...

  4. node.js 基础学习笔记3 -http

    http模块,其中封装了一个高效的HTTP服务器和一个建议的HTTP客户端 http.server是一个基于事件的HTTP服务器 http.request则是一个HTTP客户端工具,用户向服务器发送请 ...

  5. node.js 基础学习笔记2

    Module和Package是Node.js最重要的支柱. Node.j 提供require函数来调用其他模块,而且模块都是基于文件.模块和包区别是透明的,因此常常不作区分. 1.模块和文件一一对应. ...

  6. node.js 基础学习笔记1

    1. node -v 查看版本 node -e --js代码 node --进入编辑模式 Ctrl+C 退出编译模式 var http=require('http') http.createServe ...

  7. node.js 基础学习 express安装使用

    安装好nodeJs,我们需要使用命令行中安装express. 我这里默认将Node.js安装在C:\Program Files\nodCejs\盘中. 在保持联网的状态下,依次输入如下命令. npm ...

  8. node.js 基础学习

    node.js 是一个 javaScript 运行环境,可以让 js 运行在服务端. 在 nodejs 环境下,可以运行 javascript 基本语法,可以在nodejs 中执行一些无法在浏览器端执 ...

  9. node.js 基础学习笔记3 -express

    1.工作原理 当通过app.js建立的服务器时,会看到一个简单的页面.返回页面时,浏览器会向服务器发送请求.app会解析请求的路径,调用相应的逻辑,调用对应的视图模板,传递对象数值,最终生成HTML页 ...

随机推荐

  1. Java演算法-「馬踏棋盤問題」

    /* * 馬踏棋盤問題:(貪婪法求解) * 棋盤有64個位置,“日”字走法,剛好走滿整個棋盤 */ //下一個走法的方向類 class Direction{ int x; int y; int way ...

  2. JavaScript中innerHTML与innerText,createTextNode的区别

    innerHTML和innerText 它们都会把元素内内容替换掉,区别在于: innerHTML 会把替换内容里的 HTML 标记解释执行. innerText 会把替换内容里的 HTML 标记原样 ...

  3. 核心思想:决定你是富人还是穷人的11条标准(有强烈的赚钱意识,这也是他血液里的东西,太精彩了)good

    原文地址:决定你是富人还是穷人的11条标准作者:谢仲华 1.自我认知 穷人:很少想到如何去赚钱和如何才能赚到钱,认为自己一辈子就该这样,不相信会有什么改变. 富人:骨子里就深信自己生下来不是要做穷人, ...

  4. Windows10 磁盘100%解决办法

    此电脑->管理->任务计划程序->\Microsoft\Windows 一.\MemoryDiagnostic 禁用:ProcessMemoryDiagnosticEvents和Ru ...

  5. flask微服务框架的初步接触

    测试2个关联的系统接口时,经常会遇到被测试系统或被测app的处理内部处理流程会依赖另一个系统的接口返回结果,这时,常用的做法就是写一个模拟测试桩,用作返回请求时的结果.java可以用servicele ...

  6. RN如何基于js代码手动打一个main.jsbundle

    react-native bundle --entry-file index.js --bundle-output ./ios/bundle/main.jsbundle --platform ios ...

  7. sql相同表不同查询条件合并显示

    关键字:FULL JOIN 只要其中某个表存在匹配,FULL JOIN 关键字就会返回行. select a.createtime, ISNULL(lp, 0) lp , ISNULL(hp, 0) ...

  8. nginx隐藏tp路由index.php

    ---------------------------------------------- 也可以找到vhosts.conf文件修改, 重启nginx,service nginx restart

  9. Request的方法和数组

    req.getHeader("referer") [取得发送请求页面对应的浏览器地址栏信息,可以使用这种方法实现防盗链等操作] String name=new String(req ...

  10. AMBER: CPPTRAJ Tutorial C0

    CPPTRAJ作为PTRAJ的继任者,拥有比PTRAJ更强大的功能,本教程会简要的介绍CPPTRAJ的用法及注意事项. 需要的文件: trpzip2.gb.nc trpzip2.ff10.mbondi ...