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

安装

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差呀。

挺棒的,支持一下~!

回到顶部