Node.js

Node.js

Node.js 简介

Node.js 示例

本文测试代码来自how2java

第一个服务器程序

首先,引入http模块。
然后写一个Service()函数,类似于servlet中的doget()或者dopost()。
在函数中:设置返回状态为200,返回内容为Hello Node.js。
然后创建服务器,监听端口8088。

var http = require('http');
function service(request, response) {
    response.writeHead(200, {'Content-Type': 'text/plain'});
    response.end('Hello Node.js');
}
var server = http.createServer(service);
server.listen(8088);

运行结果:
在这里插入图片描述

通过Node.js 传入参数

var http = require('http');
var url=require('url'); //引入url 模块,帮助解析
var querystring=require('querystring');// 引入 querystring 库,也是帮助解析用的
function service(req,response){
    //获取返回的url对象的query属性值
    var arg = url.parse(req.url).query;
     
    //将arg参数字符串反序列化为一个对象
    var params = querystring.parse(arg);
     
    //请求的方式
    console.log("method - " + req.method);
     
    //请求的url
    console.log("url - " + req.url);
 
    //获取参数id
    console.log("id- " + params.id);
 
    response.writeHead(200, {'Content-Type': 'text/plain'});
    response.end('Hello Node.js');
}
var server = http.createServer(service);
server.listen(8088);

运行结果:
在这里插入图片描述
奇怪的是在日志里,会出现 /favicon.ico 信息,这个 favion 是 favorite icon 的缩写,即网站图标。跟我们的程序没有关系。

模块系统

首先编写一个模块代码:
它包含了一个服务器service函数,和一个普通的sayHello函数。
通过exports导出为外部接口使用。

function service(request, response) {
    response.writeHead(200, {'Content-Type': 'text/plain'});
    response.end('Hello Node.js');
}
function sayHello(){
    console.log('hello from how2j.js');
}
exports.hi = sayHello;
exports.service = service;

然后使用下面的代码,引入模块并调用函数测试:

var http = require('http');
var how2j = require('./how2j');
how2j.hi();
var server = http.createServer(how2j.service);
server.listen(8088);

路由系统

当我们的业务逻辑稍微复杂一点,就应该使用路由系统来管理了。

requestHandler.js模块: 编写了相关业务逻辑的函数。

function listCategory() { 
    return "a lot of categorys";
} 
   
function listProduct() { 
    return "a lot of products";
} 
 
exports.listCategory = listCategory; 
exports.listProduct = listProduct; 

router.js模块: 编写了相关路由的函数。
判断了路径对应的业务逻辑函数是否存在。

function route(handle, pathname) { 
  if (typeof handle[pathname] === 'function') { 
    return handle[pathname](); 
  } else {
    return pathname + ' is not defined';
  } 
} 
exports.route = route; 

server.js模块: 服务器启动模块。
传入路由判断函数、和路由映射关系,给服务器启动。

var http = require("http"); 
var url = require("url"); 
   
function start(route, handle) { 
  function onRequest(request, response) { 
    var pathname = url.parse(request.url).pathname; 
    var html = route(handle, pathname); 
    response.writeHead(200, {"Content-Type": "text/plain"}); 
    response.write(html); 
    response.end(); 
  } 
   
  http.createServer(onRequest).listen(8088); 
} 
   
exports.start = start; 

index.js 入口模块
引入了三个模块,配置了路由对应的业务逻辑的映射关系字典,然后传给服务器启动。

var server = require("./server"); 
var router = require("./router"); 
var requestHandlers = require("./requestHandlers"); 
 
var handle = {} 
handle["/listCategory"] = requestHandlers.listCategory; 
handle["/listProduct"] = requestHandlers.listProduct; 
   
server.start(router.route, handle); 

文件读写

requestHandlers.js :
主要是修改业务逻辑,修改的业务逻辑如下:

var fs = require("fs");
 
function listCategory() { 
    return "a lot of categorys";
} 
   
function listProduct() { 
    return "a lot of products";
} 
 
