最近在读<Node入门经典>, 之前没有做笔记, 今天开始把看过自己又写了的代码放这里以免忘记.

express

var express = require('express')
var app = express() app.get('/', function (req, res) {
res.send('Hello World')
})
app.listen(3000)

route

var http = require('http');
var url = require('url'); http.createServer(function(req,res){ var name = url.parse(req.url).pathname;
if (name === '/'){
res.writeHead(200,{
'Content-Type':'text/plain'
});
res.end('home page');
}
else if (name === '/about'){
res.writeHead(200,{
'Content-Type':'text/plain'
});
res.end('about me');
}
else if (name === '/redirect')
{
res.writeHead(301,{
'location': 'http://www.baidu.com'
});
res.end();
}
else{
res.writeHead(404,{
'Content-Type':'text/plain'
});
res.end('page not find');
} }).listen(3000, "127.0.0.1"); console.log('server start');

socket.io

var app = require('express')();
var http = require('http').Server(app);
var io = require('socket.io')(http); app.get('/', function(req, res){
res.sendfile('index2.html');
}); io.on('connection', function(socket){
console.log('a user connected');
socket.emit('chat message', {text:'hi'}); socket.on('disconnect', function(){
console.log('user disconnected');
}); socket.on('chat message', function(msg){
console.log('message: ' + msg);
});
}); http.listen(3000, function(){
console.log('listening on *:3000');
});
<!doctype html>
<html>
<head>
<title>Socket.IO chat</title>
</head>
<body>
<p id='count'></p>
<script src="/socket.io/socket.io.js"></script> <script>
var socket = io();
var count = document.getElementById('count');
socket.on('chat message', function(data){
count.innerHTML = data.text;
}); </script>
</body>
</html>

json

var http = require('http');

var obj = {
name:'green',
sur:'abcd'
};
console.log(obj); var json = JSON.stringify(obj);
console.log(json); var ori = JSON.parse(json);
console.log(ori);

spawn

var spawn = require('child_process').spawn;
var ping = spawn('ping', ['www.baidu.com']);
ping.stdout.setEncoding('utf8');
ping.stdout.on('data', function(data){
console.log(data);
});
ping.on('exit', function(code, signal){
console.log(code, ' ', signal);
process.exit(0);
});
setInterval(function(){
ping.kill('SIGINT');
}, 2000);

cluster

