index.php 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117
  1. <?php
  2. /**
  3. * 入口文件
  4. *
  5. * 云函数版本维护:
  6. * 1、去掉顶部的 “#!/usr/bin/env php”,将文件名改为 index.php
  7. * 2、将 “define('IS_SCF', false);” 改为 “define('IS_SCF', true);”
  8. * 3、干掉最下方的 run(); 调用
  9. *
  10. * @author mybsdc <[email protected]>
  11. * @date 2019/3/2
  12. * @time 11:05
  13. * @link https://github.com/luolongfei/freenom
  14. */
  15. error_reporting(E_ERROR);
  16. ini_set('display_errors', 1);
  17. set_time_limit(0);
  18. define('IS_SCF', false); // 是否云函数环境
  19. define('IS_CLI', PHP_SAPI === 'cli');
  20. define('DS', DIRECTORY_SEPARATOR);
  21. define('ROOT_PATH', realpath(__DIR__));
  22. define('VENDOR_PATH', realpath(ROOT_PATH . '/vendor'));
  23. define('APP_PATH', realpath(ROOT_PATH . '/app'));
  24. define('DATA_PATH', IS_SCF ? '/tmp' : realpath(ROOT_PATH . '/app/Data')); // 云函数只有 /tmp 目录的读写权限
  25. define('RESOURCES_PATH', realpath(ROOT_PATH . '/resources'));
  26. date_default_timezone_set('Asia/Shanghai');
  27. /**
  28. * 注册错误处理
  29. */
  30. register_shutdown_function('customize_error_handler');
  31. /**
  32. * 注册异常处理
  33. */
  34. set_exception_handler('exception_handler');
  35. require VENDOR_PATH . '/autoload.php';
  36. use Luolongfei\Libs\Log;
  37. use Luolongfei\Libs\Message;
  38. /**
  39. * @throws Exception
  40. */
  41. function customize_error_handler()
  42. {
  43. if (!is_null($error = error_get_last())) {
  44. Log::error('程序意外终止', $error);
  45. Message::send('可能存在错误,这边收集到的错误信息为:' . json_encode($error, JSON_UNESCAPED_UNICODE), '主人,程序意外终止');
  46. }
  47. }
  48. /**
  49. * @param \Exception $e
  50. *
  51. * @throws \Exception
  52. */
  53. function exception_handler($e)
  54. {
  55. Log::error('未捕获的异常:' . $e->getMessage());
  56. Message::send("具体的异常内容是:\n" . $e->getMessage(), '主人,未捕获的异常');
  57. }
  58. /**
  59. * 腾讯云函数
  60. *
  61. * @param $event
  62. * @param $context
  63. *
  64. * @return string
  65. */
  66. function main_handler($event, $context)
  67. {
  68. return run();
  69. }
  70. /**
  71. * 阿里云函数
  72. *
  73. * @param $event
  74. * @param $context
  75. *
  76. * @return string
  77. */
  78. function handler($event, $context)
  79. {
  80. $logger = $GLOBALS['fcLogger'];
  81. $logger->info('开始执行阿里云函数');
  82. return run();
  83. }
  84. /**
  85. * @return string|bool
  86. */
  87. function run()
  88. {
  89. try {
  90. system_check();
  91. $class = sprintf('Luolongfei\App\Console\%s', get_argv('c', 'FreeNom'));
  92. $fn = get_argv('m', 'handle');
  93. $class::getInstance()->$fn();
  94. return IS_SCF ? '云函数执行成功。' : true;
  95. } catch (\Exception $e) {
  96. system_log(sprintf('执行出错:<red>%s</red>', $e->getMessage()), $e->getTrace());
  97. Message::send("执行出错:\n" . $e->getMessage(), '主人,捕获异常');
  98. }
  99. return IS_SCF ? '云函数执行失败。' : false;
  100. }