설명 없음
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

common.php 50KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407
  1. <?php
  2. /**
  3. * 易优CMS
  4. * ============================================================================
  5. * 版权所有 2016-2028 海南赞赞网络科技有限公司,并保留所有权利。
  6. * 网站地址: http://www.eyoucms.com
  7. * ----------------------------------------------------------------------------
  8. * 如果商业用途务必到官方购买正版授权, 以免引起不必要的法律纠纷.
  9. * ============================================================================
  10. * Author: 小虎哥 <1105415366@qq.com>
  11. * Date: 2018-4-3
  12. */
  13. if (!function_exists('security_verify_func'))
  14. {
  15. /**
  16. * 当前功能是否需要密保问题验证
  17. * @param
  18. * @return bool
  19. */
  20. function security_verify_func($ctl_act = '')
  21. {
  22. if (empty($ctl_act)) {
  23. $ctl = request()->controller();
  24. $act = request()->action();
  25. $ctl_all = $ctl.'@*';
  26. $ctl_act = $ctl.'@'.$act;
  27. } else {
  28. $ctl_all = preg_replace('/\@([\w\-]+)$/i', '@*', $ctl_act);
  29. }
  30. $security = tpSetting('security');
  31. $security_verifyfunc = !empty($security['security_verifyfunc']) ? json_decode($security['security_verifyfunc'], true) : ['Filemanager@*','Arctype@ajax_newtpl','Archives@ajax_newtpl'];
  32. if (in_array($ctl_act, ['Filemanager@*','Arctype@ajax_newtpl','Archives@ajax_newtpl'])) {
  33. return true;
  34. } else {
  35. if (!empty($security['security_ask_open'])) {
  36. if (in_array($ctl_all, $security_verifyfunc) || in_array($ctl_act, $security_verifyfunc)) {
  37. return true;
  38. }
  39. }
  40. }
  41. return false;
  42. }
  43. }
  44. if (!function_exists('security_answer_verify'))
  45. {
  46. /**
  47. * 是否验证了密保答案
  48. */
  49. function security_answer_verify()
  50. {
  51. $security = tpSetting('security');
  52. if (!empty($security['security_ask_open'])) {
  53. $admin_id = session('?admin_id') ? (int)session('admin_id') : 0;
  54. $admin_info = \think\Db::name('admin')->field('admin_id,last_ip')->where(['admin_id'=>$admin_id])->find();
  55. // 当前管理员二次安全验证过的IP地址
  56. $security_answerverify_ip = !empty($security['security_answerverify_ip']) ? $security['security_answerverify_ip'] : '-1';
  57. // 同IP不验证
  58. if (empty($admin_info) || $admin_info['last_ip'] != $security_answerverify_ip) {
  59. return false;
  60. }
  61. }
  62. return true;
  63. }
  64. }
  65. if (!function_exists('del_html_dirpath')){
  66. /*
  67. * 删除静态页面
  68. */
  69. function del_html_dirpath(){
  70. $error = false;
  71. $dirArr = [];
  72. $seo_html_listname = tpCache('global.seo_html_listname');
  73. $row = \think\Db::name('arctype')->field('dirpath,diy_dirpath')->select();
  74. foreach ($row as $key => $val) {
  75. $dirpathArr = explode('/', $val['dirpath']);
  76. if (3 == $seo_html_listname) {
  77. $dir = end($dirpathArr);
  78. } else if (4 == $seo_html_listname) {
  79. $dirpathArr = explode('/', $val['diy_dirpath']);
  80. $dir = end($dirpathArr);
  81. } else {
  82. $dir = !empty($dirpathArr[1]) ? $dirpathArr[1] : '';
  83. }
  84. $filepath = "./{$dir}";
  85. if (!empty($dir) && !in_array($dir, $dirArr) && file_exists($filepath)) {
  86. @unlink($filepath."/index.html");
  87. $bool = delFile($filepath, true);
  88. if (false !== $bool) {
  89. array_push($dirArr, $dir);
  90. } else {
  91. $error = true;
  92. }
  93. }
  94. }
  95. $data = [];
  96. $data['msg'] = '';
  97. if ($error) {
  98. $num = 0;
  99. $wwwroot = glob('*', GLOB_ONLYDIR);
  100. foreach ($wwwroot as $key => $val) {
  101. if (in_array($val, $dirArr)) {
  102. if (0 == $num) {
  103. $data['msg'] .= "<font color='red'>部分目录删除失败,请手工删除:</font><br/>";
  104. }
  105. $data['msg'] .= ($num+1)."、{$val}<br/>";
  106. $num++;
  107. }
  108. }
  109. $data['height'] = $num * 24;
  110. }
  111. return $data;
  112. }
  113. }
  114. if (!function_exists('is_adminlogin'))
  115. {
  116. /**
  117. * 检验登陆
  118. * @param
  119. * @return bool
  120. */
  121. function is_adminlogin(){
  122. $admin_id = session('admin_id');
  123. if(isset($admin_id) && $admin_id > 0){
  124. return $admin_id;
  125. }else{
  126. return false;
  127. }
  128. }
  129. }
  130. if (!function_exists('getAdminInfo'))
  131. {
  132. /**
  133. * 获取管理员登录信息
  134. */
  135. function getAdminInfo($admin_id = 0)
  136. {
  137. $admin_info = [];
  138. $admin_id = empty($admin_id) ? session('admin_id') : $admin_id;
  139. if (0 < intval($admin_id)) {
  140. $admin_info = \think\Db::name('admin')
  141. ->field('a.*, b.name AS role_name')
  142. ->alias('a')
  143. ->join('__AUTH_ROLE__ b', 'b.id = a.role_id', 'LEFT')
  144. ->where("a.admin_id", $admin_id)
  145. ->find();
  146. if (!empty($admin_info)) {
  147. // 头像
  148. empty($admin_info['head_pic']) && $admin_info['head_pic'] = get_head_pic($admin_info['head_pic'], true);
  149. // 权限组
  150. $admin_info['role_id'] = !empty($admin_info['role_id']) ? $admin_info['role_id'] : -1;
  151. // 是否创始人
  152. $is_founder = 0;
  153. if (-1 == $admin_info['role_id']) {
  154. if (!empty($admin_info['parent_id'])) {
  155. $role_name = '超级管理员';
  156. } else {
  157. $is_founder = 1;
  158. $role_name = '创始人';
  159. }
  160. } else {
  161. $role_name = $admin_info['role_name'];
  162. }
  163. $admin_info['role_name'] = $role_name;
  164. $admin_info['is_founder'] = $is_founder;
  165. }
  166. }
  167. return $admin_info;
  168. }
  169. }
  170. if (!function_exists('get_conf'))
  171. {
  172. /**
  173. * 获取conf配置文件
  174. */
  175. function get_conf($name = 'global')
  176. {
  177. $arr = include APP_PATH.MODULE_NAME.'/conf/'.$name.'.php';
  178. return $arr;
  179. }
  180. }
  181. if (!function_exists('get_auth_rule'))
  182. {
  183. /**
  184. * 获取权限列表文件
  185. */
  186. function get_auth_rule($where = [])
  187. {
  188. $auth_rule = include APP_PATH.MODULE_NAME.'/conf/auth_rule.php';
  189. // 排序号排序
  190. // $sort_order_arr = array();
  191. // foreach($auth_rule as $key => $val){
  192. // $sort_order_arr[]['sort_order'] = $val['sort_order'];
  193. // }
  194. // array_multisort($sort_order_arr,SORT_ASC,$auth_rule);
  195. if (!empty($where)) {
  196. foreach ($auth_rule as $k1 => $rules) {
  197. foreach ($where as $k2 => $v2) {
  198. if ($rules[$k2] != $v2) {
  199. unset($auth_rule[$k1]);
  200. }
  201. }
  202. }
  203. }
  204. return $auth_rule;
  205. }
  206. }
  207. if (!function_exists('is_check_access'))
  208. {
  209. /**
  210. * 检测是否有该权限
  211. */
  212. function is_check_access($str = 'Index@index') {
  213. $bool_flag = 1;
  214. $role_id = session('admin_info.role_id');
  215. if (0 < intval($role_id)) {
  216. $ctl_act = strtolower($str);
  217. $arr = explode('@', $ctl_act);
  218. $ctl = !empty($arr[0]) ? $arr[0] : '';
  219. $act = !empty($arr[1]) ? $arr[1] : '';
  220. $ctl_all = $ctl.'@*';
  221. $auth_role_info = session('admin_info.auth_role_info');
  222. $permission = $auth_role_info['permission'];
  223. $permission_rules = !empty($permission['rules']) ? $permission['rules'] : [];
  224. $auth_rule = get_auth_rule();
  225. $all_auths = []; // 系统全部权限对应的菜单ID
  226. $admin_auths = []; // 用户当前拥有权限对应的菜单ID
  227. $diff_auths = []; // 用户没有被授权的权限对应的菜单ID
  228. foreach($auth_rule as $key => $val){
  229. $all_auths = array_merge($all_auths, explode(',', strtolower($val['auths'])));
  230. if (in_array($val['id'], $permission_rules)) {
  231. $admin_auths = array_merge($admin_auths, explode(',', strtolower($val['auths'])));
  232. }
  233. }
  234. $all_auths = array_unique($all_auths);
  235. $admin_auths = array_unique($admin_auths);
  236. $diff_auths = array_diff($all_auths, $admin_auths);
  237. if (in_array('archives@index_draft', $diff_auths) && !in_array('archives@*', $diff_auths)) {
  238. $index_key = array_search('archives@index_draft', $diff_auths);
  239. if (isset($diff_auths[$index_key])) {
  240. unset($diff_auths[$index_key]);
  241. }
  242. }
  243. if (in_array($ctl_act, $diff_auths) || in_array($ctl_all, $diff_auths)) {
  244. $bool_flag = false;
  245. }else if($ctl_act == 'order@index' && (in_array('member@money_index', $diff_auths) || in_array('member@*', $diff_auths)) && (in_array('shop@index', $diff_auths) || in_array('shop@*', $diff_auths))){ //Member@money_index 会员订单入口; Shop@index 商城中心订单都没有权限的清空下,关闭订单管理
  246. $bool_flag = false;
  247. }
  248. }
  249. return $bool_flag;
  250. }
  251. }
  252. if (!function_exists('getAdminMenuList')){
  253. /**
  254. * 根据角色权限过滤菜单
  255. * $menu_list 所有菜单
  256. */
  257. function getAdminMenuList($menuArr){
  258. $role_id = session('admin_info.role_id');
  259. if (0 < intval($role_id)) {
  260. $auth_role_info = session('admin_info.auth_role_info');
  261. $permission = $auth_role_info['permission'];
  262. $permission_rules = !empty($permission['rules']) ? $permission['rules'] : [];
  263. $permission_plugins = !empty($permission['plugins']) ? $permission['plugins'] : [];
  264. if (!empty($permission_plugins)){
  265. $permission_plugins = get_arr_column($permission_plugins,"code");
  266. }
  267. $web_weapp_switch = tpCache('global.web_weapp_switch');
  268. $auth_rule = get_auth_rule();
  269. $all_auths = []; // 系统全部权限对应的菜单ID
  270. $admin_auths = []; // 用户当前拥有权限对应的菜单ID
  271. $diff_auths = []; // 用户没有被授权的权限对应的菜单ID
  272. foreach($auth_rule as $key => $val){
  273. $all_auths = array_merge($all_auths, explode(',', strtolower($val['auths'])));
  274. if (in_array($val['id'], $permission_rules)) {
  275. $admin_auths = array_merge($admin_auths, explode(',', strtolower($val['auths'])));
  276. }
  277. }
  278. $all_auths = array_unique($all_auths);
  279. $admin_auths = array_unique($admin_auths);
  280. $diff_auths = array_diff($all_auths, $admin_auths);
  281. if (in_array('archives@index_draft', $diff_auths) && !in_array('archives@*', $diff_auths)) {
  282. $index_key = array_search('archives@index_draft', $diff_auths);
  283. if (isset($diff_auths[$index_key])) {
  284. unset($diff_auths[$index_key]);
  285. }
  286. }
  287. //过滤该用户不包含的权限
  288. foreach($menuArr as $k=>$val){
  289. $ctl = strtolower($val['controller_name']);
  290. $act = strtolower($val['action_name']);
  291. $ctl_act = $ctl.'@'.$act;
  292. $ctl_all = $ctl.'@*';
  293. if (in_array($ctl_act, $diff_auths) || in_array($ctl_all, $diff_auths)) {
  294. unset($menuArr[$k]);//过滤菜单
  295. }else if($val['menu_id'] == '2004021' && !is_check_access("Member@money_index") && !is_check_access("Member@money_index")){ //Member*money_index 会员订单入口; Shop*index 商城中心订单
  296. unset($menuArr[$k]);//Member*money_index 会员订单入口; Shop*index 商城中心订单都没有权限的清空下,关闭订单管理
  297. } else if ($val['menu_id'] == '2004') {
  298. if ($auth_role_info['switch_map'] <= 0) {
  299. unset($menuArr[$k]); // 功能地图入口
  300. }
  301. }
  302. //过滤没有权限的插件
  303. if ($ctl == 'weapp' && $act == 'execute'){
  304. if (1 != $web_weapp_switch || empty($permission_plugins)){
  305. unset($menuArr[$k]);//过滤菜单
  306. }else{
  307. $param_str = get_str_between($val['param'], "sm|", "|sc");
  308. if (!in_array($param_str,$permission_plugins)){
  309. unset($menuArr[$k]);//过滤菜单
  310. }
  311. }
  312. }
  313. }
  314. }
  315. return $menuArr;
  316. }
  317. }
  318. if (!function_exists('get_str_between')){
  319. function get_str_between($input, $start, $end) {
  320. $substr = substr($input, strlen($start)+strpos($input, $start),(strlen($input) - strpos($input, $end))*(-1));
  321. return $substr;
  322. }
  323. }
  324. if (!function_exists('getMenuList'))
  325. {
  326. /**
  327. * 根据角色权限过滤菜单
  328. */
  329. function getMenuList() {
  330. $menuArr = getAllMenu();
  331. // return $menuArr;
  332. $role_id = session('admin_info.role_id');
  333. if (0 < intval($role_id)) {
  334. $auth_role_info = session('admin_info.auth_role_info');
  335. $permission = $auth_role_info['permission'];
  336. $permission_rules = !empty($permission['rules']) ? $permission['rules'] : [];
  337. $auth_rule = get_auth_rule();
  338. $all_auths = []; // 系统全部权限对应的菜单ID
  339. $admin_auths = []; // 用户当前拥有权限对应的菜单ID
  340. $diff_auths = []; // 用户没有被授权的权限对应的菜单ID
  341. foreach($auth_rule as $key => $val){
  342. $all_auths = array_merge($all_auths, explode(',', $val['menu_id']), explode(',', $val['menu_id2']));
  343. if (in_array($val['id'], $permission_rules)) {
  344. $admin_auths = array_merge($admin_auths, explode(',', $val['menu_id']), explode(',', $val['menu_id2']));
  345. }
  346. }
  347. $all_auths = array_unique($all_auths);
  348. $admin_auths = array_unique($admin_auths);
  349. $diff_auths = array_diff($all_auths, $admin_auths);
  350. /*过滤三级数组菜单*/
  351. foreach($menuArr as $k=>$val){
  352. foreach ($val['child'] as $j=>$v){
  353. foreach ($v['child'] as $s=>$son){
  354. if (in_array($son['id'], $diff_auths)) {
  355. unset($menuArr[$k]['child'][$j]['child'][$s]);//过滤菜单
  356. }
  357. }
  358. }
  359. }
  360. /*--end*/
  361. /*过滤二级数组菜单*/
  362. foreach ($menuArr as $mk=>$mr){
  363. foreach ($mr['child'] as $nk=>$nrr){
  364. if (in_array($nrr['id'], $diff_auths)) {
  365. unset($menuArr[$mk]['child'][$nk]);//过滤菜单
  366. }
  367. }
  368. }
  369. /*--end*/
  370. }
  371. return $menuArr;
  372. }
  373. }
  374. if (!function_exists('getAllMenu'))
  375. {
  376. /**
  377. * 获取左侧菜单
  378. */
  379. function getAllMenu() {
  380. $menuArr = false;//extra_cache('admin_all_menu');
  381. if (!$menuArr) {
  382. $menuArr = get_conf('menu');
  383. extra_cache('admin_all_menu', $menuArr);
  384. }
  385. return $menuArr;
  386. }
  387. }
  388. if ( ! function_exists('getChanneltypeList'))
  389. {
  390. /**
  391. * 获取全部的模型
  392. */
  393. function getChanneltypeList()
  394. {
  395. $result = extra_cache('admin_channeltype_list_logic');
  396. if ($result == false)
  397. {
  398. $result = model('Channeltype')->getAll('*', array(), 'id');
  399. extra_cache('admin_channeltype_list_logic', $result);
  400. }
  401. return $result;
  402. }
  403. }
  404. if (!function_exists('tpversion'))
  405. {
  406. function tpversion($timeout = 5)
  407. {
  408. if(!empty($_SESSION['isset_push']))
  409. return false;
  410. $_SESSION['isset_push'] = 1;
  411. error_reporting(0);//关闭所有错误报告
  412. $install_time = DEFAULT_INSTALL_DATE;
  413. $serial_number = DEFAULT_SERIALNUMBER;
  414. $constsant_path = APP_PATH.'admin/conf/constant.php';
  415. if (file_exists($constsant_path)) {
  416. require_once($constsant_path);
  417. defined('INSTALL_DATE') && $install_time = INSTALL_DATE;
  418. defined('SERIALNUMBER') && $serial_number = SERIALNUMBER;
  419. }
  420. $curent_version = getCmsVersion();
  421. $mysqlinfo = \think\Db::query("SELECT VERSION() as version");
  422. $mysql_version = $mysqlinfo[0]['version'];
  423. $global_config = tpCache('global');
  424. $users_config = getUsersConfigData('all');
  425. $values = array(
  426. 'domain'=>request()->host(),
  427. 'key_num'=>$curent_version,
  428. 'install_time'=>$install_time,
  429. 'serial_number'=>$serial_number,
  430. 'ip' => serverIP(),
  431. 'agentcode' => !empty($global_config['php_agentcode']) ? $global_config['php_agentcode'] : 0,
  432. 'global_config' => base64_encode(json_encode($global_config)),
  433. 'users_config' => base64_encode(json_encode($users_config)),
  434. 'phpv' => urlencode(phpversion()),
  435. 'mysql_version' => urlencode($mysql_version),
  436. 'web_server' => urlencode($_SERVER['SERVER_SOFTWARE']),
  437. 'web_title' => tpCache('global.web_title'),
  438. );
  439. // api_Service_user_push
  440. $upgradeLogic = new \app\admin\logic\UpgradeLogic;
  441. $upgradeLogic->GetKeyData($values);
  442. $url = $upgradeLogic->getServiceUrl().'/index.php?m=api&c=Service&a=user_push';
  443. @httpRequest($url, 'POST', $values, [], $timeout);
  444. }
  445. }
  446. if (!function_exists('push_zzbaidu'))
  447. {
  448. /**
  449. * 将新链接推送给百度蜘蛛
  450. */
  451. function push_zzbaidu($type = 'urls', $aid = '', $typeid = '')
  452. {
  453. // 获取token的值:http://ziyuan.baidu.com/linksubmit/index?site=http://www.eyoucms.com/
  454. $aid = intval($aid);
  455. $typeid = intval($typeid);
  456. $sitemap_zzbaidutoken = tpCache('global.sitemap_zzbaidutoken');
  457. if (empty($sitemap_zzbaidutoken) || (empty($aid) && empty($typeid)) || !function_exists('curl_init')) {
  458. return '';
  459. }
  460. $urlsArr = array();
  461. $channeltype_list = model('Channeltype')->getAll('id, ctl_name', array(), 'id');
  462. if ($aid > 0) {
  463. $res = M('archives')->field('b.*, a.*, a.aid, b.id as typeid')
  464. ->alias('a')
  465. ->join('__ARCTYPE__ b', 'b.id = a.typeid', 'LEFT')
  466. ->find($aid);
  467. $arcurl = get_arcurl($res, false);
  468. array_push($urlsArr, $arcurl);
  469. }
  470. if (0 < $typeid) {
  471. $res = M('arctype')->field('a.*')
  472. ->alias('a')
  473. ->find($typeid);
  474. $typeurl = get_typeurl($res, false);
  475. array_push($urlsArr, $typeurl);
  476. }
  477. $type = ('edit' == $type) ? 'update' : 'urls';
  478. $api = 'http://data.zz.baidu.com/'.$type.'?site='.request()->host(true).'&token='.$sitemap_zzbaidutoken;
  479. $ch = curl_init();
  480. $options = array(
  481. CURLOPT_URL => $api,
  482. CURLOPT_POST => true,
  483. CURLOPT_RETURNTRANSFER => true,
  484. CURLOPT_POSTFIELDS => implode("\n", $urlsArr),
  485. CURLOPT_HTTPHEADER => array('Content-Type: text/plain'),
  486. );
  487. curl_setopt_array($ch, $options);
  488. $result = curl_exec($ch);
  489. return $result;
  490. }
  491. }
  492. if (!function_exists('get_homeurl'))
  493. {
  494. /**
  495. * 获取前台链接
  496. *
  497. * @param array $tagid 标签ID
  498. */
  499. function get_homeurl($mca = '', $vars = [])
  500. {
  501. static $seo_pseudo = null;
  502. static $seo_dynamic_format = null;
  503. if (null === $seo_pseudo || null === $seo_dynamic_format) {
  504. $globalConfig = tpCache('global');
  505. $seo_pseudo = !empty($globalConfig['seo_pseudo']) ? $globalConfig['seo_pseudo'] : config('ey_config.seo_pseudo');
  506. $seo_dynamic_format = !empty($globalConfig['seo_dynamic_format']) ? $globalConfig['seo_dynamic_format'] : config('ey_config.seo_dynamic_format');
  507. }
  508. $url = url($mca, $vars, true, true, $seo_pseudo, $seo_dynamic_format);
  509. // 自动隐藏index.php入口文件
  510. $url = auto_hide_index($url);
  511. return $url;
  512. }
  513. }
  514. if (!function_exists('get_total_arc'))
  515. {
  516. /**
  517. * 获取指定栏目的文档数
  518. */
  519. function get_total_arc($typeid)
  520. {
  521. static $arctypeList = null;
  522. static $archivesNums = null;
  523. static $guestbookNums = null;
  524. static $allow_release_channel = [];
  525. if (null === $arctypeList) {
  526. $allow_release_channel = config('global.allow_release_channel');
  527. $arctypeList = \think\Db::name('arctype')->field('id, parent_id, current_channel')->where([
  528. 'lang' => get_admin_lang(),
  529. 'is_del' => 0,
  530. 'weapp_code' => ['EQ', ''],
  531. ])->getAllWithIndex('id');
  532. /*-----------------文档列表模型统计数 start--------------*/
  533. $map = [
  534. 'channel' => ['IN', $allow_release_channel],
  535. 'lang' => get_admin_lang(),
  536. 'is_del' => 0, // 回收站功能
  537. ];
  538. $mapNew = "(users_id = 0 OR (users_id > 0 AND arcrank >= 0))";
  539. /*权限控制 by 小虎哥*/
  540. $admin_info = session('admin_info');
  541. if (0 < intval($admin_info['role_id'])) {
  542. $auth_role_info = $admin_info['auth_role_info'];
  543. if(! empty($auth_role_info)){
  544. if(isset($auth_role_info['only_oneself']) && 1 == $auth_role_info['only_oneself']){
  545. $map['admin_id'] = $admin_info['admin_id'];
  546. }
  547. }
  548. }
  549. /*--end*/
  550. $SqlQuery = \think\Db::name('archives')->field('typeid, count(typeid) as num')->where($map)->where($mapNew)->group('typeid')->select(false);
  551. $SqlResult = \think\Db::name('sql_cache_table')->where(['sql_md5'=>md5($SqlQuery)])->getField('sql_result');
  552. if (!empty($SqlResult)) {
  553. $archivesNums = json_decode($SqlResult, true);
  554. } else {
  555. $archivesNums = \think\Db::name('archives')->field('typeid, count(typeid) as num')->where($map)->where($mapNew)->group('typeid')->getAllWithIndex('typeid');
  556. /*添加查询执行语句到mysql缓存表*/
  557. $SqlCacheTable = [
  558. 'sql_name' => '|arctype|all|count|',
  559. 'sql_result' => json_encode($archivesNums),
  560. 'sql_md5' => md5($SqlQuery),
  561. 'sql_query' => $SqlQuery,
  562. 'add_time' => getTime(),
  563. 'update_time' => getTime(),
  564. ];
  565. \think\Db::name('sql_cache_table')->insertGetId($SqlCacheTable);
  566. /*END*/
  567. }
  568. /*-----------------文档列表模型统计数 end--------------*/
  569. /*-----------------留言模型 start--------------*/
  570. $guestbookNums = \think\Db::name('guestbook')->field('typeid, count(typeid) as num')->where([
  571. 'lang' => get_admin_lang(),
  572. ])->group('typeid')->getAllWithIndex('typeid');
  573. /*-----------------留言模型 end--------------*/
  574. }
  575. $totalnum = 0;
  576. if (!empty($arctypeList[$typeid])) {
  577. $current_channel = $arctypeList[$typeid]['current_channel'];
  578. if (in_array($current_channel, $allow_release_channel)) { // 能发布文档的模型
  579. static $arctypeAllSub = null;
  580. null === $arctypeAllSub && $arctypeAllSub = arctypeAllSub();
  581. $typeidArr = $arctypeAllSub[$typeid];
  582. foreach($typeidArr as $tid)
  583. {
  584. $totalnum += (!empty($archivesNums[$tid]['num']) ? $archivesNums[$tid]['num'] : 0);
  585. }
  586. } elseif ($current_channel == 8) { // 留言模型
  587. $totalnum = !empty($guestbookNums[$typeid]['num']) ? $guestbookNums[$typeid]['num'] : 0;
  588. }
  589. }
  590. return $totalnum;
  591. }
  592. }
  593. if (!function_exists('replace_path'))
  594. {
  595. /**
  596. * 将路径斜杆、反斜杠替换为冒号符,适用于IIS服务器在URL上的双重转义限制
  597. * @param string $filepath 相对路径
  598. * @param string $replacement 目标字符
  599. * @param boolean $is_back false为替换,true为还原
  600. */
  601. function replace_path($filepath = '', $replacement = ':', $is_back = false)
  602. {
  603. if (false == $is_back) {
  604. $filepath = str_replace(DIRECTORY_SEPARATOR, $replacement, $filepath);
  605. $filepath = preg_replace('#\/#', $replacement, $filepath);
  606. } else {
  607. $filepath = preg_replace('#'.$replacement.'#', '/', $filepath);
  608. $filepath = str_replace('//', ':/', $filepath);
  609. }
  610. return $filepath;
  611. }
  612. }
  613. if (!function_exists('get_seo_pseudo_list'))
  614. {
  615. /**
  616. * URL模式下拉列表
  617. */
  618. function get_seo_pseudo_list($key = '')
  619. {
  620. $data = array(
  621. 1 => '动态URL',
  622. 3 => '伪静态化',
  623. 2 => '静态页面',
  624. );
  625. return isset($data[$key]) ? $data[$key] : $data;
  626. }
  627. }
  628. if (!function_exists('get_chown_pathinfo'))
  629. {
  630. /**
  631. * 对指定的操作系统获取目录的所有组与所有者
  632. * @param string $path 目录路径
  633. * @return array
  634. */
  635. function get_chown_pathinfo($path = '')
  636. {
  637. $pathinfo = true;
  638. if (function_exists('stat')) {
  639. /*指定操作系统,在列表内才进行后续获取*/
  640. $isValidate = false;
  641. $os = PHP_OS;
  642. $osList = array('linux','unix');
  643. foreach ($osList as $key => $val) {
  644. if (stristr($os, $val)) {
  645. $isValidate = true;
  646. continue;
  647. }
  648. }
  649. /*--end*/
  650. if (true === $isValidate) {
  651. $path = !empty($path) ? $path : ROOT_PATH;
  652. $stat = stat($path);
  653. if (function_exists('posix_getpwuid')) {
  654. $pathinfo = posix_getpwuid($stat['uid']);
  655. } else {
  656. $pathinfo = array(
  657. 'name' => (0 == $stat['uid']) ? 'root' : '',
  658. 'uid' => $stat['uid'],
  659. 'gid' => $stat['gid'],
  660. );
  661. }
  662. }
  663. }
  664. return $pathinfo;
  665. }
  666. }
  667. if (!function_exists('menu_select'))
  668. {
  669. /*组装成层级下拉列表框*/
  670. function menu_select($selected = 0)
  671. {
  672. $select_html = '';
  673. $menuArr = getAllMenu();
  674. if (!empty($menuArr)) {
  675. foreach ($menuArr AS $key => $val)
  676. {
  677. $select_html .= '<option value="' . $val['id'] . '" data-grade="' . $val['grade'] . '"';
  678. $select_html .= ($selected == $val['id']) ? ' selected="ture"' : '';
  679. if (!empty($val['child'])) {
  680. $select_html .= ' disabled="true" style="background-color:#f5f5f5;"';
  681. }
  682. $select_html .= '>';
  683. if ($val['grade'] > 0)
  684. {
  685. $select_html .= str_repeat('&nbsp;', $val['grade'] * 4);
  686. }
  687. $name = !empty($val['name']) ? $val['name'] : '默认';
  688. $select_html .= htmlspecialchars_decode(addslashes($name)) . '</option>';
  689. if (empty($val['child'])) {
  690. continue;
  691. }
  692. foreach ($menuArr[$key]['child'] as $key2 => $val2) {
  693. $select_html .= '<option value="' . $val2['id'] . '" data-grade="' . $val2['grade'] . '"';
  694. $select_html .= ($selected == $val2['id']) ? ' selected="ture"' : '';
  695. if (!empty($val2['child'])) {
  696. $select_html .= ' disabled="true" style="background-color:#f5f5f5;"';
  697. }
  698. $select_html .= '>';
  699. if ($val2['grade'] > 0)
  700. {
  701. $select_html .= str_repeat('&nbsp;', $val2['grade'] * 4);
  702. }
  703. $select_html .= htmlspecialchars_decode(addslashes($val2['name'])) . '</option>';
  704. if (empty($val2['child'])) {
  705. continue;
  706. }
  707. foreach ($menuArr[$key]['child'][$key2]['child'] as $key3 => $val3) {
  708. $select_html .= '<option value="' . $val3['id'] . '" data-grade="' . $val3['grade'] . '"';
  709. $select_html .= ($selected == $val3['id']) ? ' selected="ture"' : '';
  710. if (!empty($val3['child'])) {
  711. $select_html .= ' disabled="true" style="background-color:#f5f5f5;"';
  712. }
  713. $select_html .= '>';
  714. if ($val3['grade'] > 0)
  715. {
  716. $select_html .= str_repeat('&nbsp;', $val3['grade'] * 4);
  717. }
  718. $select_html .= htmlspecialchars_decode(addslashes($val3['name'])) . '</option>';
  719. }
  720. }
  721. }
  722. }
  723. return $select_html;
  724. }
  725. }
  726. if (!function_exists('schemaTable'))
  727. {
  728. /**
  729. * 重新生成单个数据表缓存字段文件
  730. */
  731. function schemaTable($name)
  732. {
  733. $table = $name;
  734. $prefix = \think\Config::get('database.prefix');
  735. if (!preg_match('/^'.$prefix.'/i', $name)) {
  736. $table = $prefix.$name;
  737. }
  738. /*调用命令行的指令*/
  739. \think\Console::call('optimize:schema', ['--table', $table]);
  740. /*--end*/
  741. }
  742. }
  743. if (!function_exists('schemaAllTable'))
  744. {
  745. /**
  746. * 重新生成全部数据表缓存字段文件
  747. */
  748. function schemaAllTable()
  749. {
  750. $dbtables = \think\Db::query('SHOW TABLE STATUS');
  751. $tableList = [];
  752. foreach ($dbtables as $k => $v) {
  753. if (preg_match('/^'.PREFIX.'/i', $v['Name'])) {
  754. /*调用命令行的指令*/
  755. \think\Console::call('optimize:schema', ['--table', $v['Name']]);
  756. /*--end*/
  757. }
  758. }
  759. }
  760. }
  761. if (!function_exists('testWriteAble'))
  762. {
  763. /**
  764. * 测试目录路径是否有写入权限
  765. * @param string $d 目录路劲
  766. * @return boolean
  767. */
  768. function testWriteAble($filepath)
  769. {
  770. $tfile = '_eyout.txt';
  771. $fp = @fopen($filepath.$tfile,'w');
  772. if(!$fp) {
  773. return false;
  774. }
  775. else {
  776. fclose($fp);
  777. $rs = @unlink($filepath.$tfile);
  778. return true;
  779. }
  780. }
  781. }
  782. if (!function_exists('getArchivesSortUrl'))
  783. {
  784. /**
  785. * 在文档列表拼接排序URL
  786. * @param string $orderby 排序字段
  787. * @param string $orderwayDefault 默认为空时升序
  788. * @return string
  789. */
  790. function getArchivesSortUrl($orderby = '', $orderwayDefault = '')
  791. {
  792. $parseArr = parse_url(request()->url());
  793. $query_str = '';
  794. if (!empty($parseArr['query'])) {
  795. parse_str($parseArr['query'], $output);
  796. $output['orderby'] = $orderby;
  797. $orderway = input('param.orderway/s', $orderwayDefault);
  798. $orderway = !empty($orderway) ? $orderway : 'desc';
  799. if ('desc' == $orderway) {
  800. $orderway = 'asc';
  801. } else {
  802. $orderway = 'desc';
  803. // 再次点击恢复到默认排序
  804. // if ('arcrank' == $orderby) {
  805. // $output['orderby'] = '';
  806. // }
  807. }
  808. $output['orderway'] = $orderway;
  809. $query_str = http_build_query($output);
  810. }
  811. $url = $parseArr['path'];
  812. !empty($query_str) && $url .= '?'.$query_str;
  813. return $url;
  814. }
  815. }
  816. if (!function_exists('showArchivesFlagStr'))
  817. {
  818. /**
  819. * 在文档列表显示文档属性标识
  820. * @param array $archivesInfo 文档信息
  821. * @return string
  822. */
  823. function showArchivesFlagStr($archivesInfo = [])
  824. {
  825. static $flagResult = null;
  826. if (null === $flagResult) {
  827. $flagResult = \think\Db::name('archives_flag')->field('flag_name,flag_fieldname')->getAllWithIndex('flag_fieldname');
  828. }
  829. $arr = [];
  830. $flaglist = ['is_head','is_recom','is_special','is_b','is_jump','is_roll','is_slide','is_diyattr'];
  831. foreach ($flaglist as $key => $fieldname) {
  832. if (!empty($archivesInfo[$fieldname]) && !empty($flagResult[$fieldname]['flag_name'])) {
  833. if (in_array($flagResult[$fieldname]['flag_name'], ['推荐','加推','标粗','有图']) || stristr($flagResult[$fieldname]['flag_name'], '最')) {
  834. $small_name = msubstr($flagResult[$fieldname]['flag_name'], 1, 1);
  835. } else {
  836. $small_name = msubstr($flagResult[$fieldname]['flag_name'], 0, 1);
  837. }
  838. $arr[$fieldname] = [
  839. 'small_name' => $small_name,
  840. ];
  841. }
  842. }
  843. return $arr;
  844. }
  845. }
  846. if (!function_exists('checkPasswordLevel'))
  847. {
  848. /**
  849. * 检查密码复杂度
  850. * @param string $strPassword 密码
  851. * @return string
  852. */
  853. function checkPasswordLevel($strPassword = '')
  854. {
  855. $result = 0;
  856. $pwdlen = strlen($strPassword);
  857. if ( $pwdlen == 0) {
  858. $result += 0;
  859. }
  860. else if ( $pwdlen<8 && $pwdlen >0 ) {
  861. $result += 5;
  862. }
  863. else if ($pwdlen>10) {
  864. $result += 25;
  865. }
  866. else {
  867. $result += 10;
  868. }
  869. //check letter
  870. $bHave = false;
  871. $bAll = false;
  872. $capital = preg_match('/[A-Z]{1}/', $strPassword);//找大写字母
  873. $small = preg_match('/[a-z]{1}/', $strPassword);//找小写字母
  874. if ( empty($capital) && empty($small) )
  875. {
  876. $result += 0; //没有字母
  877. $bHave = false;
  878. }
  879. else if ( !empty($capital) && !empty($small) )
  880. {
  881. $result += 20;
  882. $bAll = true;
  883. }
  884. else
  885. {
  886. $result += 10;
  887. $bAll = true;
  888. }
  889. //检查数字
  890. $bDigi = false;
  891. $digitalLen = 0;
  892. for ( $i=0; $i<$pwdlen; $i++)
  893. {
  894. if ( $strPassword[$i] <= '9' && $strPassword[$i] >= '0' )
  895. {
  896. $bDigi = true;
  897. $digitalLen += 1;
  898. }
  899. }
  900. if ( $digitalLen==0 )//没有数字
  901. {
  902. $result += 0;
  903. $bDigi = false;
  904. }
  905. else if ($digitalLen>2)//2个数字以上
  906. {
  907. $result += 20 ;
  908. $bDigi = true;
  909. }
  910. else
  911. {
  912. $result += 10;
  913. $bDigi = true;
  914. }
  915. //检查非单词字符
  916. $bOther = false;
  917. $otherLen = 0;
  918. for ($i=0; $i<$pwdlen; $i++)
  919. {
  920. if ( ($strPassword[$i]>='0' && $strPassword[$i]<='9') ||
  921. ($strPassword[$i]>='A' && $strPassword[$i]<='Z') ||
  922. ($strPassword[$i]>='a' && $strPassword[$i]<='z')) {
  923. continue;
  924. }
  925. $otherLen += 1;
  926. $bOther = true;
  927. }
  928. if ( $otherLen == 0 )//没有非单词字符
  929. {
  930. $result += 0;
  931. $bOther = false;
  932. }
  933. else if ( $otherLen >1)//1个以上非单词字符
  934. {
  935. $result +=25 ;
  936. $bOther = true;
  937. }
  938. else
  939. {
  940. $result +=10;
  941. $bOther = true;
  942. }
  943. //检查额外奖励
  944. if ( $bAll && $bDigi && $bOther) {
  945. $result += 5;
  946. }
  947. else if ($bHave && $bDigi && $bOther) {
  948. $result += 3;
  949. }
  950. else if ($bHave && $bDigi ) {
  951. $result += 2;
  952. }
  953. $level = 0;
  954. //根据分数来算密码强度的等级
  955. if ( $result >=80 ) {
  956. $level = 7;
  957. }
  958. else if ( $result>=70) {
  959. $level = 6;
  960. }
  961. else if ( $result>=60) {
  962. $level = 5;
  963. }
  964. else if ( $result>=50) {
  965. $level = 4;
  966. }
  967. else if ( $result>=40) {
  968. $level = 3;
  969. }
  970. else if ( $result>20) {
  971. $level = 2;
  972. }
  973. else if ( $result>0) {
  974. $level = 1;
  975. }
  976. else {
  977. $level = 0;
  978. }
  979. return $level;
  980. }
  981. }
  982. if (!function_exists('getPasswordLevelTitle'))
  983. {
  984. /**
  985. * 获取密码复杂度名称
  986. * @param string $level 复杂程度
  987. * @return string
  988. */
  989. function getPasswordLevelTitle($level = 0)
  990. {
  991. $title = '弱';
  992. //根据分数来算密码强度的等级
  993. if ( $level == 7 ) {
  994. $title = '极佳';
  995. }
  996. else if ( $level == 6) {
  997. $title = '非常强';
  998. }
  999. else if ( $level == 5) {
  1000. $title = '强';
  1001. }
  1002. else if ( $level == 4) {
  1003. $title = '较强';
  1004. }
  1005. else if ( $level == 3) {
  1006. $title = '一般';
  1007. }
  1008. else if ( $level == 2) {
  1009. $title = '较弱';
  1010. }
  1011. else if ( $level == 1) {
  1012. $title = '非常弱';
  1013. }
  1014. else {
  1015. $title = '弱';
  1016. }
  1017. return $title;
  1018. }
  1019. }
  1020. if (!function_exists('downloadExcel')) {
  1021. /**
  1022. * 下载excel
  1023. * @param $strTable 表格内容
  1024. * @param $filename 文件名
  1025. */
  1026. function downloadExcel($strTable, $filename)
  1027. {
  1028. ob_end_clean();
  1029. header("Content-type: application/vnd.ms-excel");
  1030. header("Content-Type: application/force-download");
  1031. header("Content-Disposition: attachment; filename=" . $filename . "_" . date('Y-m-d') . ".xls");
  1032. header('Expires:0');
  1033. header('Pragma:public');
  1034. echo '<html><meta http-equiv="Content-Type" content="text/html; charset=utf-8" />' . $strTable . '</html>';
  1035. }
  1036. }
  1037. if (!function_exists('check_single_uiset')) {
  1038. /**
  1039. * 检测指定单页模板是否支持可视化
  1040. */
  1041. function check_single_uiset($templist = '')
  1042. {
  1043. $uisetRow = [];
  1044. $templist = !empty($templist) ? $templist : 'lists_single.htm';
  1045. $file = "./template/".TPL_THEME."pc/{$templist}";
  1046. if (file_exists($file)) {
  1047. $content = @file_get_contents($file);
  1048. if (!empty($content) && preg_match('/eyou\:ui(\s+)open\=(\'|\")(on|off)(\'|\")/i', $content)) {
  1049. $uisetRow['pc'] = true;
  1050. }
  1051. }
  1052. $file = "./template/".TPL_THEME."mobile/{$templist}";
  1053. if (file_exists($file)) {
  1054. $content = @file_get_contents($file);
  1055. if (!empty($content) && preg_match('/eyou\:ui(\s+)open\=(\'|\")(on|off)(\'|\")/i', $content)) {
  1056. $uisetRow['mobile'] = true;
  1057. }
  1058. }
  1059. return $uisetRow;
  1060. }
  1061. }
  1062. if (!function_exists('left_menu_id')) {
  1063. /**
  1064. * 左侧菜单的ID处理
  1065. */
  1066. function left_menu_id($str = '')
  1067. {
  1068. return str_replace('|', '_', $str);
  1069. }
  1070. }
  1071. if (!function_exists('list_to_tree')){
  1072. /*
  1073. * list数组转化为tree数组
  1074. * $list 原二维数组
  1075. * $pk 树型数组键名
  1076. * $pid 属性数组关联键名
  1077. * $child 树型数组下级枝干下标(标识)
  1078. * $root 根pid的值
  1079. * $has_chldren 用于获取下级个数(所有),PS:需要原二维数组$list本来就是依次层级从大到小排序
  1080. * return 根节点pid的值
  1081. */
  1082. function list_to_tree($list, $pk='id', $pid = 'parent_id', $child = 'children', $root = 0 ,$has_chldren = 1) {
  1083. //创建Tree
  1084. $tree = array();
  1085. if (is_array($list)) {
  1086. //创建基于主键的数组引用
  1087. $refer = array();
  1088. foreach ($list as $key => $data) {
  1089. $refer[$data[$pk]] = &$list[$key];
  1090. }
  1091. foreach ($list as $key => $data) {
  1092. //判断是否存在parent
  1093. $parantId = $data[$pid];
  1094. if ($root == $parantId) {
  1095. $tree[] = &$list[$key];
  1096. } else {
  1097. if (isset($refer[$parantId])) {
  1098. $parent = &$refer[$parantId];
  1099. //用于获取下级个数(所有)begin
  1100. if ($has_chldren){
  1101. if (isset($parent['has_chldren'])){
  1102. $parent['has_chldren'] ++;
  1103. }else{
  1104. $parent['has_chldren'] = 1;
  1105. }
  1106. if (isset($list[$key]['has_chldren'])){
  1107. $parent['has_chldren'] += $list[$key]['has_chldren'];
  1108. }
  1109. }
  1110. //用于获取下级个数(所有)end
  1111. $parent[$child][] = &$list[$key];
  1112. }
  1113. }
  1114. }
  1115. }
  1116. return $tree;
  1117. }
  1118. }
  1119. if (!function_exists('tree_to_list')){
  1120. /*
  1121. * tree数组转化为list数组
  1122. * $tree 原树型数组
  1123. * $child 树型数组下级枝干下标(标识)
  1124. * $pk 转化后需要作为list数组键名的属性值的属性名称(为空则转换后的list下标为从0开始的顺序)
  1125. *
  1126. * return list类型数组
  1127. */
  1128. function tree_to_list($tree, $child = 'children',$pk=''){
  1129. $imparr = array();
  1130. foreach($tree as $w) {
  1131. if(isset($w[$child])) {
  1132. $t = $w[$child];
  1133. unset($w[$child]);
  1134. if (!empty($pk)){
  1135. $imparr[$w[$pk]] = $w;
  1136. }else{
  1137. $imparr[] = $w;
  1138. }
  1139. if(is_array($t)){
  1140. if (!empty($pk)){
  1141. $imparr = $imparr + tree_to_list($t, $child,$pk);
  1142. }else{
  1143. $imparr = array_merge($imparr, tree_to_list($t, $child,$pk));
  1144. }
  1145. }
  1146. } else {
  1147. if (!empty($pk)){
  1148. $imparr[$w[$pk]] = $w;
  1149. }else{
  1150. $imparr[] = $w;
  1151. }
  1152. }
  1153. }
  1154. return $imparr;
  1155. }
  1156. }
  1157. if (!function_exists('verify_authortoken'))
  1158. {
  1159. function verify_authortoken($is_force = 0)
  1160. {
  1161. $request = request();
  1162. $web_basehost = $request->host(true);
  1163. if (false !== filter_var($web_basehost, FILTER_VALIDATE_IP) || $web_basehost == 'localhost' || file_exists('./data/conf/multidomain.txt') || preg_match('/\.(my3w\.com)$/i', $web_basehost)) {
  1164. $web_basehost = tpCache('web.web_basehost');
  1165. }
  1166. $web_basehost = preg_replace('/^(http(s)?:)?(\/\/)?([^\/\:]*)(.*)$/i', '${4}', $web_basehost);
  1167. $values = array(
  1168. 'client_domain' => urldecode($web_basehost),
  1169. 'ip' => serverIP(),
  1170. 'curent_version' => getCmsVersion(),
  1171. 'is_force' => $is_force,
  1172. );
  1173. $upgradeLogic = new \app\admin\logic\UpgradeLogic;
  1174. $upgradeLogic->GetKeyData($values);
  1175. $url = $upgradeLogic->getServiceUrl(true).'/index.php?m=api&c=Service&a=check_authortoken';
  1176. $response = @httpRequest($url, 'POST', $values, [], 5);
  1177. if (false === $response) {
  1178. $url = $url.'&'.http_build_query($values);
  1179. $context = stream_context_set_default(array('http' => array('timeout' => 5,'method'=>'GET')));
  1180. $response = @file_get_contents($url, false, $context);
  1181. }
  1182. $params = json_decode($response,true);
  1183. $web_authortoken = !empty($params['code']) ? $params['msg'] : '';
  1184. /*多语言*/
  1185. if (is_language()) {
  1186. $langRow = \think\Db::name('language')->cache(true, EYOUCMS_CACHE_TIME, 'language')
  1187. ->order('id asc')
  1188. ->select();
  1189. foreach ($langRow as $key => $val) {
  1190. tpCache('web', ['web_authortoken'=>$web_authortoken], $val['mark']);
  1191. tpCache('php', ['php_atqueryrequest_time'=>0,'php_atqueryrequest_time2'=>0], $val['mark']);
  1192. }
  1193. } else { // 单语言
  1194. tpCache('web', ['web_authortoken'=>$web_authortoken]);
  1195. tpCache('php', ['php_atqueryrequest_time'=>0,'php_atqueryrequest_time2'=>0]);
  1196. }
  1197. /*--end*/
  1198. delFile(HTML_ROOT); // 清空缓存页面
  1199. session('isset_author', null);
  1200. if (false === $response || (is_array($params) && 1 == $params['code'])) {
  1201. return ['code'=>1, 'msg'=>'授权成功'];
  1202. } else {
  1203. $msg = empty($params['msg']) ? '域名('.request()->host(true).')未授权' : $params['msg'];
  1204. return ['code'=>0, 'msg'=>$msg];
  1205. }
  1206. }
  1207. }
  1208. if (!function_exists('get_not_role_menu_id')){
  1209. /*
  1210. * 获取因为没有打开模块没有权限的入口节点id
  1211. */
  1212. function get_not_role_menu_id(){
  1213. $main_lang= get_main_lang();
  1214. $admin_lang = get_admin_lang();
  1215. $shopServicemeal = array_join_string(array('cGhwLnBocF9zZXJ2aWNlbWVhbA=='));
  1216. $global = include APP_PATH.MODULE_NAME.'/conf/global.php';
  1217. $module_rele_menu = $global['module_rele_menu'];
  1218. $module_reverse_menu = $global['module_reverse_menu'];
  1219. $not_role_menu_id = [];
  1220. $UsersConfig = getUsersConfigData('all');
  1221. //有权限的 (1 == tpCache('global.web_users_switch') && $main_lang == $admin_lang)
  1222. //会员中心
  1223. if (!empty($module_rele_menu['web_users_switch']) && (1 != tpCache('global.web_users_switch') || $main_lang != $admin_lang)){
  1224. $not_role_menu_id = array_merge($not_role_menu_id,$module_rele_menu['web_users_switch']);
  1225. }
  1226. //商城中心 => 会员中心关闭则一起关闭
  1227. // if (1 == tpCache('global.web_users_switch') && 1 == getUsersConfigData('shop.shop_open') && $main_lang == $admin_lang && 1.5 <= tpCache($shopServicemeal))
  1228. if (!empty($module_rele_menu['shop_open']) && (1 != tpCache('global.web_users_switch') || 1 != $UsersConfig['shop_open'] || $main_lang != $admin_lang || 1.5 > tpCache($shopServicemeal))){
  1229. $not_role_menu_id = array_merge($not_role_menu_id,$module_rele_menu['shop_open']);
  1230. }
  1231. //会员投稿 => 会员中心关闭则一起关闭
  1232. if (!empty($module_rele_menu['users_open_release']) && (1 != tpCache('global.web_users_switch') || 1 != $UsersConfig['users_open_release'])){
  1233. $not_role_menu_id = array_merge($not_role_menu_id,$module_rele_menu['users_open_release']);
  1234. }
  1235. //会员升级 => 会员中心关闭则一起关闭
  1236. if (!empty($module_rele_menu['level_member_upgrade']) && (1 != tpCache('global.web_users_switch') || 1 != $UsersConfig['level_member_upgrade'])){
  1237. $not_role_menu_id = array_merge($not_role_menu_id,$module_rele_menu['level_member_upgrade']);
  1238. }
  1239. //支付功能 => 会员中心关闭则一起关闭
  1240. if (!empty($module_rele_menu['pay_open']) && (1 != tpCache('global.web_users_switch') || 1 != $UsersConfig['pay_open'])){
  1241. $not_role_menu_id = array_merge($not_role_menu_id,$module_rele_menu['pay_open']);
  1242. }
  1243. //插件应用
  1244. if (!empty($module_rele_menu['web_weapp_switch']) && (1 != tpCache('global.web_weapp_switch') || $main_lang != $admin_lang)){
  1245. $not_role_menu_id = array_merge($not_role_menu_id,$module_rele_menu['web_weapp_switch']);
  1246. }
  1247. //城市分站
  1248. if (!empty($module_rele_menu['web_citysite_open']) && (1 != tpCache('global.web_citysite_open') || $main_lang != $admin_lang)){
  1249. $not_role_menu_id = array_merge($not_role_menu_id,$module_rele_menu['web_citysite_open']);
  1250. }
  1251. if (!empty($module_reverse_menu['web_citysite_open']) && 1 == tpCache('global.web_citysite_open')){
  1252. $not_role_menu_id = array_merge($not_role_menu_id,$module_reverse_menu['web_citysite_open']);
  1253. }
  1254. //其他因素
  1255. $other_rele_menu = $global['other_rele_menu'];
  1256. if (!empty($other_rele_menu)){
  1257. $not_role_menu_id = array_merge($not_role_menu_id,$other_rele_menu);
  1258. }
  1259. // 会员支付、商城中心,只要开启任何一个,左侧菜单就必须显示订单管理,否则不显示
  1260. if (1 == $UsersConfig['pay_open'] || 1 == $UsersConfig['shop_open']) {
  1261. if (in_array(2004021, $not_role_menu_id)) {
  1262. $searchIndex = array_search(2004021, $not_role_menu_id);
  1263. if (false !== $searchIndex && isset($not_role_menu_id[$searchIndex])) {
  1264. unset($not_role_menu_id[$searchIndex]);
  1265. }
  1266. }
  1267. }
  1268. return $not_role_menu_id;
  1269. }
  1270. }
  1271. if (!function_exists('handle_weapp_url'))
  1272. {
  1273. /*
  1274. * 插件完整url处理成竖线分割的url字符串
  1275. * $url 插件完整url
  1276. * return 竖线分割的url字符串
  1277. */
  1278. function handle_weapp_url($url = '', $type = 0)
  1279. {
  1280. $str_url = '';
  1281. if (2 == $type) {
  1282. $arr = explode('|', $url);
  1283. foreach ($arr as $key => $val) {
  1284. $str_url .= $val;
  1285. if ($key % 2 == 0) {
  1286. $str_url .= '&';
  1287. } else {
  1288. $str_url .= '=';
  1289. }
  1290. }
  1291. $str_url = trim($str_url, '&');
  1292. $str_url = trim($str_url, '=');
  1293. } else {
  1294. $result = !empty($url) ? explode('m=admin&c=Weapp&a=execute', $url) : '';
  1295. if (!empty($result[1])) {
  1296. $str_url = str_replace('=', '|', $result[1]);
  1297. $str_url = str_replace('&', '|', $str_url);
  1298. }
  1299. }
  1300. return $str_url;
  1301. }
  1302. }