var cluster = require('cluster');
var http = require('http');
var cpus = 4;
if (cluster.isMaster){
console.log('master start at ' + process.pid); for (var i = 0; i < cpus; ++i ){
cluster.fork();
}
cluster.on('death', function(worker){
console.log('die: ' + woker.pid);
cluster.fork();
});
}
else{
console.log('worker start ' + process.pid);

events

var eventEm = require('events').EventEmitter;
var myEvent = new eventEm(); myEvent.on('message', function(data){
console.log(data);
}); myEvent.on('destroy', function(){
console.log('destroyed');
}); myEvent.emit('message','show message');
setTimeout(function(){
myEvent.emit('destroy');
}, 1000);

stream

var http = require('http');
var fs = require('fs'); http.createServer(function(req,res){
var mp3 = 'abc.mp3';
var stat = fs.statSync(mp3); res.writeHead(200,
{
'Content-Type':'audio/mpeg',
'Content-Length': stat.size
});
var readSteam = fs.createReadStream(mp3);
readSteam.pipe(res); }).listen(3000, "127.0.0.1"); console.log('server start');

<Node入门经典>读书笔记的更多相关文章

  1. csapp读书笔记-并发编程

    这是基础,理解不能有偏差 如果线程/进程的逻辑控制流在时间上重叠,那么就是并发的.我们可以将并发看成是一种os内核用来运行多个应用程序的实例,但是并发不仅在内核,在应用程序中的角色也很重要. 在应用级 ...

  2. CSAPP 读书笔记 - 2.31练习题

    根据等式(2-14) 假如w = 4 数值范围在-8 ~ 7之间 2^w = 16 x = 5, y = 4的情况下面 x + y = 9 >=2 ^(w-1)  属于第一种情况 sum = x ...

  3. CSAPP读书笔记--第八章 异常控制流

    第八章 异常控制流 2017-11-14 概述 控制转移序列叫做控制流.目前为止,我们学过两种改变控制流的方式: 1)跳转和分支: 2)调用和返回. 但是上面的方法只能控制程序本身,发生以下系统状态的 ...

  4. CSAPP 并发编程读书笔记

    CSAPP 并发编程笔记 并发和并行 并发:Concurrency,只要时间上重叠就算并发,可以是单处理器交替处理 并行:Parallel,属于并发的一种特殊情况(真子集),多核/多 CPU 同时处理 ...

  5. 读书笔记汇总 - SQL必知必会(第4版)

    本系列记录并分享学习SQL的过程,主要内容为SQL的基础概念及练习过程. 书目信息 中文名:<SQL必知必会(第4版)> 英文名:<Sams Teach Yourself SQL i ...

  6. 读书笔记--SQL必知必会18--视图

    读书笔记--SQL必知必会18--视图 18.1 视图 视图是虚拟的表,只包含使用时动态检索数据的查询. 也就是说作为视图,它不包含任何列和数据,包含的是一个查询. 18.1.1 为什么使用视图 重用 ...

  7. 《C#本质论》读书笔记(18)多线程处理

    .NET Framework 4.0 看(本质论第3版) .NET Framework 4.5 看(本质论第4版) .NET 4.0为多线程引入了两组新API:TPL(Task Parallel Li ...

  8. C#温故知新:《C#图解教程》读书笔记系列

    一.此书到底何方神圣? 本书是广受赞誉C#图解教程的最新版本.作者在本书中创造了一种全新的可视化叙述方式,以图文并茂的形式.朴实简洁的文字,并辅之以大量表格和代码示例,全面.直观地阐述了C#语言的各种 ...

  9. C#刨根究底:《你必须知道的.NET》读书笔记系列

    一.此书到底何方神圣? <你必须知道的.NET>来自于微软MVP—王涛(网名:AnyTao,博客园大牛之一,其博客地址为:http://anytao.cnblogs.com/)的最新技术心 ...

  10. Web高级征程:《大型网站技术架构》读书笔记系列

    一.此书到底何方神圣? <大型网站技术架构:核心原理与案例分析>通过梳理大型网站技术发展历程,剖析大型网站技术架构模式,深入讲述大型互联网架构设计的核心原理,并通过一组典型网站技术架构设计 ...

随机推荐

  1. Spring cache简单使用guava cache

    Spring cache简单使用 前言 spring有一套和各种缓存的集成方式.类似于sl4j,你可以选择log框架实现,也一样可以实现缓存实现,比如ehcache,guava cache. [TOC ...

  2. Kotlin与Android SDK 集成(KAD 05)

    作者:Antonio Leiva 时间:Dec 19, 2016 原文链接:https://antonioleiva.com/kotlin-integrations-android-sdk/ 使用Ko ...

  3. 编译器开发系列--Ocelot语言7.中间代码

    Ocelot的中间代码是仿照国外编译器相关图书Modern Compiler Implementation 中所使用的名为Tree 的中间代码设计的.顾名思义,Tree 是一种树形结构,其特征是简单, ...

  4. [转]ThinkPHP中实例化对象M()和D()的区别,select和find的区别

    1.ThinkPHP中实例化对象M()和D()的区别 在实例化的过程中,经常使用D方法和M方法,这两个方法的区别在于M方法实例化模型无需用户为每个数据表定义模型类,如果D方法没有找到定义的模型类,则会 ...

  5. 我的MYSQL学习心得(十一) 视图

    我的MYSQL学习心得(十一) 视图 我的MYSQL学习心得(一) 简单语法 我的MYSQL学习心得(二) 数据类型宽度 我的MYSQL学习心得(三) 查看字段长度 我的MYSQL学习心得(四) 数据 ...

  6. 【深入浅出jQuery】源码浅析2--奇技淫巧

    最近一直在研读 jQuery 源码,初看源码一头雾水毫无头绪,真正静下心来细看写的真是精妙,让你感叹代码之美. 其结构明晰,高内聚.低耦合,兼具优秀的性能与便利的扩展性,在浏览器的兼容性(功能缺陷.渐 ...

  7. 【初探Spring】------Spring IOC(三):初始化过程---Resource定位

    我们知道Spring的IoC起到了一个容器的作用,其中装得都是各种各样的Bean.同时在我们刚刚开始学习Spring的时候都是通过xml文件来定义Bean,Spring会某种方式加载这些xml文件,然 ...

  8. .NET程序的性能要领和优化建议

    前几天在老赵的博客上看到,Bill Chiles (Roslyn 编译器的Program Manager)写了一篇文章叫做<Essential Performance Facts and .NE ...

  9. ABP源码分析四十一:ZERO的Audit,Setting,Background Job

    AuditLog: 继承自Entity<long>的实体类.封装AuditLog的信息. AuditingStore: 实现了IAuditingStore接口,实现了将AuditLog的信 ...

  10. Entity Framework 6 Recipes 2nd Edition(11-2)译 -> 为一个”模型定义”函数返回一个计算列

    11-3. 为一个”模型定义”函数返回一个计算列 问题 想从”模型定义”函数里返回一个计算列 解决方案 假设我们有一个员工(Employee)实体,属性有: FirstName, LastName,和 ...