nodejs 本地php服务器,nodejs搭建本地http服务器

初学NODEJS,从网站下载了一个单文件的node.exe,简单JS测试可以了,但是需要用到一些库就完全不行了

什么npm命令,输了都无效,想安装npm也不知咋弄

后面下载了最新版本,安装的msi版本,结果装了好几分钟自动回退,最后在虚拟机中先装好,再复制出来,整整弄了半天,不容易呀。

然后找了2个例子,都成功实现了,一个是自已写代码,要处理好多问题,比如我的网页是GB2312,NODE.js是UTF-8,

搞了半天装了3个库:安装编码转换--npm install iconv

npm install iconv-lite

npm install bufferhelper

结果可以运行了,中文路径的问题也搞定了,但是图片问题还没搞定,也变成了文字读取。

后面别人说可以下载其他库,然后又找了一个例子,这个没用什么库,但是代码比较全面,改动就可以用了。

不过改改也花了几小时,一切不会呀从头学的。

中文路径名,还有一些文件编码是ANSI的,结果htm中指定是'utf-8'这样也显示不出来

我改好的完美版,基本上大家粘上就直接能用了,还需要加一些目录默认文件,比如打开一个新目录

www.abc.com/aa/bbb/

一般应该显示index.htm,如果没有就显示一个错误页或文字,这功能还没加上,还有原作者他连“.htm”后缀的格式都没加上,直接显示成了文本htm代码。

【 "htm": "text/html",】这一行是我加的

var PORT = 3000;

var http = require('http');

var url=require('url');

var fs=require('fs');

var mine=require('./mine').types;

var path=require('path');

var RequestUrl='';

var RootPath='www';//网站根目录

var server = http.createServer(function (request, response) {

RequestUrl=request.url;

//默认页面

if (RequestUrl=='' || RequestUrl=='/'){

RequestUrl='/index.htm';

}

else

{

RequestUrl=decodeURIComponent(RequestUrl);

}

console.log('请求网址:' +RequestUrl);

var realfile=RootPath+RequestUrl;

console.log(realfile);

var ext = path.extname(realfile);

ext = ext ? ext.slice(1) : 'unknown';

console.log("请求类型:exr= " + ext);

fs.exists(realfile, function (exists) {

if (!exists) {

response.writeHead(404, {

'Content-Type': 'text/plain'

});

response.write("This request URL " + realfile + " was not found on this server.");

response.end();

} else {

fs.readFile(realfile, "binary", function (err, file) {

if (err) {

response.writeHead(500, {

'Content-Type': 'text/plain'

});

response.end(err);

} else {

var contentType = mine[ext] || "text/plain";

response.writeHead(200, {

'Content-Type': contentType

});

response.write(file, "binary");

response.end();

}

});

}

});

});

server.listen(PORT);

console.log("Server runing at port: " + PORT + ".");

代码比较长有1517个字左右,格式化了一下,还是觉的很精美的,还有SUBLIME这个编辑工具才20M,可以支持编辑几十种语言或格式,很强大呀。

bVPMgl?w=709&h=869

‘=======================

以下是原作者的文章:来源:http://www.cnblogs.com/shawn-...

nodejs搭建本地http服务器

由于不做php相关的东西,懒得装apache,干脆利用nodejs搭建一个本地的服务器用于测试。

nodejs这玩意儿吧,对做前端的介入后端简直就是一把利器。而且目前,nodejs也越来越有商用价值。

nodejs其实是非常底层的,从功能上说,它既是apache也是php。像搭建http服务器这种功能,本来是apache已经封装好的,但nodejs需要我们手动来搭建。其实在实际应用中,我们可以使用现成的框架。但这里,我想手动搭建,也加深一下对http服务器的理解。

我们node执行下面这个文件,我命名为http.js,它将创建一个httpServer并监听3000端口。

var PORT = 3000;

var http = require('http');

var url=require('url');

var fs=require('fs');

