|
@@ -1,6 +1,8 @@
|
|
var express = require('express');
|
|
var express = require('express');
|
|
var request = require('superagent');
|
|
var request = require('superagent');
|
|
var router = express.Router();
|
|
var router = express.Router();
|
|
|
|
+var disabledIP = require('../utils/disabledIP').list;
|
|
|
|
+var cookie = { 'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/54.0.2840.71 Safari/537.36' };
|
|
|
|
|
|
router.get('/*', function(req, res, next) {
|
|
router.get('/*', function(req, res, next) {
|
|
getJSON(req, res, next);
|
|
getJSON(req, res, next);
|
|
@@ -11,7 +13,7 @@ router.post('/*', function(req, res, next) {
|
|
});
|
|
});
|
|
|
|
|
|
function getJSON(req, res, next) {
|
|
function getJSON(req, res, next) {
|
|
- var ip = req.ip.replace(/\:\:ffff\:/, '').replace(/\:\:1/, '127.0.0.1');
|
|
|
|
|
|
+ var ip = req.headers['x-real-ip'] ? req.headers['x-real-ip'] : req.ip.replace(/::ffff:/, '');
|
|
var host = req.hostname;
|
|
var host = req.hostname;
|
|
var protocol = req.protocol;
|
|
var protocol = req.protocol;
|
|
var originalUrl = req.originalUrl;
|
|
var originalUrl = req.originalUrl;
|
|
@@ -25,105 +27,127 @@ function getJSON(req, res, next) {
|
|
},
|
|
},
|
|
status: {
|
|
status: {
|
|
code: 200,
|
|
code: 200,
|
|
- massage: ''
|
|
|
|
|
|
+ message: ''
|
|
}
|
|
}
|
|
};
|
|
};
|
|
- method = req.method.toUpperCase();
|
|
|
|
- if (url) {
|
|
|
|
- var _temp = {};
|
|
|
|
- switch (method) {
|
|
|
|
- case 'GET':
|
|
|
|
- // get request
|
|
|
|
- if (/\?url\=/.test(originalUrl)) {
|
|
|
|
- url = originalUrl.split('url=')[1];
|
|
|
|
- }
|
|
|
|
|
|
+ if (disabledIP.indexOf(ip) > -1) {
|
|
|
|
|
|
- if (params) {
|
|
|
|
- for (var i in params) {
|
|
|
|
- _temp[i] = encodeURI(params[i]);
|
|
|
|
|
|
+ output['data']['info'] = '很抱歉,您的IP因为滥用接口已被禁用,如有疑问,请致信 xioveliu@gmail.com ';
|
|
|
|
+ output['status'] = -1;
|
|
|
|
+ output['message'] = 'DISABLED IP';
|
|
|
|
+ res.json(output);
|
|
|
|
+
|
|
|
|
+ } else {
|
|
|
|
+
|
|
|
|
+ method = req.method.toUpperCase();
|
|
|
|
+ if (url) {
|
|
|
|
+ var _temp = {};
|
|
|
|
+ switch (method) {
|
|
|
|
+ case 'GET':
|
|
|
|
+ // get request
|
|
|
|
+ if (/\?url\=/.test(originalUrl)) {
|
|
|
|
+ url = originalUrl.split('url=')[1];
|
|
}
|
|
}
|
|
- }
|
|
|
|
- url = url.indexOf('?') === -1 ? url.replace(/\&/, '?') : url;
|
|
|
|
- url = /^(http|https)\:\/\//.test(url) ? url : 'http://' + url;
|
|
|
|
- url = url.replace(/\&callback\=(\w+)/, '');
|
|
|
|
- request
|
|
|
|
- .get(url)
|
|
|
|
- .query(_temp)
|
|
|
|
- .end(function(err, response) {
|
|
|
|
- var body = response.text || response.body || {};
|
|
|
|
- if (typeof body === 'string') {
|
|
|
|
- try {
|
|
|
|
- body = JSON.parse(body);
|
|
|
|
- } catch (e) {
|
|
|
|
- output.status = {
|
|
|
|
- code: -1
|
|
|
|
- };
|
|
|
|
- }
|
|
|
|
- }
|
|
|
|
- if (!err && response.statusCode == 200) {
|
|
|
|
- output = body;
|
|
|
|
- } else {
|
|
|
|
- output = {
|
|
|
|
- data: {},
|
|
|
|
- status: {
|
|
|
|
- code: -1,
|
|
|
|
- message: err || 'Something bad happend.'
|
|
|
|
- }
|
|
|
|
- };
|
|
|
|
- }
|
|
|
|
- if (callback) {
|
|
|
|
- res.jsonp(output);
|
|
|
|
- } else {
|
|
|
|
- res.json(output);
|
|
|
|
|
|
+
|
|
|
|
+ if (params) {
|
|
|
|
+ for (var i in params) {
|
|
|
|
+ _temp[i] = encodeURI(params[i]);
|
|
}
|
|
}
|
|
- });
|
|
|
|
- break;
|
|
|
|
- default:
|
|
|
|
- // post request
|
|
|
|
- if (params) {
|
|
|
|
- for (var i in params) {
|
|
|
|
- _temp[i] = params[i];
|
|
|
|
}
|
|
}
|
|
- }
|
|
|
|
- request
|
|
|
|
- .post(url)
|
|
|
|
- .type('form')
|
|
|
|
- .send(_temp)
|
|
|
|
- .end(function(err, response) {
|
|
|
|
- var body = response.text || response.body || {};
|
|
|
|
- if (typeof body === 'string') {
|
|
|
|
- try {
|
|
|
|
- body = JSON.parse(body);
|
|
|
|
- } catch (e) {
|
|
|
|
- output.status = {
|
|
|
|
- code: -1
|
|
|
|
|
|
+ url = url.indexOf('?') === -1 ? url.replace(/\&/, '?') : url;
|
|
|
|
+ url = /^(http|https)\:\/\//.test(url) ? url : 'http://' + url;
|
|
|
|
+ url = url.replace(/\&callback\=(\w+)/, '');
|
|
|
|
+ request
|
|
|
|
+ .get(url)
|
|
|
|
+ .set(cookie)
|
|
|
|
+ .query(_temp)
|
|
|
|
+ .end(function(err, response) {
|
|
|
|
+ var body = {};
|
|
|
|
+ if (response && response.text) {
|
|
|
|
+ body = response.text;
|
|
|
|
+ } else if (response && response.body) {
|
|
|
|
+ body = response.body;
|
|
|
|
+ }
|
|
|
|
+ if (typeof body === 'string') {
|
|
|
|
+ try {
|
|
|
|
+ body = JSON.parse(body);
|
|
|
|
+ } catch (e) {
|
|
|
|
+ output.status = {
|
|
|
|
+ code: -1
|
|
|
|
+ };
|
|
|
|
+ }
|
|
|
|
+ }
|
|
|
|
+ if (!err && response.statusCode == 200) {
|
|
|
|
+ output = body;
|
|
|
|
+ } else {
|
|
|
|
+ output = {
|
|
|
|
+ data: {},
|
|
|
|
+ status: {
|
|
|
|
+ code: -1,
|
|
|
|
+ message: err || 'Something bad happend.'
|
|
|
|
+ }
|
|
};
|
|
};
|
|
}
|
|
}
|
|
|
|
+ if (callback) {
|
|
|
|
+ res.jsonp(output);
|
|
|
|
+ } else {
|
|
|
|
+ res.json(output);
|
|
|
|
+ }
|
|
|
|
+ });
|
|
|
|
+ break;
|
|
|
|
+ default:
|
|
|
|
+ // post request
|
|
|
|
+ if (params) {
|
|
|
|
+ for (var i in params) {
|
|
|
|
+ _temp[i] = params[i];
|
|
}
|
|
}
|
|
- if (!err && response.statusCode == 200) {
|
|
|
|
- output = body;
|
|
|
|
- } else {
|
|
|
|
- output = {
|
|
|
|
- data: {},
|
|
|
|
- status: {
|
|
|
|
- code: -1,
|
|
|
|
- message: err || 'Something bad happend.'
|
|
|
|
|
|
+ }
|
|
|
|
+ request
|
|
|
|
+ .post(url)
|
|
|
|
+ .set(cookie)
|
|
|
|
+ .type('form')
|
|
|
|
+ .send(_temp)
|
|
|
|
+ .end(function(err, response) {
|
|
|
|
+ var body = {};
|
|
|
|
+ if (response && response.text) {
|
|
|
|
+ body = response.text;
|
|
|
|
+ } else if (response && response.body) {
|
|
|
|
+ body = response.body;
|
|
|
|
+ }
|
|
|
|
+ if (typeof body === 'string') {
|
|
|
|
+ try {
|
|
|
|
+ body = JSON.parse(body);
|
|
|
|
+ } catch (e) {
|
|
|
|
+ output.status = {
|
|
|
|
+ code: -1
|
|
|
|
+ };
|
|
}
|
|
}
|
|
- };
|
|
|
|
- }
|
|
|
|
- if (callback) {
|
|
|
|
- res.jsonp(output);
|
|
|
|
- } else {
|
|
|
|
- res.json(output);
|
|
|
|
- }
|
|
|
|
- });
|
|
|
|
- break;
|
|
|
|
- }
|
|
|
|
- } else {
|
|
|
|
- if (callback) {
|
|
|
|
- res.jsonp(output);
|
|
|
|
|
|
+ }
|
|
|
|
+ if (!err && response.statusCode == 200) {
|
|
|
|
+ output = body;
|
|
|
|
+ } else {
|
|
|
|
+ output = {
|
|
|
|
+ data: {},
|
|
|
|
+ status: {
|
|
|
|
+ code: -1,
|
|
|
|
+ message: err || 'Something bad happend.'
|
|
|
|
+ }
|
|
|
|
+ };
|
|
|
|
+ }
|
|
|
|
+ if (callback) {
|
|
|
|
+ res.jsonp(output);
|
|
|
|
+ } else {
|
|
|
|
+ res.json(output);
|
|
|
|
+ }
|
|
|
|
+ });
|
|
|
|
+ break;
|
|
|
|
+ }
|
|
} else {
|
|
} else {
|
|
- res.json(output);
|
|
|
|
|
|
+ if (callback) {
|
|
|
|
+ res.jsonp(output);
|
|
|
|
+ } else {
|
|
|
|
+ res.json(output);
|
|
|
|
+ }
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|