完整實例(根據(jù)不同的url地址請求不同的文件【模板】)
const ip = '192.168.1.12';//主機IP
const port = 2001;//端口號
//引入的組建模塊 http、url、fs
const http = require('http');
const urls = require('url');
const fs = require('fs');
//實例化一個服務容器
var server = new http.Server();
//監(jiān)聽一個端口
server.listen(port , ip);
//注冊一個事件處理的on方法
server.on('request' , function(req , res){
//獲取請求的url地址
var url = urls.parse(req.url);
//console.log(url.pathname);
//根據(jù)path路徑來讀取不同的模板文件
switch( url.pathname ){
//顯示首頁
case '' || '/':
//讀取文件內(nèi)容
fs.readFile('./index.html',function( error, content){
if(error){
//如果有錯誤時,顯示錯誤信息
funError();
}else{
//正確時瀏覽器輸出模板文件的內(nèi)容
funAuccess(res,content);
}
});
break;
//顯示列表頁面
case '/list':
fs.readFile('./list.html',function( error, content){
if(error){
funError(res , error);
}else{
funAuccess(res,content);
}
});
break;
//顯示詳情頁
case '/show':
fs.readFile('./show.html',function( error, content){
if(error){
funError(res , error);
}else{
funAuccess(res,content);
}
});
break;
//獲取靜態(tài)資源的頁面 如:css\js
default:
//獲取文件名
var filename = url.pathname.substring(1);
//獲取文件名對應的類型值
var type = getAllType( filename.substring(filename.lastIndexOf('.')+1));
//測試所用
//console.log(type);
//讀取靜態(tài)資源的頁面
fs.readFile(filename , function( error, content){
if(error){
funError(res , error);
}else{
res.writeHead(200,{'Content-Type' : type});
res.write(content);
res.end();
}
});
break;
}
});
//錯誤提示的函數(shù)
function funError(response , error){
response.writeHead(400,{'Content-Type':'text/plain;charset="utf-8"'});
response.write(error.message);
response.end();
}
//正確時輸出文件內(nèi)容的函數(shù)
function funAuccess(response,cont){
response.writeHead(200,{'Content-Type':'text/html;charset="utf-8"'});//頭信息
response.write(cont);//模板文件內(nèi)容
response.end();
}
//定義文件類型的函數(shù)
function getAllType(code){
var type = '';
switch(code){
case 'html':
type = 'text/html;charset=utf-8';
break;
case 'js':
type = 'application/javascript/html;charset=utf-8';
break;
case 'css':
type = 'text/css;charset=utf-8';
break;
case 'text':
type = 'text/plain;charset=utf-8';
break;
case 'manifest':
type = 'text/cache-manifest;charset=utf-8';
break;
default:
type = 'application/octet-stream';
break;
}
return type;
}
復習
//主機IP
const ip = '192.168.1.118';
//端口號
const port = 2000;
//引入的組建模塊 http、url、fs
const http = require('http');
const url = require('url');
const fs = require('fs');
//創(chuàng)建一個服務
var server = http.createServer(function(req,res){
res.writeHead(200,{'Content-Type':'text/plain'});
res.write('my nodejs');
res.end();
});
//監(jiān)聽一個端口
server.listen(port,ip,function(){
console.log('server start');
});
抽象方法及獲取URL部分塊的內(nèi)容 url
const ip = '192.168.1.118';//主機IP
const port = 2001;//端口號
//引入的組建模塊 http、url、fs
const http = require('http');
const url = require('url');
const fs = require('fs');
//創(chuàng)建服務的回調(diào)函數(shù)
var funSer = function(req,res){
//獲取url地址塊的內(nèi)容 如:/path/show
var parth = url.parse(req.url).pathname;
res.write(parth);
res.end();
}
//監(jiān)聽端口的回調(diào)
var fun = function(){
console.log('server start');
}
var server = http.createServer(funSer).listen(port,ip,fun);
讀取文件的內(nèi)容 File System
const ip = '192.168.1.118';//主機IP
const port = 2001;//端口號
//引入的組建模塊 http、url、fs
const http = require('http');
const url = require('url');
const fs = require('fs');
//真正打印文件內(nèi)容
fs.readFile('./index.html', (err, data) => {
if (err) throw err;
//打印字符串內(nèi)容
console.log(data.toString());
});
//創(chuàng)建服務的回調(diào)函數(shù)
var funSer = function(req,res){
//獲取url地址塊的內(nèi)容 如:/path/show
var parth = url.parse(req.url).pathname;
res.write(parth);
res.end();
}
//監(jiān)聽端口的回調(diào)
var fun = function(){
console.log('server start');
}
var server = http.createServer(funSer).listen(port,ip,fun);
讀取文件的內(nèi)容并在瀏覽器中輸出 File System
const ip = '192.168.1.118';//主機IP
const port = 2001;//端口號
//引入的組建模塊 http、url、fs
const http = require('http');
const url = require('url');
const fs = require('fs');
//讀取文件內(nèi)容
var data = fs.readFileSync('./index.html');
//創(chuàng)建服務的回調(diào)函數(shù)
var funSer = function(req , res){
//獲取url地址塊的內(nèi)容 如:/path/show
var path = urls.parse( req.url ).pathname;
res.write( data.toString() );
res.write( path );
res.end();
}
//監(jiān)聽端口的回調(diào)
var fun = function(){
console.log('server start');
}
var server = http.createServer(funSer).listen(port,ip,fun);