CommonFunction.php 37 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085
  1. <?php
  2. namespace Biz\Common;
  3. class CommonFunction {
  4. function checkDebug()
  5. {
  6. return (isset($_GET['debug']) && intval($_GET['debug'])==-99999) || APP_DEBUG==1?1:0;
  7. }
  8. function View($Path = "") {
  9. if (!$Path) {
  10. global $ViewPath;
  11. $ViewPath = explode("\\", $ViewPath);
  12. $ViewPath[3] = explode("Controller", $ViewPath[3]);
  13. $ViewPath[3] = $ViewPath[3][0];
  14. return APP_PATH . "/" . $ViewPath[1] . "/View/" . $ViewPath[3] . "/" . $ViewPath[4] . ".blade.php";
  15. } else {
  16. return APP_PATH . "/" . $Path . ".blade.php";
  17. }
  18. }
  19. function arrayToOptions($data, $key, $val)
  20. {
  21. $options = array();
  22. if (is_array($data) && count($data)) {
  23. foreach ($data as $k => $value) {
  24. $options[$value[$key]] = $value[$val];
  25. }
  26. }
  27. return $options;
  28. }
  29. function M($TABLE_NAME = "") {
  30. return new DB($TABLE_NAME);
  31. }
  32. function checkClose() {
  33. if (file_exists(ROOT_PATH . '/Cache/system.lock')) {
  34. if (is_mobile()) {
  35. return appExec("Mobile", "Weihu", "index");
  36. } else {
  37. return appExec("home", "weihu", "index");
  38. }
  39. }
  40. }
  41. /**
  42. * 发布消息
  43. *
  44. * @param integer $status
  45. * @param string $msg
  46. * @param string $data
  47. * @return void
  48. */
  49. function publishNotify($channel, $status = 1, $data = '') {
  50. // toLog('publishNotify-'.$channel.'+++'.$data);
  51. C()->get('msg')->publish($channel, $data);
  52. }
  53. /**
  54. * 数组分类排序
  55. * @param [array] $columnsArr [需要进行排序的数组]
  56. * @param [int] $plmid [所属分类ID]
  57. */
  58. function getColumns($columnsArr, $plmid) {
  59. $menu = array();
  60. foreach ($columnsArr as $v) {
  61. if ($v['plmid'] == $plmid) {
  62. $menu[] = $v;
  63. $a = getColumns($columnsArr, $v['lmid']);
  64. foreach ($a as $vv) {
  65. $menu[] = $vv;
  66. }
  67. }
  68. }
  69. return $menu;
  70. }
  71. /**
  72. * 获取客户端真实IP
  73. */
  74. function GETIP() {
  75. global $ip;
  76. if (getenv("HTTP_CLIENT_IP")) {
  77. $ip = getenv("HTTP_CLIENT_IP");
  78. } else if (getenv("HTTP_X_FORWARDED_FOR")) {
  79. $ip = getenv("HTTP_X_FORWARDED_FOR");
  80. } else if (getenv("REMOTE_ADDR")) {
  81. $ip = getenv("REMOTE_ADDR");
  82. } else {
  83. $ip = "Unknow";
  84. }
  85. return $ip;
  86. }
  87. function dump($data, $exit = 1) {
  88. echo "<pre>";
  89. print_r($data);
  90. echo "</pre>";
  91. if ($exit) {
  92. exit;
  93. }
  94. }
  95. function OrderID($prefix = '') {
  96. $num = mt_rand(100, 999);
  97. list($s, $m) = explode(' ', microtime());
  98. $order = date("YmdHis") . ($s * 1000000) . $num;
  99. return $prefix . $order;
  100. }
  101. /**
  102. * 容器
  103. */
  104. function C() {
  105. static $c = array();
  106. if (!isset($c['container'])) {
  107. $c['container'] = new \System\Di();
  108. }
  109. return $c['container'];
  110. }
  111. /**
  112. * 全局变量快捷操作
  113. * @param [type] $key [description]
  114. * @param [type] $value [description]
  115. */
  116. function S($key, $value = null) {
  117. if ($value != null) {
  118. $GLOBALS[$key] = $value;
  119. }
  120. if (isset($GLOBALS[$key])) {
  121. return $GLOBALS[$key];
  122. }
  123. }
  124. /**
  125. * 载入模型
  126. * @param [type] $name [description]
  127. * @param string $proj [description]
  128. * @return [type] [description]
  129. */
  130. function lm($name, $proj = '') {
  131. $proj = empty($proj) ? S('CUR_PROJECT') : $proj;
  132. if (empty($proj)) {
  133. throw new \Exception("项目{$proj}不存在", 1);
  134. }
  135. $cls = "\\App\\" . ucfirst($proj) . "\\Model\\" . ucfirst($name);
  136. if(!class_exists($cls)){
  137. return;
  138. }
  139. $key = 'model_' . $name . $proj;
  140. C()->shared($key, $cls);
  141. return C()->get($key);
  142. }
  143. /**
  144. * 载入语言包
  145. * @param string $key 语言项
  146. * @param string $file 语言文件名
  147. * @param string $proj 项目名称
  148. * @return [type] [description]
  149. */
  150. function lang($file = '', $proj = '') {
  151. $proj = empty($proj) ? S('CUR_PROJECT') : $proj;
  152. $file = empty($file) ? S('CUR_CONTROLLER') : $file;
  153. $ckey = "Lang_{$proj}_{$file}";
  154. if (C()->has($ckey)) {
  155. return C()->get($ckey);
  156. } else {
  157. C()->shared($ckey, function () use ($proj, $file) {
  158. $file = ucfirst($file);
  159. $proj = ucfirst($proj);
  160. $lang = new \System\Lang();
  161. $lang_files = array();
  162. if (S('CUR_PROJECT') == $proj && S('CUR_CONTROLLER') == $file) {
  163. $lang_files[] = ROOT_PATH . "/Application/Commons/Lang/Common.php";
  164. $lang_files[] = ROOT_PATH . "/Application/{$proj}/Lang/Common.php";
  165. }
  166. $lang_files[] = ROOT_PATH . "/Application/{$proj}/Lang/{$file}.php";
  167. $data = array();
  168. foreach ($lang_files as $v) {
  169. if (file_exists($v)) {
  170. $data2 = include $v;
  171. if (is_array($data2)) {
  172. $data = array_merge($data, $data2);
  173. }
  174. }
  175. }
  176. $lang->load($data);
  177. return $lang;
  178. });
  179. return C()->get($ckey);
  180. }
  181. }
  182. /**
  183. * 标签替换
  184. *
  185. * @param [type] $message
  186. * @param array $data
  187. * @param string $tag
  188. * @return void
  189. */
  190. function parseTag($message,$data=array(),$tag='#'){
  191. if(is_array($data) && count($data)>0){
  192. foreach ($data as $k => $v) {
  193. $message = str_replace($tag . $k . $tag, $v, $message);
  194. }
  195. }
  196. return $message;
  197. }
  198. function appExec($proj, $ctrl, $method, $exec = 0) {
  199. $proj = ucfirst($proj);
  200. $ctrl = ucfirst($ctrl);
  201. $method = ucfirst($method);
  202. S('CUR_PROJECT', $proj);
  203. S('CUR_CONTROLLER', $ctrl);
  204. S('CUR_METHOD', $method);
  205. checkPlatform();
  206. toDomain();
  207. //设置REMOTE_KEY
  208. lm('setinfo','commons')->setKey();
  209. $cls = "\\App\\{$proj}\\Controller\\{$ctrl}";
  210. C()->set($ctrl, $cls);
  211. $cls = C()->get($ctrl);
  212. if (!$cls) {
  213. exit("404 NOT FOUND");
  214. }
  215. if ($exec) {
  216. $result = $cls->$method();
  217. if (!empty($result)) {
  218. Render($result);
  219. }
  220. }
  221. if (method_exists($cls, $method)) {
  222. $result = $cls->$method();
  223. if (!empty($result)) {
  224. Render($result);
  225. }
  226. } else {
  227. exit("404 METHOD NOT FOUND");
  228. }
  229. }
  230. /**
  231. * UUID 生成
  232. */
  233. function UUID() {
  234. $prefix = '';
  235. $uuid = '';
  236. $str = md5(uniqid(mt_rand(), true));
  237. $uuid = substr($str, 0, 8) . '-';
  238. $uuid .= substr($str, 8, 4) . '-';
  239. $uuid .= substr($str, 12, 4) . '-';
  240. $uuid .= substr($str, 16, 4) . '-';
  241. $uuid .= substr($str, 20, 12);
  242. return $prefix . $uuid;
  243. }
  244. /**
  245. *密码加密码
  246. */
  247. function GenEncryption() {
  248. srand((double) microtime() * 1000000); //create a random number feed.
  249. $ychar = "0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F,G,H,I,J,K,L,M,N,O,P,Q,R,S,T,U,V,W,X,Y,Z,a,b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u,v,w,x,y,z";
  250. $list = explode(",", $ychar);
  251. $authnum = "";
  252. for ($i = 0; $i < 6; $i++) {
  253. $randnum = rand(0, 61); // 10+26;
  254. $authnum .= $list[$randnum];
  255. }
  256. return $authnum;
  257. }
  258. //密码加密
  259. function GenPassword($password) {
  260. $Enc = GenEncryption();
  261. $Pwd = md5(md5($Enc . $password));
  262. return array("encryption" => $Enc, "password" => $Pwd);
  263. }
  264. //密码验证
  265. function VerPassword($identity, $password) {
  266. $account = M("account_password")->where("account_identity = '$identity' and", "status = ", '1')->select("encryption,account_password")->find();
  267. $VerPwd = md5(md5($account["encryption"] . $password));
  268. if ($VerPwd == $account["account_password"]) {
  269. unset($account);
  270. unset($VerPwd);
  271. return true;
  272. } else {
  273. unset($account);
  274. unset($VerPwd);
  275. return false;
  276. }
  277. }
  278. /**
  279. * Json return
  280. * @param string $data [description]
  281. * @param string $status [description]
  282. * @param string $msg [description]
  283. * @param string $method [description]
  284. */
  285. function JsonReturn($data = "", $status = "200", $msg = "", $method = "") {
  286. // header("Content-type:application/json;charset:utf-8");
  287. // header('content-type:text/html; charset=utf-8');
  288. if(isset($_REQUEST['crossdomain']) && !empty($_REQUEST['crossdomain'])){
  289. header("Access-Control-Allow-Origin:{$_REQUEST['crossdomain']}");
  290. }else{
  291. header("Access-Control-Allow-Origin:*");
  292. }
  293. header('Access-Control-Allow-Methods:POST,GET,PUT,DELETE,OPTIONS');
  294. header('Access-Control-Allow-Credentials:true');
  295. $retdata=array("status" => $status, "msg" => $msg, "data" =>$data);
  296. $devicetype=isset($_REQUEST['devicetype'])?trim($_REQUEST['devicetype']):'';
  297. if(!empty($devicetype) && in_array($devicetype,array('ios','android'))){
  298. $path=S('CUR_PROJECT').'/'.S('CUR_CONTROLLER').'/'. S('CUR_METHOD');
  299. $retdata=C()->get($devicetype."Result")->update($path,$retdata);
  300. }
  301. if ($method == '') {
  302. //dump($devicetype);
  303. echo (json_encode($retdata,JSON_UNESCAPED_UNICODE));
  304. } else {
  305. echo ($method . "(" . json_encode($retdata,JSON_UNESCAPED_UNICODE) . ")");
  306. }
  307. }
  308. function XmlReturn($data = "", $status = 200, $msg = '') {
  309. // header("Content-type:text/xml;charset:utf-8");
  310. $xml = '<?xml version="1.0" encoding="utf-8"?>';
  311. $xml .= "<root>";
  312. $xml .= '<status>' . $status . '</status>';
  313. $xml .= '<msg>' . $msg . '</msg>';
  314. $xml .= "<rows>";
  315. $xml .= toXml($data);
  316. $xml .= "</rows>";
  317. $xml .= "</root>";
  318. echo($xml);
  319. }
  320. function toXml($data) {
  321. // print_r($data);
  322. $xml = '';
  323. if (is_array($data) && count($data) > 0) {
  324. foreach ($data as $k => $v) {
  325. $key = $k;
  326. if (is_numeric($k)) {
  327. $key = 'data';
  328. }
  329. if (is_array($v)) {
  330. $xml .= "<{$key}>" . toXml($v) . "</{$key}>";
  331. continue;
  332. }
  333. if (is_string($v)) {
  334. $xml .= "<{$key}>{$v}</{$key}>";
  335. }
  336. }
  337. }
  338. return $xml;
  339. }
  340. function WriteLog($Log) {
  341. $logger = new Logger('LOGGS');
  342. $logURI = "Cache/log/" . date("Y-m-d-H-i") . ".log";
  343. $logger->pushHandler(new StreamHandler($logURI, Logger::DEBUG));
  344. $logger->pushHandler(new FirePHPHandler());
  345. $logger->addInfo(var_export($Log,1));
  346. }
  347. /**
  348. * 计算当前用时
  349. *
  350. * @param string $runName
  351. * @param integer $return
  352. * @return void
  353. */
  354. function computeTime($runName='',$return=0,$start=1){
  355. $curTime= get_millisecond();
  356. $numTime=$curTime-(intval($GLOBALS['startTime'])*1000);
  357. if($return){
  358. return array('curTime'=>$curTime,'numTime'=>$numTime,'runName'=>$runName);
  359. }else{
  360. echo "<pre>执行{$runName} 功能,当前时间为:{$curTime},累积用时: {$numTime}</pre>";
  361. return;
  362. }
  363. }
  364. function get_millisecond()
  365. {
  366. list($usec, $sec) = explode(" ", microtime());
  367. $msec = round($usec * 1000);
  368. return $sec . $msec;
  369. }
  370. function toLog($text, $rewrite = 0) {
  371. $data = "=============" . date("Y-m-d H:i", time()) . "==========================================" . chr(13);
  372. $data .= var_export($text, 1) . chr(13);
  373. $data .= "======================================================================================" . chr(13);
  374. $data = iconv('utf-8', 'gb2312', $data);
  375. if ($rewrite) {
  376. file_put_contents(ROOT_PATH . '/logs.txt', $data);
  377. } else {
  378. file_put_contents(ROOT_PATH . '/logs.txt', $data, FILE_APPEND);
  379. }
  380. }
  381. /**
  382. * 发送数据到前台,根据请求的数据格式返回相应的数据
  383. * @param [type] $data [description]
  384. * @param string $status [description]
  385. * @param string $msg [description]
  386. */
  387. function Render($data, $status = "1", $msg = "", $method = '') {
  388. $format = S('CUR_RETURN_FORMAT');
  389. $msg = empty($msg) ? lang('errors', 'api')->get('error' . $status) : $msg;
  390. if (empty($format) || $format == 'json') {
  391. JsonReturn($data, $status, $msg);
  392. }
  393. if ($format == 'xml') {
  394. XmlReturn($data, $status, $msg);
  395. }
  396. exit;
  397. }
  398. function _beginTransaction() {
  399. S('DB')->beginTransaction();
  400. }
  401. function _rollBack() {
  402. S('DB')->rollBack();
  403. }
  404. function _commit() {
  405. S('DB')->commit();
  406. }
  407. /**
  408. * 服务
  409. *
  410. * @param string 服务名称
  411. * @param array $params
  412. * @return void
  413. */
  414. function SRV($name, $params = array()) {
  415. return C()->get($name)->update($params);
  416. }
  417. /**
  418. * 是否验证token过期
  419. *
  420. * @return bool
  421. */
  422. function isCheckToken() {
  423. $result = true;
  424. $allowMethod = include ROOT_PATH . "/Config/AllowMethod.php";
  425. $key = S('CUR_PROJECT') . '/' . S('CUR_CONTROLLER') . '/' . S('CUR_METHOD');
  426. if ($allowMethod[$key] == 1) {
  427. $result = false;
  428. }
  429. return $result;
  430. }
  431. function checkPlatform(){
  432. if(isset($_GET['platform'])){
  433. $_SESSION['platform']=$_GET['platform']=='wap'?1:0;
  434. }
  435. if(isset($_GET['clearPlatform']) && intval($_GET['clearPlatform'])==1){
  436. $_SESSION['platform']=null;
  437. }
  438. }
  439. function is_mobile() {
  440. if(isset($_SESSION['platform']) && $mobile=intval($_SESSION['platform'])>0 ){
  441. return $mobile==1?true:false;
  442. }
  443. $user_agent = $_SERVER['HTTP_USER_AGENT'];
  444. $mobile_agents = Array("240x320", "acer", "acoon", "acs-", "abacho", "ahong", "airness", "alcatel", "amoi", "android", "anywhereyougo.com", "applewebkit/525", "applewebkit/532", "asus", "audio", "au-mic", "avantogo", "becker", "benq", "bilbo", "bird", "blackberry", "blazer", "bleu", "cdm-", "compal", "coolpad", "danger", "dbtel", "dopod", "elaine", "eric", "etouch", "fly ", "fly_", "fly-", "go.web", "goodaccess", "gradiente", "grundig", "haier", "hedy", "hitachi", "htc", "huawei", "hutchison", "inno", "ipad", "ipaq", "ipod", "jbrowser", "kddi", "kgt", "kwc", "lenovo", "lg ", "lg2", "lg3", "lg4", "lg5", "lg7", "lg8", "lg9", "lg-", "lge-", "lge9", "longcos", "maemo", "mercator", "meridian", "micromax", "midp", "mini", "mitsu", "mmm", "mmp", "mobi", "mot-", "moto", "nec-", "netfront", "newgen", "nexian", "nf-browser", "nintendo", "nitro", "nokia", "nook", "novarra", "obigo", "palm", "panasonic", "pantech", "philips", "phone", "pg-", "playstation", "pocket", "pt-", "qc-", "qtek", "rover", "sagem", "sama", "samu", "sanyo", "samsung", "sch-", "scooter", "sec-", "sendo", "sgh-", "sharp", "siemens", "sie-", "softbank", "sony", "spice", "sprint", "spv", "symbian", "tablet", "talkabout", "tcl-", "teleca", "telit", "tianyu", "tim-", "toshiba", "tsm", "up.browser", "utec", "utstar", "verykool", "virgin", "vk-", "voda", "voxtel", "vx", "wap", "wellco", "wig browser", "wii", "windows ce", "wireless", "xda", "xde", "zte");
  445. $is_mobile = false;
  446. foreach ($mobile_agents as $device) {
  447. if (stristr($user_agent, $device)) {
  448. $is_mobile = true;
  449. break;
  450. }
  451. }
  452. return $is_mobile;
  453. }
  454. function toDomain() {
  455. $domain = $_SERVER['HTTP_HOST'];
  456. $config = include ROOT_PATH . '/Config/Domain.php';
  457. $is_mobile = is_mobile();
  458. $curDomain = $old_domain = $domain;
  459. if (is_array($config) && count($config) > 0) {
  460. $domains = array();
  461. $domains[] = $domain;
  462. if ($is_mobile) {
  463. $domains[] = str_replace('www.', 'm.', $domain);
  464. $domains[] = 'm.' . $domain;
  465. } else {
  466. $domains[] = str_replace('m.', '', $domain);
  467. $domains[] = str_replace('m.', 'www.', $domain);
  468. }
  469. foreach ($domains as $key => $value) {
  470. if (isset($config[$value])) {
  471. $v = $config[$value];
  472. if ($v == 'pay') {
  473. return;
  474. }
  475. if ($is_mobile) {
  476. if ($v == 'pc') {
  477. continue;
  478. }
  479. } else {
  480. if ($v != 'pc') {
  481. continue;
  482. }
  483. }
  484. $curDomain = $value;
  485. // $_SESSION['domain']=$value;
  486. }
  487. }
  488. }
  489. // echo $curDomain;
  490. if ($is_mobile) {
  491. if (S('CUR_PROJECT') == 'Home') {
  492. header("Location:http://" . $curDomain . "/m");
  493. //header("Location:http://" . $curDomain . "/mobile-index/index");
  494. }
  495. } else {
  496. if (S('CUR_PROJECT') == 'Mobile') {
  497. header("Location:http://" . $curDomain . "/home-index/index");
  498. }
  499. }
  500. /**
  501. * 数据签名认证
  502. * @param array $data 被认证的数据
  503. * @return string 签名
  504. */
  505. function data_auth_sign($data) {
  506. //数据类型检测
  507. if (!is_array($data)) {
  508. $data = (array) $data;
  509. }
  510. ksort($data); //排序
  511. $code = http_build_query($data); //url编码并生成query字符串
  512. $sign = sha1($code); //生成签名
  513. return $sign;
  514. }
  515. /*
  516. * 判断用户是否登录
  517. * */
  518. function isLogin($str = '',$type='agent') {
  519. $session = $_SESSION[$type.'Info'];
  520. if(empty($session)){
  521. return null;
  522. }
  523. if($type=='agent'){
  524. if($str=='name'){
  525. return $session['agent_user'];
  526. }
  527. if($str=='uid'){
  528. return $session['user_identity'];
  529. }
  530. }
  531. }
  532. }
  533. function jump($url){
  534. header('Location:'.$url);
  535. }
  536. //手机中间星号
  537. function phoneHide($phone)
  538. {
  539. if (!empty($phone)) {
  540. $phone = substr_replace($phone, '****', 3, 4);
  541. }
  542. return $phone;
  543. }
  544. /**
  545. * @param $game_code 球类代码
  546. * @param int $isJoin 是否用于join
  547. * @return array
  548. * @throws Exception
  549. * 根据球类代码 定义相关model
  550. */
  551. function getModels($game_code,$isJoin=1){
  552. $game_type = lm('GameType', 'Sports')->where('game_code',$game_code)->select('game_code')->first();
  553. // 获取不同球类model
  554. if($isJoin == 1){
  555. switch ($game_type->game_code){
  556. case 'zq':
  557. $model_league = 'st_zq_league';
  558. $model_match = 'st_zq_competition';
  559. $model_odds = 'st_zq_odds';
  560. $model_odds_record = 'st_zq_odds_record';
  561. $model_result = 'st_zq_result';
  562. $model_result_record = 'st_zq_result_record';
  563. $model_league_result = 'st_zq_league_result';
  564. $model_local_league = 'st_zq_local_league';
  565. $model_local_match = 'st_zq_local_match';
  566. break;
  567. case 'lq':
  568. $model_league = 'st_lq_league';
  569. $model_match = 'st_lq_competition';
  570. $model_odds = 'st_lq_odds';
  571. $model_odds_record = 'st_lq_odds_record';
  572. $model_result = 'st_lq_result';
  573. $model_result_record = 'st_lq_result_record';
  574. $model_league_result = 'st_lq_league_result';
  575. $model_local_league = 'st_lq_local_league';
  576. $model_local_match = 'st_lq_local_match';
  577. break;
  578. case 'wq':
  579. $model_league = 'st_wq_league';
  580. $model_match = 'st_wq_competition';
  581. $model_odds = 'st_wq_odds';
  582. $model_odds_record = 'st_wq_odds_record';
  583. $model_result = 'st_wq_result';
  584. $model_result_record = 'st_wq_result_record';
  585. $model_league_result = 'st_wq_league_result';
  586. $model_local_league = 'st_wq_local_league';
  587. $model_local_match = 'st_wq_local_match';
  588. break;
  589. case 'bq':
  590. $model_league = 'st_bq_league';
  591. $model_match = 'st_bq_competition';
  592. $model_odds = 'st_bq_odds';
  593. $model_odds_record = 'st_bq_odds_record';
  594. $model_result = 'st_bq_result';
  595. $model_result_record = 'st_bq_result_record';
  596. $model_league_result = 'st_bq_league_result';
  597. $model_local_league = 'st_bq_local_league';
  598. $model_local_match = 'st_bq_local_match';
  599. break;
  600. case 'gj':
  601. $model_league = 'st_zq_league';
  602. $model_match = 'st_zq_competition';
  603. $model_odds = 'st_zq_odds';
  604. $model_result = 'st_zq_result';
  605. break;
  606. default:
  607. throw new \Exception(Render([], '10002', lang('Tips','Sports')->get('PARAM_ERROR')));
  608. }
  609. }else{
  610. switch ($game_type->game_code){
  611. case 'zq':
  612. $model_league = 'st_zq_league';
  613. $model_match = 'st_zq_competition';
  614. $model_odds = 'st_zq_odds';
  615. $model_result = 'SoccerResult';
  616. break;
  617. case 'lq':
  618. $model_league = 'st_lq_league';
  619. $model_match = 'st_lq_competition';
  620. $model_odds = 'st_lq_odds';
  621. $model_result = 'BasketballResult';
  622. break;
  623. case 'wq':
  624. $model_league = 'st_wq_league';
  625. $model_match = 'st_wq_competition';
  626. $model_odds = 'st_wq_odds';
  627. $model_result = 'TennisResult';
  628. break;
  629. case 'bq':
  630. $model_league = 'st_bq_league';
  631. $model_match = 'st_bq_competition';
  632. $model_odds = 'st_bq_odds';
  633. $model_result = 'BaseballResult';
  634. break;
  635. case 'gj':
  636. $model_league = 'st_zq_league';
  637. $model_match = 'st_zq_competition';
  638. $model_odds = 'st_zq_odds';
  639. $model_result = 'SoccerResult';
  640. break;
  641. default:
  642. throw new \Exception(Render([], '10002', lang('Tips','Sports')->get('PARAM_ERROR')));
  643. }
  644. }
  645. $data = [
  646. 'model_league'=>$model_league,//联赛
  647. 'model_match'=>$model_match,//赛事
  648. 'model_odds'=>$model_odds,//赔率
  649. 'model_result' =>$model_result,//赛事结果
  650. 'model_odds_record' => $model_odds_record,//赔率记录
  651. 'model_result_record' =>$model_result_record,//赛事结果记录
  652. 'model_league_result'=>$model_league_result,//联赛结果
  653. 'model_local_league'=>$model_local_league,//本地关联联赛
  654. 'model_local_match'=>$model_local_match,//本地关联赛事
  655. ];
  656. return $data;
  657. }
  658. /**
  659. * @param $type_code
  660. * @return array
  661. * @throws \Exception
  662. * 获取不同状态下的 查询条件
  663. */
  664. function getState($type_code,$model_match = ''){
  665. if($model_match == ''){
  666. switch ($type_code){
  667. case 'StRollBall'://滚球 正在进行
  668. $where = [
  669. ['status','<','2'],
  670. ['is_rollball','=',1],
  671. /*
  672. ['match_date','=',date("Y-m-d")],
  673. ['match_time','>',date("H:i:s", time()-(90*60))],
  674. ['match_time','<',date("H:i:s", time())]
  675. */
  676. ];
  677. break;
  678. case 'StSoon'://即将 今日两小时内开始
  679. $where = [
  680. ['status','=','0'],
  681. ['match_date','=',date("Y-m-d")],
  682. ['match_time','<',date("H:i:s", strtotime("+2 hour"))],
  683. ['match_time','>',date("H:i:s", time())]
  684. /*
  685. ['utime','>',date("Y-m-d").' 00:00:00']
  686. */
  687. ];
  688. break;
  689. case 'StToday'://今日 今日未开始未结束
  690. $where = [
  691. ['status', '<', '2'],
  692. ['match_date','=',date("Y-m-d")],
  693. ['match_time','>',date("H:i:s", time())],
  694. /*
  695. ['is_today', '=', 1],
  696. ['type', '=', '1'],
  697. ['utime','>',date("Y-m-d").' 00:00:00']
  698. */
  699. ];
  700. break;
  701. case 'StMorningPlate'://早盘
  702. $where = [
  703. ['status', '<', '2'],
  704. ['is_morningplate', '=', 1],
  705. ['us_time','>',$this->qgmdate('Y-m-d H:i:s', '', -4)],
  706. /*
  707. ['match_date','>',date("Y-m-d",time())],
  708. ['match_time','>',date("H:i:s", time())],
  709. ['type', '=', '2'],
  710. ['utime','>',date("Y-m-d").' 00:00:00']
  711. */
  712. ];
  713. break;
  714. case 'StStringScene'://串场
  715. $where = [
  716. ['status', '<', '2'],
  717. ['is_stringscene', '=', 1],
  718. ['us_time','>',$this->qgmdate('Y-m-d H:i:s', '', -4)],
  719. /*
  720. ['match_date','>',date("Y-m-d",time())],
  721. ['match_time','>',date("H:i:s", time())],
  722. ['type', '=', '3'],
  723. ['utime','>',date("Y-m-d").' 00:00:00']
  724. */
  725. ];
  726. break;
  727. case 'StChampion'://冠军
  728. $where = [
  729. 'type'=>1
  730. ];
  731. break;
  732. default:
  733. throw new \Exception(Render([], '10002', lang('Tips','Sports')->get('PARAM_ERROR')));
  734. }
  735. }else{
  736. switch ($type_code){
  737. case 'StRollBall'://滚球 正在进行
  738. $where = [
  739. [$model_match.'.is_rollball','=',1],
  740. [$model_match.'.status','<','2'],
  741. /*
  742. [$model_match.'.status','>','0'],
  743. [$model_match.'.match_date','=',date("Y-m-d")],
  744. [$model_match.'.match_time','>',date("H:i:s", time()-(90*60))],
  745. [$model_match.'.match_time','<',date("H:i:s", time())]
  746. */
  747. ];
  748. break;
  749. case 'StSoon'://即将 今日两小时内开始
  750. $where = [
  751. [$model_match.'.status','=','0'],
  752. [$model_match.'.match_date','=',date("Y-m-d")],
  753. [$model_match.'.match_time','<',date("H:i:s", strtotime("+2 hour"))],
  754. [$model_match.'.match_time','>',date("H:i:s", time())]
  755. /*
  756. [$model_match.'.utime','>',date("Y-m-d").' 00:00:00']
  757. */
  758. ];
  759. break;
  760. case 'StToday'://今日 今日未开始未结束
  761. $where = [
  762. [$model_match.'.status', '<', '2'],
  763. [$model_match.'.match_date','=',date("Y-m-d")],
  764. [$model_match.'.match_time','>',date("H:i:s", time())],
  765. /*
  766. [$model_match.'.utime','>',date("Y-m-d").' 00:00:00'],
  767. [$model_match.'.is_today','=',1],
  768. [$model_match.'.type', '=', '1'],
  769. */
  770. ];
  771. break;
  772. case 'all'://所有赛事
  773. $where = [
  774. [$model_match.'.status', '<', '2'],
  775. ];
  776. break;
  777. case 'StMorningPlate'://早盘
  778. $where = [
  779. [$model_match.'.status', '<', '2'],
  780. [$model_match.'.is_morningplate','=',1],
  781. [$model_match.'.us_time','>',$this->qgmdate('Y-m-d H:i:s', '', -4)],
  782. /*
  783. [$model_match.'.match_date','>',date("Y-m-d",time())],
  784. [$model_match.'.match_time','>',date("H:i:s", time())],
  785. [$model_match.'.type', '=', '2'],
  786. [$model_match.'.utime','>',date("Y-m-d").' 00:00:00']
  787. */
  788. ];
  789. break;
  790. case 'StStringScene'://串场 查询串场状态为1 开赛时间大于当前时间
  791. $where = [
  792. [$model_match.'.is_stringscene','=',1],
  793. [$model_match.'.us_time','>',$this->qgmdate('Y-m-d H:i:s', '', -4)],
  794. [$model_match.'.status', '<', '2'],
  795. /*
  796. [$model_match.'.match_date','>',date("Y-m-d",time())],
  797. [$model_match.'.match_time','>',date("H:i:s", time())],
  798. [$model_match.'.type', '=', '3'],
  799. [$model_match.'.utime','>',date("Y-m-d").' 00:00:00']
  800. */
  801. ];
  802. break;
  803. case 'StChampion'://冠军
  804. $where = [
  805. 'type'=>1
  806. ];
  807. break;
  808. default:
  809. throw new \Exception(Render([], '10002', lang('Tips','Sports')->get('PARAM_ERROR')));
  810. }
  811. }
  812. return $where;
  813. }
  814. /**
  815. * @param $data
  816. * @return array
  817. * 处理当国家下无联赛数据 删除该数组
  818. */
  819. function handleArr($data){
  820. $hData = [];
  821. foreach ($data as $key =>$v){
  822. if(empty($v['league_count'])){
  823. $v = [];
  824. }
  825. $hData[]=$v;
  826. }
  827. foreach($hData as $k=>$v){
  828. if(empty($v)){
  829. unset($hData[$k]);
  830. }
  831. }
  832. foreach ($hData as $k=>$v){
  833. $v['league_count'] = array_values($v['league_count']);
  834. $hData[$k]=$v;
  835. }
  836. return array_values($hData);
  837. }
  838. /**
  839. * @param $arr
  840. * @param $key
  841. * @return array
  842. * 去除二维数组重复项
  843. */
  844. function array_unset_tt($arr,$key){
  845. //建立一个目标数组
  846. $res = array();
  847. foreach ($arr as $value) {
  848. //查看有没有重复项
  849. if(isset($res[$value[$key]])){
  850. unset($value[$key]); //有:销毁
  851. }else{
  852. $res[$value[$key]] = $value;
  853. }
  854. }
  855. return $res;
  856. }
  857. /**
  858. * 处理冠军盘口 数组结构
  859. */
  860. function array_gj_tt($data,$oddsData){
  861. foreach ($data as $k=>&$v){
  862. foreach ($v['league_count'] as $kk=>&$vv){
  863. foreach ($oddsData as $kkk=>$vvv){
  864. if($vv['lg_id'] == $vvv['lg_id']){
  865. $vv['oddsData'][]=$vvv;
  866. }
  867. }
  868. if($vv['oddsData']){
  869. $vv['oddsData'] = $this->array_unset_tt($vv['oddsData'],'p_code');
  870. $vv['count'] = count($vv['oddsData']);
  871. unset($vv['oddsData']);
  872. }
  873. if(count($vv) == 5){
  874. unset($v['league_count'][$kk]);
  875. }
  876. }
  877. $v['league_count'] = array_values($v['league_count']);
  878. if(empty($v['league_count'])){
  879. unset($data[$k]);
  880. }
  881. }
  882. return array_values($data);
  883. }
  884. /**
  885. * 处理冠军以外 数组结构
  886. */
  887. function array_other_tt($data,$matchData){
  888. foreach ($data as $k=>&$v){
  889. foreach ($v['league_count'] as $kk=>&$vv){
  890. foreach ($matchData as $kkk=>$vvv){
  891. if($vv['lg_id'] == $vvv['lg_id']){
  892. $vv['matchData'][]=$vvv;
  893. }
  894. }
  895. if($vv['matchData']){
  896. $vv['matchData'] = $this->array_unset_tt($vv['matchData'],'match_id');
  897. $vv['count'] = count($vv['matchData']);
  898. unset($vv['matchData']);
  899. }
  900. if(empty($vv['count'])){
  901. unset($v['league_count'][$kk]);
  902. }
  903. }
  904. $v['league_count'] = array_values($v['league_count']);
  905. if(empty($v['league_count'])){
  906. unset($data[$k]);
  907. }
  908. }
  909. return array_values($data);
  910. }
  911. /**
  912. * 时间格式化
  913. * @param string $dateformat 时间格式
  914. * @param int $timestamp 时间戳
  915. * @param int $timeoffset 时区偏差 默认8 北京时间 -4美东时间
  916. * @return string
  917. */
  918. function qgmdate($dateformat = 'Y-m-d H:i:s', $timestamp = '', $timeoffset = 8,$type = '') {
  919. if(empty($timestamp)) {
  920. $timestamp = time();
  921. }
  922. $result = gmdate($dateformat, $timestamp + $timeoffset * 3600);
  923. return $result;
  924. }
  925. /**
  926. * 判断二维数组是否包含一维数组
  927. * @param mixed $arr 查询条件
  928. * @param mixed $arrs 运动类型
  929. * @return string
  930. */
  931. function judgeEqual($arr, $arrs){
  932. foreach ($arrs as $value) {
  933. if (count($value) === count($arr)) {
  934. $a = 0;
  935. foreach ($value as $key => $v) {
  936. $a++;
  937. if ($v != $arr[$key]) {
  938. break;
  939. }
  940. if ($a == count($key)) { // 到最后一个元素都没有出现不相等,就说明这两个数组相等。
  941. return true;
  942. }
  943. }
  944. }
  945. }
  946. return false;
  947. }
  948. // 排列
  949. function arrangement($a, $m) {
  950. $r = array();
  951. $n = count($a);
  952. if ($m <= 0 || $m > $n) {
  953. return $r;
  954. }
  955. for ($i=0; $i<$n; $i++) {
  956. $b = $a;
  957. $t = array_splice($b, $i, 1);
  958. if ($m == 1) {
  959. $r[] = $t;
  960. } else {
  961. $c = $this->arrangement($b, $m-1);
  962. foreach ($c as $v) {
  963. $r[] = array_merge($t, $v);
  964. }
  965. }
  966. }
  967. return $r;
  968. }
  969. // 组合
  970. function combination($a, $m) {
  971. $r = array();
  972. $n = count($a);
  973. if ($m <= 0 || $m > $n) {
  974. return $r;
  975. }
  976. for ($i=0; $i<$n; $i++) {
  977. $t = array($a[$i]);
  978. if ($m == 1) {
  979. $r[] = $t;
  980. } else {
  981. $b = array_slice($a, $i+1);
  982. $c = $this->combination($b, $m-1);
  983. foreach ($c as $v) {
  984. $r[] = array_merge($t, $v);
  985. }
  986. }
  987. }
  988. return $r;
  989. }
  990. // 阶乘
  991. function factorial($n) {
  992. return array_product(range(1, $n));
  993. }
  994. // 排列数
  995. function A1($n, $m) {
  996. return factorial($n)/factorial($n-$m);
  997. }
  998. // 组合数
  999. function C1($n, $m) {
  1000. return A1($n, $m)/factorial($m);
  1001. }
  1002. }
  1003. ?>