2013-10-09 71 views
26

我正在学习使用Node.js.目前,我有一个文件夹结构如下所示:使用RESTIFY服务静态文件

index.html 
server.js 
client 
    index.html 
    subs 
    index.html 
    page.html 
res 
    css 
    style.css 
    img 
    profile.png 
    js 
    page.js 
    jquery.min.js 

server.js是我的web服务器的代码。我使用node server.js从命令行运行。该文件的内容是:

var restify = require('restify'); 

var server = restify.createServer({ 
    name: 'Test App', 
    version: '1.0.0' 
}); 

server.use(restify.acceptParser(server.acceptable)); 
server.use(restify.queryParser()); 
server.use(restify.bodyParser()); 

server.get('/echo/:name', function (req, res, next) { 
    res.send(req.params); 
    return next(); 
}); 

server.listen(2000, function() { 
    console.log('%s running on %s', server.name, server.url); 
}); 

如您所见,此服务器依赖于RESTIFY。我被告知我必须使用RESTIFY。但是,我无法弄清楚如何提供静态文件。例如,如何在我的应用程序中为* .html,* .css,* .png和* .js文件提供服务?

谢谢!

+0

可能的重复:http://stackoverflow.com/questions/15463841/serving-static-files-with-restify-node-js?rq = 1 – vinaut

回答

38

documentation

server.get(/\/docs\/public\/?.*/, restify.serveStatic({ 
    directory: './public' 
})); 

但是,这将在./public/docs/public/目录中搜索文件。
我更喜欢使用__dirname这里的关键:

server.get(/\/public\/?.*/, restify.serveStatic({ 
    directory: __dirname 
})); 

现在大家都/public/.* URL映射到./public/目录。

+0

你的情况下'__dirname'有哪些值? – letmaik

+1

[__dirname](https://nodejs.org/docs/latest/api/globals.html#globals_dirname) –

0

我刚刚遇到了这个问题,所以虽然这可能不会帮助你,但它可以帮助其他有困难的人。

当您声明Restify为​​时,serveStatic方法将位于插件对象中,因此使用restify.serveStatic将悄然失败。访问该方法的正确方法是restify.plugins.serveStatic

你可以找到更新文档位置:http://restify.com/docs/plugins-api/#serve-static

4

根据我目前的RESTify版本(V5.2.0)

serveStatic已移入plugins,所以代码会是这样

server.get(
    /\/(.*)?.*/, 
    restify.plugins.serveStatic({ 
    directory: './static', 
    }) 
) 

上面的语法将为文件夹static上的静态文件提供服务。所以你可以得到像http://yoursite.com/awesome-photo.jpg

的静态文件由于某种原因,如果你想在特定路径下提供静态文件,例如http://yoursite.com/assets/awesome-photo.jpg

的代码应该被重构到这个

server.get(
    /\/assets\/(.*)?.*/, 
    restify.plugins.serveStatic({ 
    directory: `${app_root}/static`, 
    appendRequestPath: false 
    }) 
) 

选项上面appendRequestPath: false意味着我们不包括assets路径到文件名

0
server.get('/', function(req, res, next) { 
    fs.readFile(__dirname + '/index.html', function (err, data) { 
     if (err) { 
      next(err); 
      return; 
     } 
     res.setHeader('Content-Type', 'text/html'); 
     res.writeHead(200); 
     res.end(data); 
     next(); 
    }); 
}); 
0

试试这个:这里的观点是静态资源目录名

server.get('/\/.*/', restify.plugins.serveStatic({ 

    directory: __dirname + "/view/", 
    default: './home.html' 

    }) 
);