使用ruby搭建简易的http服务和sass环境

由于在通常的前端开发情况下,我们会有可能需要一个http服务,当然你可以选择自己写一个node的http服务,也比较简单,比如下面的node代码:

var PORT = 3000;

var http = require('http');
var url=require('url');
var fs=require('fs');
var mine= {
"css": "text/css",
"gif": "image/gif",
"html": "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"
};
var path=require('path');
var server = http.createServer(function (request, response) {
var pathname = url.parse(request.url).pathname;
console.log(pathname)
var realPath = pathname.substr(1);//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 + ".");

但这个比较麻烦就是每次都要把这个文件copy到项目目录下,而且安装sass环境也是需要ruby的,所以我们有必要了解下gem安装sass 和asdf.

先导官网下载个ruby ,安装完之后就可以使用

gem install sass

命令安装其他组件了,比如要装sass环境.如果要安装beta版本的,可以在命令行中输入

gem install sass --pre

升级命令是

gem update sass

今天我们要装asdf这么个http服务,首先我们使用

gem install asdf

安装完成之后就可以在你需要访问的文件夹目录使用

asdf -p 8080

然后就会出现如下图所示:

然后你就可以使用 http://localhost:8080/ 来访问当前目录的http服务了。

由于国内网络原因,有可能导致 rubygems.org 存放在 Amazon S3 上面的资源文件间歇性连接失败。这时候我们可以通过gem sources命令来配置源,先移除默认的https://rubygems.org源,然后添加淘宝的源https://ruby.taobao.org/,然后查看下当前使用的源是哪个,如果是淘宝的,则表示可以输入sass安装命令gem install了。

$ gem sources --remove https://rubygems.org/
$ gem sources -a https://ruby.taobao.org/
$ gem sources -l
*** CURRENT SOURCES *** https://ruby.taobao.org
# 请确保只有 ruby.taobao.org
$ gem install sass

最新文章

  1. Unity中游戏的声音管理
  2. window.print() 去掉页眉页脚及打印链接【转载】
  3. 你了解System.out.println()的真正含义吗?
  4. sql 时间向减函数
  5. rolling hash
  6. 用css3写出来的进度条
  7. php实现返回上一页的功能的3种有效方法
  8. smartforms长文本处理方式
  9. $.each()遍历json数据
  10. Socket之心跳包实现思路
  11. 背包九讲PDF
  12. shell脚本执行错误 $'\r':command not found
  13. 重构客户注册-基于ActiveMQ实现短信验证码生产者
  14. Java读取Excel内容
  15. Mac命令行使用tree查看目录结构
  16. cached-query 将缓存和查询数据库高速连接起来的轻类库
  17. Eclipse中Activiti插件的安装
  18. Humble Numbers(hdu1058)
  19. Solidworks公司电脑图纸被加密之后如何解密输出
  20. 主流HTML5游戏框架的分析和对比

热门文章

  1. 【转】“正由另一进程使用,因此该进程无法访问该文件”的问题&解决方法
  2. 【转】C#中如何实现左截取和右截取字符串
  3. C++中typename关键字的用法
  4. MySQL性能优化的最佳21条经验
  5. c#用socket异步传输字符串
  6. struts深入原理之RequestProcessor与xml
  7. sizzle源码分析 (4)sizzle 技术总结及值得我们学习的地方
  8. 《HelloGitHub月刊》第05期
  9. PHP函数处理函数实例详解
  10. Activity onDestroy() 回调缓慢问题分析及完美解决方案