次のように、Express フレームワークとhttp-authモジュールを使用して設計された node.js アプリケーションがあります。
var auth = require('http-auth');
var express = require('express');
// ...
var mywebapp = express();
// ...
if (usebasicauth) {
var basic = auth.basic({realm:"MyRealm", file:"/srv/config/passwd"});
mywebapp.use(auth.connect(basic));
}
mywebapp.use('/js', express.static(__dirname + '/files/js'));
mywebapp.use('/css', express.static(__dirname + '/files/css'));
// ...
/jsただし、および/cssディレクトリの下にあるアセットを保護したくありません。これは私がやってみたものです:
if (usebasicauth) {
var basic = auth.basic({realm:"MyRealm", file:"/srv/config/passwd"});
mywebapp.use(function(req, res, next) {
if (/^\/(css|js)/.test(req.url)) {
next();
}
else {
auth.connect(basic);
}
});
}
以下の URL にアクセスして、期待どおり/cssに動作しようとしています。/jsただし、他の URL は読み込まれません。
他の URL を期待どおりに機能させるにはどうすればよいですか?