function readFile(){
    var html = fs.readFileSync('how2j.html');
    return html;
}
 
function writeFile(){
    fs.writeFile('how2java.html', 'hello from how2java');
    return "write successful";
}
 
exports.listCategory = listCategory; 
exports.listProduct = listProduct; 
exports.readFile = readFile; 
exports.writeFile = writeFile; 

index.js

var server = require("./server"); 
var router = require("./router"); 
var requestHandlers = require("./requestHandlers"); 
 
var handle = {} 
handle["/listCategory"] = requestHandlers.listCategory; 
handle["/listProduct"] = requestHandlers.listProduct; 
handle["/readFile"] = requestHandlers.readFile; 
handle["/writeFile"] = requestHandlers.writeFile; 
   
server.start(router.route, handle); 

npm

npm是一个node.js 自动安装的一个下载工具。

下载

如下面的语句可以下载how2java模块。

npm install how2java

发布

所有npm都是发布在 https://www.npmjs.com/ 上面的,所以在发布之前,需要到 npmjs 上去注册一个账号,才有权限发布自己定义模块。

发布的js文件:
a.js

function hello(){
  console.log("hello from how2java");
}
exports.hello=hello;
 步骤 6 : 新建 package.json

下面是一个package.json指出模块的相关信息:

{
  "name": "how2java",
  "version": "1.0.3",
  "description": "npm of how2java",
  "main": "a.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "keywords": [
    "how2java"
  ],
  "author": "how2j",
  "license": "ISC"
}

登录:npm adduser
发布:npm publish

cnpm

这就是cnpm在中国的npm。
安装:npm install -g cnpm --registry=https://registry.npm.taobao.org
检查版本:cnpm -v
下载:cnpm install how2java
不支持直接发布。

mysql

Node.js : mysql 增删查改。

var mysql      = require("mysql");
var connection;
 
function openConnection(){
    connection = mysql.createConnection({
          host     : "127.0.0.1",
          user     : "root",
          password : "admin",
          database : "nodejs"
        });
    connection.connect();
}
function closeConnection(){
    connection.end();  
}
 
function showAll(){
    openConnection();
    var  sql = "SELECT * FROM category_ order by id asc";
    connection.query(sql,function (err, results) {
        if(err){
            console.log("[SELECT ERROR] - ",err.message);
            return;
        }
        if(results)
        {
            for(var i = 0; i < results.length; i++)
            {
                console.log("%d\t%s", results[i].id, results[i].name);
            }
        }  
    });
    closeConnection();     
}
 
function add(name){
    openConnection();
    var params = [null,name];  
    var  sql = "insert into category_ values (?,?)";
    connection.query(sql,params,function (err, result) {
        if(err){
         console.log("[INSERT ERROR] - ",err.message);
         return;
        }       
       console.log("insert success, the generated id is:",result.insertId);       
    });
    closeConnection(); 
}
 
function remove(id){
    openConnection();
    var params = [id]; 
    var  sql = "delete from category_ where id = ?";
    connection.query(sql,params,function (err, result) {
        if(err){
         console.log("[REMOVE ERROR] - ",err.message);
         return;
        }       
       console.log("remove id=%d success ",id);       
    });
    closeConnection(); 
}
 
function get(id){
    openConnection();
    var params = [id]; 
    var  sql = "select * from category_ where id = ?";
    connection.query(sql,params,function (err, result) {
        if(err){
         console.log("[GET ERROR] - ",err.message);
         return;
        }       
        if(result.length !=0){
            var category = {id:result[0].id,name:result[0].name};
            console.log("get category:"+ JSON.stringify(result))
        }
        else{
            console.log("not found with id :" + id)
        }
         
    });
    closeConnection(); 
}
 
function update(id,name){
    openConnection();
    var params = [name,id];
    var sql = "update category_ set name = ? where id = ?";
    connection.query(sql,params,function (err, result) {
        if(err){
         console.log("[UPDATE ERROR] - ",err.message);
         return;
        }       
         
        console.log("update success"+result.affectedRows);
 
    });
    closeConnection(); 
}