var mine=require('./mine').types;

var path=require('path');

var server = http.createServer(function (request, response) {

var pathname = url.parse(request.url).pathname;

var realPath = path.join("assets", pathname);

//console.log(realPath);

var ext = path.extname(realPath);

ext = ext ? ext.slice(1) : 'unknown';

fs.exists(realPath, function (exists) {

if (!exists) {

response.writeHead(404, {

'Content-Type': 'text/plain'

});

response.write("This request URL " + pathname + " was not found on this server.");

response.end();

} else {

fs.readFile(realPath, "binary", function (err, file) {

if (err) {

response.writeHead(500, {

'Content-Type': 'text/plain'

});

response.end(err);

} else {

var contentType = mine[ext] || "text/plain";

response.writeHead(200, {

'Content-Type': contentType

});

response.write(file, "binary");

response.end();

}

});

}

});

});

server.listen(PORT);

console.log("Server runing at port: " + PORT + ".");

上面我们还引入了一个mine.js,这是我自己写的,里面存储的是名值对,用于定义不同后缀的文件所对应的返回方式:

exports.types = {

"css": "text/css",

"gif": "image/gif",

"html": "text/html",

"htm": "text/html",

"ico": "image/x-icon",

"jpeg": "image/jpeg",

"jpg": "image/jpeg",

"js": "text/javascript",

"json": "application/json",

"pdf": "application/pdf",

"png": "image/png",

"svg": "image/svg+xml",

"swf": "application/x-shockwave-flash",

"tiff": "image/tiff",

"txt": "text/plain",

"wav": "audio/x-wav",

"wma": "audio/x-ms-wma",

"wmv": "video/x-ms-wmv",

"xml": "text/xml"

};

fs模块是用于读取文件的,提供读取文件的方法,其实仔细研究文档会发现,它有同步和异步两种读取方式。fs.exists这个方法网上很多文章写作path.exists,,现在推荐写作fs.exists这个方法。否则会报警:

需要注意的是,不仅浏览器访问html文件会形成一次访问,里面链接的js,css等外部文件也会分别形成一次http访问。所以,http.createServer的回调其实是在一次页面访问中执行了多次的。我们console.log(realPath)一下就可以看到:

bVPMf5?w=362&h=366

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
使用Node.js搭建本地服务器非常简单。首先,我们需要安装Node.js。 安装完成后,打开终端(或命令行窗口),进入想要搭建服务器的文件夹。 创建一个新的Node.js文件,命名为server.js(或其他任何你喜欢的名称),然后将以下代码复制到该文件中: ```javascript const http = require('http'); const fs = require('fs'); const path = require('path'); const server = http.createServer((req, res) => { let filePath = path.join(__dirname, req.url); let contentType = 'text/html'; fs.exists(filePath, (exists) => { if (exists) { fs.readFile(filePath, (error, content) => { if (error) { res.writeHead(500); res.end('Server Error'); } else { res.writeHead(200, { 'Content-Type': contentType }); res.end(content, 'utf-8'); } }); } else { res.writeHead(404); res.end('File Not Found'); } }); }); server.listen(3000, () => { console.log('Server running at http://localhost:3000/'); }); ``` 上述代码使用了Node.js的HTTP、FS和Path模块。server.js文件创建了一个HTTP服务器。当有请求发送到服务器时,它会检查请求的URL地址是否是文件路径,并将请求的文件作为响应发回给客户端。 在终端中运行以下命令启动服务器: ``` node server.js ``` 这将在本地启动一个HTTP服务器,监听在3000端口上。你可以通过浏览器访问http://localhost:3000/ 来访问该服务器。 请注意,在代码中,`contentType`变量默认设置为'text/html',这意味着服务器会将所有请求的文件作为HTML文件返回。你也可以根据需要更改它,例如如果你想返回CSS文件,可以将其设置为'text/css'。 以上就是使用Node.js搭建本地服务器并访问文件的简单过程。希望对你有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值