app.js 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. var express = require('express');
  2. var request = require('request');
  3. var path = require('path');
  4. var favicon = require('serve-favicon');
  5. var logger = require('morgan');
  6. var cookieParser = require('cookie-parser');
  7. var bodyParser = require('body-parser');
  8. var logUtils = require('./utils/logUtils');
  9. //Welcome Page
  10. var welcome = require('./routes/welcome');
  11. var index = require('./routes/index');
  12. //网易云音乐
  13. var netease = require('./routes/netease');
  14. //JsonBird version 1.0
  15. var v1 = require('./routes/v1');
  16. var app = express();
  17. app.listen(process.env.PORT || 5000);
  18. /***
  19. * 获取引用网站
  20. */
  21. app.all('*', function(req, res, next) {
  22. res.header("Access-Control-Allow-Origin", "*");
  23. res.header("Access-Control-Allow-Headers", "Origin, X-Requested-With, Content-Type, Accept,Access-Control-Allow-Origin");
  24. res.header("Access-Control-Allow-Methods", "PUT,POST,GET,DELETE,OPTIONS");
  25. res.header("X-Powered-By", '1.0.0');
  26. res.header("Vary", "Origin");
  27. var protocol = req.protocol;
  28. var host = req.hostname;
  29. var ip = req.ip;
  30. var ref = req.headers.referer;
  31. var originalUrl = req.originalUrl;
  32. var logs = {
  33. IP: ip,
  34. Host: host,
  35. Referer: ref,
  36. //Protocol: protocol,
  37. Location: '',
  38. OriginalUrl: originalUrl
  39. };
  40. if (/Host/.test(originalUrl)) {
  41. next();
  42. } else {
  43. if (originalUrl.indexOf('/bing/') > -1 || originalUrl.indexOf('/assets/') > -1) {
  44. var err = new Error('这个接口已经改了,请不要在访问这个接口了..., 新的接口:https://api.ioliu.cn/v1/');
  45. err.status = 404;
  46. next(err);
  47. return;
  48. }
  49. if (originalUrl.indexOf('.css') === -1 && originalUrl.indexOf('.js') === -1) {
  50. logUtils.log(logs);
  51. var str = '';
  52. for (var i in logs) {
  53. str += (i + '=' + logs[i] + '&');
  54. }
  55. request('http://bird.daoapp.io?' + str);
  56. }
  57. next();
  58. }
  59. });
  60. // view engine setup
  61. app.set('views', path.join(__dirname, 'views'));
  62. app.set('view engine', 'pug');
  63. app.enable('trust proxy');
  64. // uncomment after placing your favicon in /public
  65. //app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
  66. app.use(logger('dev'));
  67. app.use(bodyParser.json());
  68. app.use(bodyParser.urlencoded({ extended: false }));
  69. app.use(cookieParser());
  70. app.use('/static/', express.static(path.join(__dirname, 'public')));
  71. app.use('/', welcome);
  72. app.use('/v1', v1);
  73. app.use('/netease', netease);
  74. // catch 404 and forward to error handler
  75. app.use(function(req, res, next) {
  76. var err = new Error('Not Found');
  77. err.status = 404;
  78. next(err);
  79. });
  80. // error handlers
  81. // development error handler
  82. // will print stacktrace
  83. if (app.get('env') === 'development') {
  84. app.use(function(err, req, res, next) {
  85. res.status(err.status || 500);
  86. res.send({
  87. code: err.status,
  88. message: err.message,
  89. error: err
  90. });
  91. });
  92. }
  93. // production error handler
  94. // no stacktraces leaked to user
  95. app.use(function(err, req, res, next) {
  96. res.status(err.status || 500);
  97. res.send({
  98. code: err.status,
  99. message: err.message,
  100. error: {}
  101. });
  102. });
  103. module.exports = app;