Express 框架

Express 框架是一个方便开发者的 web 框架,可以让开发者方便地处理路由,Cookie,静态文件,上传文件, RESTFULL风格等等常见操作。

创建 package.json 文件

一个json文件指明了用到什么第三方包。
创建的 package.json 如下:

{
  "name": "test",
  "version": "1.0.0",
  "description": "",
  "main": "index.js",
  "scripts": {
    "test": "echo \"Error: no test specified\" && exit 1"
  },
  "author": "",
  "license": "ISC"
}

安装 Express 框架

使用如下指令安装npm install express --saveExpress 框架。

实现简单的路由功能

app.js 演示了 express的简单路由功能。
分别创建了//abc功能。

var express = require('express');
var app = express();
  
app.get('/', function (req, res) {
   res.send('Hello from express');
});
 
app.get('/abc', function (req, res) {
       res.send('abc page from express');
});
  
var server = app.listen(8088);

访问测试地址

分别访问 http://127.0.0.1:8088http://127.0.0.1:8088/abc

静态文件访问

html静态文件:

<html>
    <head>
        <link rel="stylesheet" type="text/css" href="static/css/style.css" />
    </head>
    <body>
        <div class="content">
            Hello Express      
        </div>
    </body>
    <script src="static/js/how2j.js"></script> 
</html>

css文件:

div.content{
    border:1px solid gray;
    width:500px;
    margin:50px auto;
    color:skyblue;
    padding:20px;
}

js文件:

alert("hello from static/js/how2j.js");

static 文件从 当前工作目录下的/public 下获取。
app.js 启动服务器

var express = require('express')
var path = require('path')
var app = express()
 
app.use(express.static(path.join(__dirname, 'public')))
app.listen(8088);

添写相应的地址测试
分别是http://127.0.0.1:8088/abchttp://127.0.0.1:8088

文件上传

upload.html:文件上传的前端

<!DOCTYPE html>
 
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<form action="uploadPhoto" method="post" enctype="multipart/form-data">
  上传图片 : <input type="file" name="image" accept="image/*" /> <br>
  <input type="submit" value="上传">
</form>

上传文件处理的文件:

var express = require('express');
var path = require('path')
var fs = require("fs");
var multer  = require('multer');
  
var app = express();
//指定静态文件位置
app.use(express.static(path.join(__dirname, 'public')))
//上传之后放在工作目录下的 tmp 目录下。 上传的时候上传控件的name 必须是  image
app.use(multer({ dest: path.join(__dirname, 'tmp') }).array('image'));
  
//获取后缀名
function getExtName(fileName){
    var index1=fileName.lastIndexOf(".");
    var index2=fileName.length;
    var extName=fileName.substring(index1+1,index2);
    return extName;
}
  
app.post('/uploadPhoto', function (req, res) {
   //获取上传图片的后缀名
   var extName = getExtName(req.files[0].originalname);
     
   //随机数
   var rundomNumber = Math.ceil(Math.random()*10000000);
   //以随机数作为文件名
   var randomFileName =  rundomNumber + "."+extName;
     
   //创建图片目录
   var imgFolder = __dirname + "/public/img/";
   if(!fs.exists(imgFolder))
       fs.mkdir(imgFolder);
     
   //图片路径
   var imgFile = __dirname + "/public/img/" + randomFileName;
     
   //上传临时文件的路径
   var uploadedTempFilePath = req.files[0].path;
     
   //读取临时文件
   fs.readFile( uploadedTempFilePath, function (err, data) {
       //读取成功之后,复制到图片路径
        fs.writeFile(imgFile, data, function (err) {
            //写成功之后,返回 img元素显示上传之后的图片
              res.writeHead(200, {'Content-Type': 'text/html'});
              res.end("<img src='img/"+randomFileName+"'/>");
       });
   });
})
   
var server = app.listen(8088);

参考

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值