functions.php 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. <?php
  2. /**
  3. * 加载配置
  4. */
  5. function load_config()
  6. {
  7. $GLOBALS['cfg'] = include(CONFIG_FILE);
  8. }
  9. /**
  10. * 写入调试日志
  11. * @param string $msg 日志消息
  12. * @param string $type 日志级别
  13. * @param string $file 文件名
  14. * @return bool 操作状态
  15. */
  16. function debug_log($msg, $type = 'DEBUG', $file = 'debug')
  17. {
  18. global $cfg;
  19. $type = strtoupper($type);
  20. if (!in_array($type, $cfg['log_types'])) {
  21. return false;
  22. }
  23. $msg = is_scalar($msg) ? strval($msg) : json_encode($msg, JSON_UNESCAPED_UNICODE);
  24. $file = $cfg['log_path'] . '/' . $file . '.log';
  25. clearstatcache(true, $file);
  26. $flags = (file_exists($file) && filesize($file) >= $cfg['log_max_size']) ? 0 : FILE_APPEND;
  27. return file_put_contents($file, date("[Y-m-d H:i:s] ") . $type . ': ' . $msg . "\n", $flags);
  28. }
  29. /**
  30. * 确保只有一个实例在运行
  31. * @param int $lock 锁文件路径
  32. * @return resource 锁文件句柄
  33. */
  34. function run_single_instance($lock)
  35. {
  36. //打开文件(不存在创建,存在以写入方式打开,指针位于文件头,)
  37. $fh = fopen($lock, 'c');
  38. if (!$fh) {
  39. exit(1);
  40. }
  41. //尝试上锁
  42. if (!flock($fh, LOCK_EX | LOCK_NB)) {
  43. exit(0);
  44. }
  45. //截断文件
  46. ftruncate($fh, 0);
  47. //写入进程ID
  48. fwrite($fh, getmypid());
  49. fflush($fh);
  50. //返回
  51. return $fh;
  52. }
  53. /**
  54. * 使用cURL发送POST请求
  55. * @param string $url 请求地址
  56. * @param array $post POST数据数组
  57. * @param array $options HTTP选项数组
  58. * @param string $error 用于返回错误信息
  59. * @param int $errno 用于返回错误码
  60. * @param string $httpCode 用于返回响应的HTTP状态码
  61. * @param array $outHeaders 用于获得返回的HTTP头
  62. * @return mixed 成功返回请求返回结果,失败返回flase
  63. */
  64. function curl_post($url, $post = [], $options = [], &$error = false, &$errno = false, &$httpCode = false, $isupload = false, &$outHeaders = false)
  65. {
  66. $heads = array();
  67. $defaults = [
  68. CURLOPT_POST => 1,
  69. CURLOPT_URL => $url,
  70. CURLOPT_RETURNTRANSFER => 1,
  71. CURLOPT_CONNECTTIMEOUT => 5,
  72. CURLOPT_TIMEOUT => 10,
  73. CURLOPT_POSTFIELDS => ($isupload || is_string($post)) ? $post : http_build_query($post),
  74. ];
  75. if ($isupload) {
  76. $defaults[CURLOPT_SAFE_UPLOAD] = true;
  77. }
  78. if (is_array($outHeaders)) {
  79. $defaults[CURLOPT_HEADERFUNCTION] = function ($c, $v) use(&$outHeaders) {
  80. if(!empty(rtrim($v))) {
  81. list($field, $value) = explode(':', $v, 2);
  82. if ($field && $value) {
  83. $outHeaders[strtolower($field)] = trim($value);
  84. }
  85. }
  86. return strlen($v);
  87. };
  88. }
  89. $ch = curl_init();
  90. $result = '';
  91. if ($ch) {
  92. foreach ($options as $k=>$v) {
  93. $defaults[$k] = $v;
  94. }
  95. curl_setopt_array($ch, $defaults);
  96. $result = curl_exec($ch);
  97. if ($result === false) {
  98. if ($error !== false) {
  99. $error = curl_error($ch);
  100. }
  101. if ($errno !== false) {
  102. $errno = curl_errno($ch);
  103. }
  104. }
  105. if ($httpCode !== false) {
  106. $httpCode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
  107. }
  108. curl_close($ch);
  109. }
  110. return $result;
  111. }
  112. /**
  113. * 使用cURL发送GET请求
  114. * @param string $url 请求地址
  115. * @param array $post GET数据数组
  116. * @param array $options HTTP选项数组
  117. * @param string $error 用于返回错误信息
  118. * @param int $errno 用于返回错误码
  119. * @param string $httpCode 用于返回响应的HTTP状态码
  120. * @param array $outHeaders 用于获得返回的HTTP头
  121. * @return mixed 成功返回请求返回结果,失败返回flase
  122. */
  123. function curl_get($url, $get = [], $options = [], &$error = false, &$errno = false, &$httpCode = false, &$outHeaders = false)
  124. {
  125. $defaults = [
  126. CURLOPT_URL => $url. (strpos($url, '?') === FALSE ? '?' : '&'). http_build_query($get),
  127. CURLOPT_HEADER => 0,
  128. CURLOPT_RETURNTRANSFER => TRUE,
  129. CURLOPT_CONNECTTIMEOUT => 5,
  130. CURLOPT_TIMEOUT => 10,
  131. ];
  132. if (is_array($outHeaders)) {
  133. $defaults[CURLOPT_HEADERFUNCTION] = function ($c, $v) use(&$outHeaders) {
  134. if (!empty(rtrim($v))) {
  135. list($field, $value) = explode(':', $v, 2);
  136. if ($field && $value) {
  137. $outHeaders[strtolower($field)] = trim($value);
  138. }
  139. }
  140. return strlen($v);
  141. };
  142. }
  143. $ch = curl_init();
  144. $result = '';
  145. if ($ch) {
  146. foreach ($options as $k=>$v) {
  147. $defaults[$k] = $v;
  148. }
  149. curl_setopt_array($ch, $defaults);
  150. $result = curl_exec($ch);
  151. if ($result === false) {
  152. if ($error !== false) {
  153. $error = curl_error($ch);
  154. }
  155. if ($errno !== false) {
  156. $errno = curl_errno($ch);
  157. }
  158. }
  159. if ($httpCode !== false) {
  160. $httpCode = curl_getinfo($ch, CURLINFO_HTTP_CODE);
  161. }
  162. curl_close($ch);
  163. }
  164. return $result;
  165. }