精华 express 防盗链模块
发布于 11 年前 作者 lellansin 10015 次浏览 最后一次编辑是 9 年前 来自 分享

安装

npm install express-anti-leech

使用

var express = require('express'),
 path = require('path'),
 app = express();
 
var AntiLeech = require('express-anti-leech');
// 允许引用的域名白名单
var hosts = ['localhost', 'localhost:8004'];
// 反盗链类型
var exts = ['.png', '.jpg', '.jpeg', '.gif', '.swf', '.flv'];
// 盗链默认指向图片
var pictrue = "/images/default.png";
app.use(AntiLeech({
 allow: hosts,
 exts: exts,
 log: console.log, // 你也可以使用自己的方法来记录
 default: pictrue
}));
// 请在调用静态资源之前先使用反盗链模块
app.use(express.static(path.join(__dirname, 'public')));
app.set('port', process.env.PORT || 8004);
app.get('/', function(req, res) {
 res.redirect("/index.html");
});
app.listen(app.get('port'), function() {
 console.log("Express test server listening on http://localhost:" + app.get('port'));
});

测试效果图: express_anti_leech_1.jpg express_anti_leech_2.jpg <code>localhost:8004</code> 在白名单之中,而 <code>127.0.0.1:8004</code> 不在白名单中,所以 <code>localhost:8004</code> 下访问正常,而 <code>127.0.0.1:8004</code> 下则被重定向到指定的图片。

9 回复

不错,不过我觉得还是在nginx之类的做好点、

(削除) 不过通常这类问题都是nginx来做的 (削除ここまで)

感谢各位的支持。 关于 nginx 反向代理,个人觉得,node.js 既然已经包含了 webserver 的部分,有些东西用 node.js 来实现也是不错的。只不过目前 node 的 webserver 还不够给力。 而在已经用了 nginx 的情况下(在 node.js 之外又包了一层 webserver),使用 nginx 必然是效率更高的。 本模块的目的就是在没有使用 nginx 的情况下,用来防盗链。或者用了 nginx 但是不想配置的那么分散的人用的(非大型项目,算是程序员常见的懒惰行为吧。不过,说不定以后 node 更新,大家可以不用 nginx 反向代理了 ;) )。

@lellansin 我用websocket模块构建过反向代理,挺好用的,个人觉得效率不比nginx差呀。

挺棒的,支持一下〜!

回到顶部

AltStyle によって変換されたページ (->オリジナル) /