CommonFunction.php 40 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186
  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. // ['is_rollball','=',1],
  670. ['status','<','2'],
  671. ['match_date','=',date("Y-m-d")],
  672. ['match_time','>',date("H:i:s", time()-(90*60))],
  673. ['match_time','<',date("H:i:s", time())]
  674. ];
  675. break;
  676. case 'StSoon'://即将 今日两小时内开始
  677. $where = [
  678. ['status','=','0'],
  679. ['match_date','=',date("Y-m-d")],
  680. ['match_time','<',date("H:i:s", strtotime("+2 hour"))],
  681. ['match_time','>',date("H:i:s", time())]
  682. /*
  683. ['utime','>',date("Y-m-d").' 00:00:00']
  684. */
  685. ];
  686. break;
  687. case 'StToday'://今日 今日未开始未结束
  688. $where = [
  689. ['status', '<', '2'],
  690. ['match_date','=',date("Y-m-d")],
  691. ['match_time','>',date("H:i:s", time())],
  692. /*
  693. ['is_today', '=', 1],
  694. ['type', '=', '1'],
  695. ['utime','>',date("Y-m-d").' 00:00:00']
  696. */
  697. ];
  698. break;
  699. case 'StMorningPlate'://早盘
  700. $where = [
  701. ['status', '<', '2'],
  702. ['is_morningplate', '=', 1],
  703. ['us_time','>',$this->qgmdate('Y-m-d H:i:s', '', -4)],
  704. /*
  705. ['match_date','>',date("Y-m-d",time())],
  706. ['match_time','>',date("H:i:s", time())],
  707. ['type', '=', '2'],
  708. ['utime','>',date("Y-m-d").' 00:00:00']
  709. */
  710. ];
  711. break;
  712. case 'StStringScene'://串场
  713. $where = [
  714. ['status', '<', '2'],
  715. ['is_stringscene', '=', 1],
  716. ['us_time','>',$this->qgmdate('Y-m-d H:i:s', '', -4)],
  717. /*
  718. ['match_date','>',date("Y-m-d",time())],
  719. ['match_time','>',date("H:i:s", time())],
  720. ['type', '=', '3'],
  721. ['utime','>',date("Y-m-d").' 00:00:00']
  722. */
  723. ];
  724. break;
  725. case 'StChampion'://冠军
  726. $where = [
  727. 'type'=>1
  728. ];
  729. break;
  730. default:
  731. throw new \Exception(Render([], '10002', lang('Tips','Sports')->get('PARAM_ERROR')));
  732. }
  733. }else{
  734. switch ($type_code){
  735. case 'StRollBall'://滚球 正在进行
  736. $where = [
  737. // [$model_match.'.is_rollball','=',1],
  738. [$model_match.'.status','<','2'],
  739. [$model_match.'.match_date','=',date("Y-m-d")],
  740. [$model_match.'.match_time','>',date("H:i:s", time()-(90*60))],
  741. [$model_match.'.match_time','<',date("H:i:s", time())]
  742. ];
  743. break;
  744. case 'StSoon'://即将 今日两小时内开始
  745. $where = [
  746. [$model_match.'.status','=','0'],
  747. [$model_match.'.match_date','=',date("Y-m-d")],
  748. [$model_match.'.match_time','<',date("H:i:s", strtotime("+2 hour"))],
  749. [$model_match.'.match_time','>',date("H:i:s", time())]
  750. /*
  751. [$model_match.'.utime','>',date("Y-m-d").' 00:00:00']
  752. */
  753. ];
  754. break;
  755. case 'StToday'://今日 今日未开始未结束
  756. $where = [
  757. [$model_match.'.status', '<', '2'],
  758. [$model_match.'.match_date','=',date("Y-m-d")],
  759. [$model_match.'.match_time','>',date("H:i:s", time())],
  760. /*
  761. [$model_match.'.utime','>',date("Y-m-d").' 00:00:00'],
  762. [$model_match.'.is_today','=',1],
  763. [$model_match.'.type', '=', '1'],
  764. */
  765. ];
  766. break;
  767. case 'all'://所有赛事
  768. $where = [
  769. [$model_match.'.status', '<', '2'],
  770. ];
  771. break;
  772. case 'StMorningPlate'://早盘
  773. $where = [
  774. [$model_match.'.status', '<', '2'],
  775. [$model_match.'.is_morningplate','=',1],
  776. [$model_match.'.us_time','>',$this->qgmdate('Y-m-d H:i:s', '', -4)],
  777. /*
  778. [$model_match.'.match_date','>',date("Y-m-d",time())],
  779. [$model_match.'.match_time','>',date("H:i:s", time())],
  780. [$model_match.'.type', '=', '2'],
  781. [$model_match.'.utime','>',date("Y-m-d").' 00:00:00']
  782. */
  783. ];
  784. break;
  785. case 'StStringScene'://串场 查询串场状态为1 开赛时间大于当前时间
  786. $where = [
  787. [$model_match.'.is_stringscene','=',1],
  788. [$model_match.'.us_time','>',$this->qgmdate('Y-m-d H:i:s', '', -4)],
  789. [$model_match.'.status', '<', '2'],
  790. /*
  791. [$model_match.'.match_date','>',date("Y-m-d",time())],
  792. [$model_match.'.match_time','>',date("H:i:s", time())],
  793. [$model_match.'.type', '=', '3'],
  794. [$model_match.'.utime','>',date("Y-m-d").' 00:00:00']
  795. */
  796. ];
  797. break;
  798. case 'StChampion'://冠军
  799. $where = [
  800. 'type'=>1
  801. ];
  802. break;
  803. default:
  804. throw new \Exception(Render([], '10002', lang('Tips','Sports')->get('PARAM_ERROR')));
  805. }
  806. }
  807. return $where;
  808. }
  809. /**
  810. * @param $data
  811. * @return array
  812. * 处理当国家下无联赛数据 删除该数组
  813. */
  814. function handleArr($data){
  815. $hData = [];
  816. foreach ($data as $key =>$v){
  817. if(empty($v['league_count'])){
  818. $v = [];
  819. }
  820. $hData[]=$v;
  821. }
  822. foreach($hData as $k=>$v){
  823. if(empty($v)){
  824. unset($hData[$k]);
  825. }
  826. }
  827. foreach ($hData as $k=>$v){
  828. $v['league_count'] = array_values($v['league_count']);
  829. $hData[$k]=$v;
  830. }
  831. return array_values($hData);
  832. }
  833. /**
  834. * @param $arr
  835. * @param $key
  836. * @return array
  837. * 去除二维数组重复项
  838. */
  839. function array_unset_tt($arr,$key){
  840. //建立一个目标数组
  841. $res = array();
  842. foreach ($arr as $value) {
  843. //查看有没有重复项
  844. if(isset($res[$value[$key]])){
  845. unset($value[$key]); //有:销毁
  846. }else{
  847. $res[$value[$key]] = $value;
  848. }
  849. }
  850. return $res;
  851. }
  852. /**
  853. * 处理冠军盘口 数组结构
  854. */
  855. function array_gj_tt($data,$oddsData){
  856. foreach ($data as $k=>&$v){
  857. foreach ($v['league_count'] as $kk=>&$vv){
  858. foreach ($oddsData as $kkk=>$vvv){
  859. if($vv['lg_id'] == $vvv['lg_id']){
  860. $vv['oddsData'][]=$vvv;
  861. }
  862. }
  863. if($vv['oddsData']){
  864. $vv['oddsData'] = $this->array_unset_tt($vv['oddsData'],'p_code');
  865. $vv['count'] = count($vv['oddsData']);
  866. unset($vv['oddsData']);
  867. }
  868. if(count($vv) != 5){
  869. unset($v['league_count'][$kk]);
  870. }
  871. }
  872. $v['league_count'] = array_values($v['league_count']);
  873. if(empty($v['league_count'])){
  874. unset($data[$k]);
  875. }
  876. }
  877. return array_values($data);
  878. }
  879. /**
  880. * 处理冠军以外 数组结构
  881. */
  882. function array_other_tt($data,$matchData){
  883. foreach ($data as $k=>&$v){
  884. foreach ($v['league_count'] as $kk=>&$vv){
  885. foreach ($matchData as $kkk=>$vvv){
  886. if($vv['lg_id'] == $vvv['lg_id']){
  887. $vv['matchData'][]=$vvv;
  888. }
  889. }
  890. if($vv['matchData']){
  891. $vv['matchData'] = $this->array_unset_tt($vv['matchData'],'match_id');
  892. $vv['count'] = count($vv['matchData']);
  893. unset($vv['matchData']);
  894. }
  895. if(empty($vv['count'])){
  896. unset($v['league_count'][$kk]);
  897. }
  898. }
  899. $v['league_count'] = array_values($v['league_count']);
  900. if(empty($v['league_count'])){
  901. unset($data[$k]);
  902. }
  903. }
  904. return array_values($data);
  905. }
  906. /**
  907. * 时间格式化
  908. * @param string $dateformat 时间格式
  909. * @param int $timestamp 时间戳
  910. * @param int $timeoffset 时区偏差 默认8 北京时间 -4美东时间
  911. * @return string
  912. */
  913. function qgmdate($dateformat = 'Y-m-d H:i:s', $timestamp = '', $timeoffset = 8,$type = '') {
  914. if(empty($timestamp)) {
  915. $timestamp = time();
  916. }
  917. $result = gmdate($dateformat, $timestamp + $timeoffset * 3600);
  918. return $result;
  919. }
  920. /**
  921. * 判断二维数组是否包含一维数组
  922. * @param mixed $arr 查询条件
  923. * @param mixed $arrs 运动类型
  924. * @return string
  925. */
  926. function judgeEqual($arr, $arrs){
  927. foreach ($arrs as $value) {
  928. if (count($value) === count($arr)) {
  929. $a = 0;
  930. foreach ($value as $key => $v) {
  931. $a++;
  932. if ($v != $arr[$key]) {
  933. break;
  934. }
  935. if ($a == count($key)) { // 到最后一个元素都没有出现不相等,就说明这两个数组相等。
  936. return true;
  937. }
  938. }
  939. }
  940. }
  941. return false;
  942. }
  943. // 排列
  944. function arrangement($a, $m) {
  945. $r = array();
  946. $n = count($a);
  947. if ($m <= 0 || $m > $n) {
  948. return $r;
  949. }
  950. for ($i=0; $i<$n; $i++) {
  951. $b = $a;
  952. $t = array_splice($b, $i, 1);
  953. if ($m == 1) {
  954. $r[] = $t;
  955. } else {
  956. $c = $this->arrangement($b, $m-1);
  957. foreach ($c as $v) {
  958. $r[] = array_merge($t, $v);
  959. }
  960. }
  961. }
  962. return $r;
  963. }
  964. // 组合
  965. function combination($a, $m) {
  966. $r = array();
  967. $n = count($a);
  968. if ($m <= 0 || $m > $n) {
  969. return $r;
  970. }
  971. for ($i=0; $i<$n; $i++) {
  972. $t = array($a[$i]);
  973. if ($m == 1) {
  974. $r[] = $t;
  975. } else {
  976. $b = array_slice($a, $i+1);
  977. $c = $this->combination($b, $m-1);
  978. foreach ($c as $v) {
  979. $r[] = array_merge($t, $v);
  980. }
  981. }
  982. }
  983. return $r;
  984. }
  985. // 阶乘
  986. function factorial($n) {
  987. return array_product(range(1, $n));
  988. }
  989. // 排列数
  990. function A1($n, $m) {
  991. return factorial($n)/factorial($n-$m);
  992. }
  993. // 组合数
  994. function C1($n, $m) {
  995. return A1($n, $m)/factorial($m);
  996. }
  997. //处理空赔率赛事
  998. function Handle_Odds_Null($matchData=[],$models=[],$oddsTypeWhere=[]){
  999. //===获取当前赛事是否有赔率,如果没有则去除===
  1000. //获取当前match_id
  1001. $match_ids = [];
  1002. foreach($matchData as $k=>$v){
  1003. $match_ids[] = $v['match_id'];
  1004. }
  1005. //获取下赛事赔率
  1006. $oddsData = lm($models['model_odds'],'Sports')
  1007. ->select('match_id')
  1008. ->whereIn('match_id',$match_ids)
  1009. ->where($oddsTypeWhere)
  1010. ->distinct('match_id')
  1011. ->get()
  1012. ->toArray();
  1013. //如果赔率为空,则返回空
  1014. if(empty($oddsData)) return $oddsData;
  1015. $matchData_new = [];
  1016. foreach($matchData as $k=>$v){
  1017. foreach($oddsData as $kk=>$vv){
  1018. if($v['match_id'] == $vv['match_id']){
  1019. $matchData_new[] = $matchData[$k];
  1020. }
  1021. }
  1022. }
  1023. return $matchData_new;
  1024. //===赛事空赔率 处理end ===
  1025. }
  1026. //处理空赔率联赛
  1027. function Handle_Odds_Null_lg($matchData=[],$models=[]){
  1028. //===获取当前联赛是否有赔率,如果没有则去除===
  1029. //获取当前lg_id
  1030. $lg_ids = [];
  1031. foreach($matchData as $k=>$v){
  1032. $lg_ids[] = $v['lg_id'];
  1033. }
  1034. //获取下赛事赔率
  1035. $oddsData = lm($models['model_odds'],'Sports')
  1036. ->select('lg_id')
  1037. ->whereIn('lg_id',$lg_ids)
  1038. ->where('type',1)
  1039. ->distinct('lg_id')
  1040. ->get()
  1041. ->toArray();
  1042. //如果赔率为空,则返回空
  1043. if(empty($oddsData)) return $oddsData;
  1044. $matchData_new = [];
  1045. foreach($matchData as $k=>$v){
  1046. foreach($oddsData as $kk=>$vv){
  1047. if($v['lg_id'] == $vv['lg_id']){
  1048. $matchData_new[] = $matchData[$k];
  1049. }
  1050. }
  1051. }
  1052. return $matchData_new;
  1053. //===联赛空赔率 处理end ===
  1054. }
  1055. /**
  1056. * 处理各球类投注: 可赢金额计算
  1057. * $game_code 球类代码
  1058. * $p_code 父级玩法代码
  1059. * $odds 赔率
  1060. * $bet_amount 投注金额
  1061. * $type 投注类型 1单式
  1062. */
  1063. function getEarnMoney($game_code='',$p_code='',$odds=0,$bet_amount=0,$type=0){
  1064. //单式投注
  1065. if($type == 1){
  1066. //足球 可赢金额 计算规则
  1067. if($game_code == 'zq'){
  1068. //球队进球数:大/小;进球:大/小;让球;
  1069. if($p_code == 'tema_ball' || $p_code == 'goal_size' || $p_code == 'concede'){
  1070. //可赢金额 = 赔率*投注金额
  1071. $prize_money = $odds*$bet_amount;
  1072. }else{
  1073. //可赢金额 = (赔率-1)*投注金额
  1074. $prize_money = ($odds-1)*$bet_amount;
  1075. }
  1076. }
  1077. //篮球 可赢金额 计算规则
  1078. if($game_code == 'lq'){
  1079. //可赢金额 = 赔率*投注金额
  1080. $prize_money = $odds*$bet_amount;
  1081. }
  1082. //网球 可赢金额 计算规则
  1083. if($game_code == 'wq'){
  1084. //可赢金额 = 赔率*投注金额
  1085. $prize_money = $odds*$bet_amount;
  1086. }
  1087. //棒球 可赢金额 计算规则
  1088. if($game_code == 'bq'){
  1089. //可赢金额 = 赔率*投注金额
  1090. $prize_money = $odds*$bet_amount;
  1091. }
  1092. }
  1093. return $prize_money;
  1094. }
  1095. }
  1096. ?>