次のように、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 を期待どおりに機能させるにはどうすればよいですか?