心理咨询网
Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363
  1. <?php
  2. /**
  3. * @ copyright (C)2016-2099 Hnaoyun Inc.
  4. * @ author XingMeng
  5. * @ email hnxsh@foxmail.com
  6. * @ date 2017年4月14日
  7. * 公共处理函数
  8. */
  9. use core\basic\Config;
  10. // 获取字符串型自动编码
  11. function get_auto_code($string, $start = '1')
  12. {
  13. if (! $string)
  14. return $start;
  15. if (is_numeric($string)) { // 如果纯数字则直接加1
  16. return sprintf('%0' . strlen($string) . 's', $string + 1);
  17. } else { // 非纯数字则先分拆
  18. $reg = '/^([a-zA-Z-_]+)([0-9]+)$/';
  19. $str = preg_replace($reg, '$1', $string); // 字母部分
  20. $num = preg_replace($reg, '$2', $string); // 数字部分
  21. return $str . sprintf('%0' . (strlen($string) - strlen($str)) . 's', $num + 1);
  22. }
  23. }
  24. // 获取指定分类列表
  25. function get_type($tcode)
  26. {
  27. $type_model = model('admin.system.Type');
  28. if (! ! $result = $type_model->getItem($tcode)) {
  29. return $result;
  30. } else {
  31. return array();
  32. }
  33. }
  34. // 生成区域选择
  35. function make_area_Select($tree, $selectid = null)
  36. {
  37. $list_html = '';
  38. global $blank;
  39. foreach ($tree as $values) {
  40. // 默认选择项
  41. if ($selectid == $values->acode) {
  42. $select = "selected='selected'";
  43. } else {
  44. $select = '';
  45. }
  46. // 禁用父栏目选择功能
  47. if ($values->son) {
  48. $disabled = "disabled='disabled'";
  49. } else {
  50. $disabled = '';
  51. }
  52. $list_html .= "<option value='{$values->acode}' $select $disabled>{$blank}{$values->acode} {$values->name}";
  53. // 子菜单处理
  54. if ($values->son) {
  55. $blank .= '  ';
  56. $list_html .= make_area_Select($values->son, $selectid);
  57. }
  58. }
  59. // 循环完后回归位置
  60. $blank = substr($blank, 0, - 6);
  61. return $list_html;
  62. }
  63. // 检测指定的方法是否拥有权限
  64. function check_level($btnAction, $isPath = false)
  65. {
  66. $user_level = session('levels');
  67. if ($isPath) {
  68. if (in_array($btnAction, $user_level)) {
  69. return true;
  70. }
  71. } else {
  72. if (in_array('/' . M . '/' . C . '/' . $btnAction, $user_level) || session('id') == 1) {
  73. return true;
  74. }
  75. }
  76. }
  77. // 获取返回按钮
  78. function get_btn_back($btnName = '返 回')
  79. {
  80. if (! ! $backurl = get('backurl')) {
  81. $url = base64_decode($backurl);
  82. } elseif (isset($_SERVER["HTTP_REFERER"])) {
  83. $url = $_SERVER["HTTP_REFERER"];
  84. } else {
  85. $url = url('/' . M . '/' . C . '/index');
  86. }
  87. $btn_html = "<a href='" . $url . "' class='layui-btn layui-btn-primary'>$btnName</a>";
  88. return $btn_html;
  89. }
  90. // 获取新增按钮
  91. function get_btn_add($btnName = '新 增')
  92. {
  93. $user_level = session('levels');
  94. if (! in_array('/' . M . '/' . C . '/add', $user_level) && session('id') != 1)
  95. return;
  96. $btn_html = "<a href='" . url("/" . M . '/' . C . "/add") . get_btn_qs() . "' class='layui-btn layui-btn-primary'>$btnName</a>";
  97. return $btn_html;
  98. }
  99. // 获取更多按钮
  100. function get_btn_more($idValue, $id = 'id', $btnName = '详情')
  101. {
  102. $btn_html = "<a href='" . url("/" . M . '/' . C . "/index/$id/$idValue") . "' class='layui-btn layui-btn-xs layui-btn-primary' title='$btnName'>$btnName</a>";
  103. return $btn_html;
  104. }
  105. // 获取删除按钮
  106. function get_btn_del($idValue, $id = 'id', $btnName = '删除')
  107. {
  108. $user_level = session('levels');
  109. if (! in_array('/' . M . '/' . C . '/del', $user_level) && session('id') != 1)
  110. return;
  111. $btn_html = "<a href='" . url('/' . M . '/' . C . "/del/$id/$idValue") . "' onclick='return confirm(\"您确定要删除么?\")' class='layui-btn layui-btn-xs layui-btn-danger' title='$btnName'>$btnName</a>";
  112. return $btn_html;
  113. }
  114. // 获取修改按钮
  115. function get_btn_mod($idValue, $id = 'id', $btnName = '修改')
  116. {
  117. $user_level = session('levels');
  118. if (! in_array('/' . M . '/' . C . '/mod', $user_level) && session('id') != 1)
  119. return;
  120. $btn_html = "<a href='" . url("/" . M . '/' . C . "/mod/$id/$idValue") . get_btn_qs() . "' class='layui-btn layui-btn-xs'>$btnName</a>";
  121. return $btn_html;
  122. }
  123. // 获取其它按钮
  124. function get_btn($btnName, $theme, $btnAction, $idValue, $id = 'id')
  125. {
  126. $user_level = session('levels');
  127. if (! in_array('/' . M . '/' . C . '/' . $btnAction, $user_level) && session('id') != 1)
  128. return;
  129. $btn_html = "<a href='" . url("/" . M . '/' . C . "/$btnAction/$id/$idValue") . get_btn_qs() . "' class='layui-btn layui-btn-xs $theme'>$btnName</a>";
  130. return $btn_html;
  131. }
  132. // 获取按钮返回参数
  133. function get_btn_qs()
  134. {
  135. if (isset($_SERVER["QUERY_STRING"]) && ! ! $qs = $_SERVER["QUERY_STRING"]) {
  136. return "&backurl=" . base64_encode(URL);
  137. } else {
  138. return "?backurl=" . base64_encode(URL);
  139. }
  140. }
  141. // 获取返回URL
  142. function get_backurl()
  143. {
  144. if (! ! $backurl = get('backurl')) {
  145. if (isset($_SERVER["QUERY_STRING"]) && ! ! get('p')) {
  146. return "&backurl=" . $backurl;
  147. } else {
  148. return "?backurl=" . $backurl;
  149. }
  150. } else {
  151. return;
  152. }
  153. }
  154. // 获取返回tab跳转地址
  155. function get_tab($tid)
  156. {
  157. if (isset($_SERVER["QUERY_STRING"]) && ! ! get('p')) {
  158. return "&#tab=" . $tid;
  159. } else {
  160. return "?#tab=" . $tid;
  161. }
  162. }
  163. // 缓存语言信息
  164. function cache_config($refresh = false)
  165. {
  166. // 系统配置缓存
  167. $config_cache = RUN_PATH . '/config/' . md5('config') . '.php';
  168. if (! file_exists($config_cache) || $refresh) {
  169. $model = model('admin.system.Config');
  170. $config = $model->getConfig();
  171. unset($config['sn']);
  172. unset($config['sn_user']);
  173. Config::set(md5('config'), $config, false, true);
  174. }
  175. // 多语言缓存
  176. $lg_cache = RUN_PATH . '/config/' . md5('area') . '.php';
  177. if (! file_exists($lg_cache) || $refresh) {
  178. $model = model('admin.system.Config');
  179. $area = $model->getAreaTheme(); // 获取所有语言
  180. $map = array();
  181. foreach ($area as $key => $value) {
  182. $map[$value['acode']] = $value;
  183. }
  184. if (! $map) {
  185. error('系统没有任何可用区域,请核对后再试!');
  186. }
  187. $lgs['lgs'] = $map;
  188. Config::set(md5('area'), $lgs, false, true);
  189. }
  190. // 分站缓存
  191. $city_cache = RUN_PATH . '/config/' . md5('city') . '.php';
  192. if ( file_exists(ROOT_PATH . '/data/city.lock') && ( ! file_exists($city_cache) || $refresh ) ) {
  193. $model = model('admin.system.City');
  194. $city = $model->getAllList(); // 获取城市分站
  195. $map = array();
  196. foreach ($city as $key => $value) {
  197. $map[$value['etitle']] = $value;
  198. }
  199. $citys['citys'] = $map;
  200. Config::set(md5('city'), $citys, false, true);
  201. }
  202. }
  203. /**
  204. * 生成分站URL分站参数
  205. * @param string $etitle 分站英文名称
  206. * @param string $isurl 分站绑定链接
  207. * @return string $path 追加URL参数
  208. */
  209. function create_city_url( $etitle, $isurl, $path=false ){
  210. $main_domain = Config::get('main_domain'); //主域名
  211. $wildcard = Config::get('wildcard'); //泛域名支持
  212. $city_suffix = Config::get('city_suffix')?'.html':'/'; //分站后缀
  213. $http = 'http://';
  214. if( is_https() ){
  215. $http = 'https://';
  216. }
  217. if( $wildcard ){
  218. if( $main_domain=='' ){
  219. error('请到后台全局配置->参数配置->基本配置中填入「网站主域名」');
  220. }
  221. //生成泛域名
  222. $domain = create_domain($main_domain,$etitle);
  223. if( $path ){
  224. $url = $http . $domain.'/'.PATH;
  225. }
  226. $url = $http . $domain;
  227. }else{
  228. if( $isurl ){
  229. if( $path ){
  230. $url = $http . $isurl.'/'.PATH;
  231. }else{
  232. $url = $http . $isurl;
  233. }
  234. }else{
  235. if( $path ){
  236. $url = ($main_domain ? $http . $main_domain : '') . '/'.$etitle.'/'.PATH;
  237. }else{
  238. $url = ($main_domain ? $http . $main_domain : '') . '/'.$etitle.$city_suffix;
  239. }
  240. }
  241. }
  242. return $url;
  243. }
  244. // 生成新域名 @cms88
  245. function create_domain( $domain, $etitle ){
  246. $domain_first = explode('.', $domain)[0];
  247. $new_domain = str_replace($domain_first, $etitle, $domain);
  248. return $new_domain;
  249. }
  250. // 获取默认语言
  251. function get_default_lg()
  252. {
  253. $default = current(Config::get('lgs'));
  254. return $default['acode'];
  255. }
  256. // 获取当前语言并进行安全处理
  257. function get_lg()
  258. {
  259. $lg = cookie('lg');
  260. if (! $lg || ! preg_match('/^[\w\-]+$/', $lg)) {
  261. $lg = get_default_lg();
  262. cookie('lg', $lg);
  263. }
  264. return $lg;
  265. }
  266. // 获取当前语言主题
  267. function get_theme()
  268. {
  269. $lgs = Config::get('lgs');
  270. $lg = get_lg();
  271. return $lgs[$lg]['theme'];
  272. }
  273. // 推送百度
  274. function post_baidu($api, $urls)
  275. {
  276. $ch = curl_init();
  277. $options = array(
  278. CURLOPT_CONNECTTIMEOUT => 30,
  279. CURLOPT_TIMEOUT => 90,
  280. CURLOPT_URL => $api,
  281. CURLOPT_POST => true,
  282. CURLOPT_RETURNTRANSFER => true,
  283. CURLOPT_POSTFIELDS => implode("\n", $urls),
  284. CURLOPT_HTTPHEADER => array(
  285. 'Content-Type: text/plain'
  286. )
  287. );
  288. curl_setopt_array($ch, $options);
  289. $result = json_decode(curl_exec($ch));
  290. return $result;
  291. }
  292. function titlereplace($data){
  293. //把? ?都替换为空格
  294. $search = array('?','?',' ','%',',');
  295. return str_replace($search, "_", $data);
  296. }
  297. function baiduSubmitResource($appid,$accessToken){
  298. $obj = new BaiduSmartappOpenapiClientSubmitResource();
  299. // 开发者在此设置请求参数,文档示例中的参数均为示例参数,实际参数请参考对应接口的文档上方的参数说明填写
  300. // 注意:代码示例中的参数字段基本是驼峰形式,而文档中的参数说明的参数字段基本是下划线形式
  301. // 如果开发者不想传非必需参数,可以将设置该参数的行注释
  302. $params = new BaiduSmartappOpenapiClientSubmitResourceRequest();
  303. $params->accessToken =$accessToken;
  304. $params->appId = $appid; // 文档中对应字段:app_id,实际使用时请替换成真实参数
  305. $params->body = "天气凉了适合来一碗甜酒酿来暖暖胃,甜酒酿的功效非常多,网路上很多人也都有介绍,甜酒酿不只能改善经痛,也有丰胸和美白的作用!!这边用最简单、省时的方式教大家做酒酿蛋。 "; // 文档中对应字段:body,实际使用时请替换成真实参数
  306. $params->ext = '{"publish_time": "2022年9月8日"}'; // 文档中对应字段:ext,实际使用时请替换成真实参数
  307. $params->feedSubType = "中餐"; // 文档中对应字段:feed_sub_type,实际使用时请替换成真实参数
  308. $params->feedType = "美食"; // 文档中对应字段:feed_type,实际使用时请替换成真实参数
  309. $params->images = '["http://www.xx.com/static/upload/image/20220726/1517118158226.jpg"]'; // 文档中对应字段:images,实际使用时请替换成真实参数
  310. $params->mappSubType = "1001"; // 文档中对应字段:mapp_sub_type,实际使用时请替换成真实参数
  311. $params->mappType = "1000"; // 文档中对应字段:mapp_type,实际使用时请替换成真实参数
  312. $params->path = "/pages/article/view?id=47696"; // 文档中对应字段:path,实际使用时请替换成真实参数
  313. $params->tags = "丰胸,酒酿蛋,丰胸酒酿蛋,纯天然丰胸酒酿蛋"; // 文档中对应字段:tags,实际使用时请替换成真实参数
  314. $params->title = "纯天然丰胸酒酿蛋"; // 文档中对应字段:title,实际使用时请替换成真实参数
  315. echo(json_encode($params));
  316. if ($obj->doRequest($params)){
  317. echo "请求信息成功!";
  318. // 如果请求成功 可以直接通过 getData 方法获取到返回结构体里的 data 字段值
  319. var_dump($obj->getData());
  320. // 如果请求成功 可以通过 getErrMsg 方法获取到完整的响应信息
  321. var_dump($obj->getErrMsg());
  322. exit();
  323. } else {
  324. echo "请求信息失败";
  325. // 如果请求失败 可以直接通过 getErrMsg 方法获取到报错信息,辅助问题定位
  326. var_dump($obj->getErrMsg());
  327. exit();
  328. }
  329. }