fcgi_server.php 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: stanley-king
  5. * Date: 16/3/10
  6. * Time: 下午9:08
  7. */
  8. class fcgi_server
  9. {
  10. static private $stInstance = NULL;
  11. static public function instance()
  12. {
  13. if(self::$stInstance == NULL) {
  14. self::$stInstance = new fcgi_server();
  15. }
  16. return self::$stInstance;
  17. }
  18. private function is_exclude($file)
  19. {
  20. static $exfiles = array('wxnotify.php','pub_wxnotify.php','alipay_notify_url.php','dispatch_notify.php','kdniao_notify.php',
  21. 'cmbpay_notify.php','cmbpay_sign.php','wxauthor.php','api/wxLogin/index.php','api/wxLogin/callback.php',
  22. 'test.php');
  23. $path = BASE_ROOT_PATH . '/mobile/';
  24. $file = str_replace($path,'',$file);
  25. return in_array($file,$exfiles);
  26. }
  27. private function parase_requri()
  28. {
  29. $method = strtolower(request_helper::method());
  30. if($method == 'get') {
  31. return;
  32. }
  33. $file = request_helper::req_uri();
  34. $ops = explode("?",$file);
  35. if(count($ops) == 2)
  36. {
  37. $squery = $ops[1];
  38. $params = preg_split('/&|=/', $squery);
  39. for ($i = 0; $i < count($params); ++$i) {
  40. $key = $params[$i];
  41. $val = $params[++$i];
  42. $_GET[$key] = $val;
  43. $_POST[$key] = $val;
  44. }
  45. }
  46. }
  47. private function clear_global()
  48. {
  49. $_SESSION = [];
  50. $_COOKIE = [];
  51. $_POST = [];
  52. $_GET = [];
  53. }
  54. public function run_looper()
  55. {
  56. DFAFilter::instance();
  57. require_once(BASE_ROOT_PATH.'/mobile/index.php');
  58. while(($ret = fcgi_accept()) >= 0)
  59. {
  60. $start = microtime(true);
  61. ob_start();
  62. $this->clear_global();
  63. performance_helper::clear();
  64. http_header::instance()->start();
  65. try
  66. {
  67. Log::start_sql_log();
  68. $this->parase_requri();
  69. init_request();
  70. init_cookie($_SERVER['HTTP_COOKIE']);
  71. $file = request_helper::script_file();
  72. session::instance()->start();
  73. $remote_addr = request_helper::remote_addr();
  74. Log::record("file={$file} remoteaddr={$remote_addr}",Log::DEBUG);
  75. if(file_exists($file))
  76. {
  77. if(self::is_exclude($file))
  78. {
  79. include $file;
  80. }
  81. else
  82. {
  83. fcgi_header("Content-Type: text/html; charset=UTF-8");
  84. if(!isset($_GET['act'])) {
  85. $_GET['act'] = 'index';
  86. }
  87. if(!isset($_GET['op'])) {
  88. $_GET['op'] = 'index';
  89. }
  90. if(!isset($_POST['act'])) {
  91. $_POST['act'] = 'index';
  92. }
  93. if(!isset($_POST['op'])) {
  94. $_POST['op'] = 'index';
  95. }
  96. Base::mobile_control();
  97. }
  98. }
  99. else
  100. {
  101. fcgi_header("Content-Type: text/html; charset=UTF-8");
  102. echo "no such file.";
  103. }
  104. }
  105. catch (Exception $ex) {
  106. mobileControl::outerr($ex->getCode(),$ex->getMessage());
  107. Log::record("run_looper exception catch code={$ex->getCode()} msg={$ex->getMessage()} trace={$ex->getTraceAsString()}",Log::ERR);
  108. }
  109. session::instance()->end();
  110. fcgi_headers_sent();
  111. $contents = ob_get_clean();
  112. Log::record("run_looper contents={$contents}",Log::ERR);
  113. // fcgi_echo($contents);
  114. Log::end_sql_log();
  115. //fcgi_finish();//单线程的情况下不需要调用
  116. $msg = sprintf("request time=%.6f\r\n\r\n",microtime(true) - $start);
  117. Log::record($msg,Log::DEBUG);
  118. }
  119. fcgi_fini();
  120. }
  121. }