common.php 52 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491
  1. <?php
  2. /**
  3. *
  4. * Common.php (项目公共函数库)
  5. *
  6. */
  7. if(!defined("Ainaphp")) exit("Access Denied");
  8. //判断是否为移动端
  9. function is_mobile() {
  10. $user_agent = $_SERVER['HTTP_USER_AGENT'];
  11. $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","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","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","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");
  12. $is_mobile = false;
  13. foreach ($mobile_agents as $device) {
  14. if (stristr($user_agent, $device)) {
  15. $is_mobile = true;
  16. break;
  17. }
  18. }
  19. return $is_mobile;
  20. }
  21. //判断是否为微信
  22. function is_weixin(){
  23. if ( strpos($_SERVER['HTTP_USER_AGENT'], 'MicroMessenger') !== false ) {
  24. return true;
  25. }
  26. return false;
  27. }
  28. //curl解析json
  29. function http_request_json($url){
  30. $ch = curl_init();
  31. curl_setopt($ch, CURLOPT_URL, $url);
  32. curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, false);
  33. curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, false);
  34. curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
  35. $result = curl_exec($ch);
  36. curl_close($ch);
  37. return $result;
  38. }
  39. function fieldoption($fields,$value=null,$space=''){
  40. $options = explode("\n",$fields['setup']['options']);
  41. foreach($options as $r) {
  42. $v = explode("|",$r);
  43. $k = trim($v[1]);
  44. $optionsarr[$k] = $v[0];
  45. }
  46. if(isset($value)){
  47. if(strpos($value,',')){
  48. $value =explode(",",$value);
  49. $data=array();
  50. foreach((array)$value as $val){
  51. $data[]= $optionsarr[$val];
  52. }
  53. if($space!=''){
  54. return implode(stripcslashes($space),$data);
  55. }else{
  56. return $data;
  57. }
  58. }else{
  59. return $optionsarr[$value];
  60. }
  61. }else{
  62. return $optionsarr;
  63. }
  64. }
  65. function picstoarr($str=''){
  66. $data=array();
  67. $v = explode(":::",$str);
  68. foreach((array)$v as $r){
  69. $r=explode('|',$r);
  70. $res['file']=$r[0];
  71. $res['desc']=$r[1];
  72. $data[]=$res;
  73. }
  74. return $data;
  75. }
  76. function get_arrparentid($pid, $array=array(),$arrparentid='') {
  77. if(!is_array($array) || !isset($array[$pid])) return $pid;
  78. $parentid = $array[$pid]['parentid'];
  79. $arrparentid = $arrparentid ? $parentid.','.$arrparentid : $parentid;
  80. if($parentid) {
  81. $arrparentid = get_arrparentid($parentid,$array, $arrparentid);
  82. }else{
  83. $data = array();
  84. $data['bid'] = $pid;
  85. $data['arrparentid'] = $arrparentid;
  86. }
  87. return $arrparentid;
  88. }
  89. function getform($form,$info,$value=''){
  90. return $form->$info['type']($info,$value);
  91. }
  92. function getvalidate($info){
  93. $validate_data=array();
  94. if($info['minlength']) $validate_data['minlength'] = ' minlength:'.$info['minlength'];
  95. if($info['maxlength']) $validate_data['maxlength'] = ' maxlength:'.$info['maxlength'];
  96. if($info['required']) $validate_data['required'] = ' required:true';
  97. if($info['pattern']) $validate_data['pattern'] = ' '.$info['pattern'].':true';
  98. if($info['errormsg']) $errormsg = ' title="'.$info['errormsg'].'"';
  99. $validate= implode(',',$validate_data);
  100. $validate= $validate ? 'validate="'.$validate.'" ' : '';
  101. $parseStr = $validate.$errormsg;
  102. return $parseStr;
  103. }
  104. function sendmail($tomail,$subject,$body,$config=''){
  105. if(!$config)$config = F('Config');
  106. import("@.ORG.PHPMailer");
  107. $mail = new PHPMailer();
  108. if($config['mail_type']==1){
  109. $mail->IsSMTP();
  110. }elseif($config['mail_type']==2){
  111. $mail->IsMail();
  112. }else{
  113. if($config['sendmailpath']){
  114. $mail->Sendmail =$config['mail_sendmail'];
  115. }else{
  116. $mail->Sendmail =ini_get('sendmail_path');
  117. }
  118. $mail->IsSendmail();
  119. }
  120. if($config['mail_auth']){
  121. $mail->SMTPAuth = true; // 开启SMTP认证
  122. }else{
  123. $mail->SMTPAuth = false; // 开启SMTP认证
  124. }
  125. $mail->PluginDir=LIB_PATH."ORG/";
  126. $mail->CharSet='utf-8';
  127. $mail->SMTPDebug = false; // 改为2可以开启调试
  128. $mail->Host = $config['mail_server']; // GMAIL的SMTP
  129. //$mail->SMTPSecure = "ssl"; // 设置连接服务器前缀
  130. //$mail->Encoding = "base64";
  131. $mail->Port = $config['mail_port']; // GMAIL的SMTP端口号
  132. $mail->Username = $config['mail_user']; // GMAIL用户名,必须以@gmail结尾
  133. $mail->Password = $config['mail_password']; // GMAIL密码
  134. //$mail->From ="coo@ainatec.com";
  135. //$mail->FromName = "Aina系统";
  136. $mail->SetFrom($config['mail_from'], $config['site_name']); //发送者邮箱
  137. $mail->AddAddress($tomail); //可同时发多个
  138. //$mail->AddReplyTo('287804931@qq.com', 'ainaphp'); //回复到这个邮箱
  139. //$mail->WordWrap = 50; // 设定 word wrap
  140. //$mail->AddAttachment("/var/tmp/file.tar.gz"); // 附件1
  141. //$mail->AddAttachment("/tmp/image.jpg", "new.jpg"); // 附件2
  142. $mail->IsHTML(true); // 以HTML发送
  143. $mail->Subject = $subject;
  144. $mail->Body = $body;
  145. //$mail->AltBody = "This is the body when user views in plain text format"; //纯文字时的Body
  146. if(!$mail->Send())
  147. {
  148. return false;
  149. }else{
  150. return true;
  151. }
  152. }
  153. function delattach($map=''){
  154. $model = M('Attachment');
  155. $att= $model->field('aid,filepath')->where($map)->select();
  156. $aids=array();
  157. foreach((array)$att as $key=> $r){
  158. $aids[]=$r['aid'];
  159. @unlink(__ROOT__.$r['filepath']);
  160. }
  161. $r =$model->delete(implode(',',$aids));
  162. return false!==$r ? true : false;
  163. }
  164. function template_file($module='',$path='',$ext='html'){
  165. $sysConfig = F('sys.config');
  166. $path= $path ? $path : TMPL_PATH.'Home/'.$sysConfig['DEFAULT_THEME'].'/';
  167. $tempfiles = dir_list($path,$ext);
  168. foreach ($tempfiles as $key=>$file){
  169. $dirname = basename($file);
  170. if($module){
  171. if(strstr($dirname,$module.'_')) {
  172. $arr[$key]['name'] = substr($dirname,0,strrpos($dirname, '.'));
  173. $arr[$key]['value'] = substr($arr[$key]['name'],strpos($arr[$key]['name'], '_')+1);
  174. $arr[$key]['filename'] = $dirname;
  175. $arr[$key]['filepath'] = $file;
  176. }
  177. }else{
  178. $arr[$key]['name'] = substr($dirname,0,strrpos($dirname, '.'));
  179. $arr[$key]['value'] = substr($arr[$key]['name'],strpos($arr[$key]['name'], '_')+1);
  180. $arr[$key]['filename'] = $dirname;
  181. $arr[$key]['filepath'] = $file;
  182. }
  183. }
  184. return $arr;
  185. }
  186. function fileext($filename) {
  187. return strtolower(trim(substr(strrchr($filename, '.'), 1, 10)));
  188. }
  189. function dir_path($path) {
  190. $path = str_replace('\\', '/', $path);
  191. if(substr($path, -1) != '/') $path = $path.'/';
  192. return $path;
  193. }
  194. function dir_create($path, $mode = 0777) {
  195. if(is_dir($path)) return TRUE;
  196. $ftp_enable = 0;
  197. $path = dir_path($path);
  198. $temp = explode('/', $path);
  199. $cur_dir = '';
  200. $max = count($temp) - 1;
  201. for($i=0; $i<$max; $i++) {
  202. $cur_dir .= $temp[$i].'/';
  203. if (@is_dir($cur_dir)) continue;
  204. @mkdir($cur_dir, $mode,true);
  205. @chmod($cur_dir, $mode);
  206. }
  207. return is_dir($path);
  208. }
  209. function mk_dir($dir, $mode = 0777) {
  210. if (is_dir($dir) || @mkdir($dir, $mode))
  211. return true;
  212. if (!mk_dir(dirname($dir), $mode))
  213. return false;
  214. return @mkdir($dir, $mode);
  215. }
  216. function dir_copy($fromdir, $todir) {
  217. $fromdir = dir_path($fromdir);
  218. $todir = dir_path($todir);
  219. if (!is_dir($fromdir)) return FALSE;
  220. if (!is_dir($todir)) dir_create($todir);
  221. $list = glob($fromdir.'*');
  222. if (!empty($list)) {
  223. foreach($list as $v) {
  224. $path = $todir.basename($v);
  225. if(is_dir($v)) {
  226. dir_copy($v, $path);
  227. } else {
  228. copy($v, $path);
  229. @chmod($path, 0777);
  230. }
  231. }
  232. }
  233. return TRUE;
  234. }
  235. function dir_list($path, $exts = '', $list= array()) {
  236. $path = dir_path($path);
  237. $files = glob($path.'*');
  238. foreach($files as $v) {
  239. $fileext = fileext($v);
  240. if (!$exts || preg_match("/\.($exts)/i", $v)) {
  241. $list[] = $v;
  242. if (is_dir($v)) {
  243. $list = dir_list($v, $exts, $list);
  244. }
  245. }
  246. }
  247. return $list;
  248. }
  249. function dir_tree($dir, $parentid = 0, $dirs = array()) {
  250. if ($parentid == 0) $id = 0;
  251. $list = glob($dir.'*');
  252. foreach($list as $v) {
  253. if (is_dir($v)) {
  254. $id++;
  255. $dirs[$id] = array('id'=>$id,'parentid'=>$parentid, 'name'=>basename($v), 'dir'=>$v.'/');
  256. $dirs = dir_tree($v.'/', $id, $dirs);
  257. }
  258. }
  259. return $dirs;
  260. }
  261. function dir_delete($dir) {
  262. //$dir = dir_path($dir);
  263. if (!is_dir($dir)) return FALSE;
  264. $handle = opendir($dir); //打开目录
  265. while(($file = readdir($handle)) !== false) {
  266. if($file == '.' || $file == '..')continue;
  267. $d = $dir.DIRECTORY_SEPARATOR.$file;
  268. is_dir($d) ? dir_delete($d) : @unlink($d);
  269. }
  270. closedir($handle);
  271. return @rmdir($dir);
  272. }
  273. function toDate($time, $format = 'Y-m-d H:i:s') {
  274. if (empty ( $time )) {
  275. return '';
  276. }
  277. $format = str_replace ( '#', ':', $format );
  278. return date ($format, $time );
  279. }
  280. function savecache($name = '',$id='') {
  281. unlink(RUNTIME_FILE);
  282. $Model = M ( $name );
  283. if($name=='Lang'){
  284. $list = $Model->order('listorder')->select ();
  285. $pkid = $Model->getPk ();
  286. $data = array ();
  287. foreach ( $list as $key => $val ) {
  288. $data [$val ['mark']] = $val;
  289. }
  290. F($name,$data);
  291. }elseif($name=='Module'){
  292. $list = $Model->order('listorder')->select ();
  293. $pkid = $Model->getPk ();
  294. $data = array ();
  295. foreach ( $list as $key => $val ){
  296. $data [$val [$pkid]] = $val;
  297. $smalldata[$val['name']] = $val [$pkid];
  298. }
  299. F($name,$data);
  300. F('Mod',$smalldata);
  301. //savecache
  302. }elseif($name=='Config'){
  303. $list = $Model->select ();
  304. $data=$sysdata=$temp=$memberconfig=array();
  305. foreach($list as $key=>$r) {
  306. if($r['groupid']==6){
  307. $sysdata[$r['varname']]=$r['value'];
  308. }elseif($r['groupid']==3){
  309. if(APP_LANG)
  310. $memberconfig_temp[$r['lang']][$r['varname']]=$r['value'];
  311. else
  312. $memberconfig[$r['varname']]=$r['value'];
  313. }else{
  314. if(APP_LANG)
  315. if($r['lang']){$temp[$r['lang']][$r['varname']]=$r['value'];}else{$data[$r['varname']]=$r['value'];}
  316. else
  317. $data[$r['varname']]=$r['value'];
  318. }
  319. }
  320. if(APP_LANG){
  321. $lang=F('Lang');
  322. foreach((array)$lang as $key=>$r){
  323. $data1=array();
  324. $data1 = array_merge($temp[$r['id']],$data);
  325. F('Config_'.$key,$data1);
  326. F('member.config_'.$key,$memberconfig_temp[$r['id']]);
  327. if(empty($data1['HOME_ISHTML'])){
  328. @unlink('./index.html');
  329. @unlink('./'.$key.'/index.html');
  330. }
  331. }
  332. }else{
  333. F('Config',$data);
  334. F('member.config',$memberconfig);
  335. if(empty($data['HOME_ISHTML']))@unlink('./index.html');
  336. }
  337. $langs = M('Lang')->field('mark')->select();foreach((array)$langs as $r ) $lang1[]=$r['mark'];
  338. $sysdata['LANG_LIST'] = 'zh-cn,'.implode(',',$lang1);
  339. F('sys.config',$sysdata);
  340. }elseif($name=='Category'){
  341. $data=$smalldata=$temp=array();
  342. if(APP_LANG){
  343. $lang=F('Lang');
  344. foreach((array)$lang as $key=>$r){
  345. $langid =$r['id'];
  346. if($langid){
  347. $lang = $key;
  348. $list = $Model->where('lang='.$langid)->order('listorder')->select ();
  349. $pkid = $Model->getPk ();
  350. $data = array ();
  351. foreach ( $list as $key => $val ) {
  352. $data [$val [$pkid]] = $val;
  353. $smalldata[$val['catdir']] = $val [$pkid];
  354. }
  355. F('Category_'.$lang,$data);
  356. F('Cat_'.$lang,$smalldata);
  357. }
  358. }
  359. }else{
  360. $list = $Model->order('listorder')->select ();
  361. $pkid = $Model->getPk ();
  362. $data = array ();
  363. foreach ( $list as $key => $val ) {
  364. $data [$val [$pkid]] = $val;
  365. $smalldata[$val['catdir']] = $val [$pkid];
  366. }
  367. F($name,$data);
  368. F('Cat',$smalldata);
  369. }
  370. }elseif($name=='Field'){
  371. if($id){
  372. $list = $Model->order('listorder')->where('moduleid='.$id)->select ();
  373. $pkid = 'field';
  374. $data = array ();
  375. foreach ( $list as $key => $val ) {
  376. $data [$val [$pkid]] = $val;
  377. }
  378. $name=$id.'_'.$name;
  379. F($name,$data);
  380. }else{
  381. $module = F('Module');
  382. foreach ( $module as $key => $val ) {
  383. savecache($name,$key);
  384. }
  385. }
  386. }elseif($name=='Dbsource'){
  387. $list = $Model->select ();
  388. $data = array ();
  389. foreach ( $list as $key => $val ) {
  390. $data [$val ['name']] = $val;
  391. }
  392. F($name,$data);
  393. }else{
  394. $list = $Model->order('listorder')->select ();
  395. $pkid = $Model->getPk ();
  396. $data = array ();
  397. foreach ( $list as $key => $val ) {
  398. $data [$val [$pkid]] = $val;
  399. }
  400. F($name,$data);
  401. if($name=='Urlrule'){
  402. $config = F('sys.config');
  403. if($config['URL_URLRULE'])routes_cache($config['URL_URLRULE']);
  404. }
  405. }
  406. return true;
  407. }
  408. function checkfield($fields,$postdata){
  409. foreach ( $postdata as $key => $val ) {
  410. $setup=$fields[$key]['setup'];
  411. if(!empty($fields[$key]['required']) && empty($postdata[$key])) return '';
  412. //$setup=string2array($fields[$key]['setup']);
  413. if($setup['multiple'] || $setup['inputtype']=='checkbox' || $fields[$key]['type']=='checkbox'){
  414. //$postdata[$key] = safe_replace(strip_tags($postdata[$key]));
  415. $postdata[$key] = implode(',',$postdata[$key]);
  416. }elseif($fields[$key]['type']=='datetime'){
  417. $postdata[$key] =strtotime($postdata[$key]);
  418. }elseif($fields[$key]['type']=='textarea'){
  419. $postdata[$key]=addslashes_array($postdata[$key]);
  420. }elseif($fields[$key]['type']=='images' || $fields[$key]['type']=='files'){
  421. $name = $key.'_name';
  422. $arrdata =array();
  423. foreach($postdata[$key] as $k=>$res){
  424. if(!empty($postdata[$key][$k])) $arrdata[]= safe_replace(strip_tags($postdata[$key][$k].'|'.$postdata[$name][$k]));
  425. }
  426. $postdata[$key]=implode(':::',$arrdata);
  427. }elseif($fields[$key]['type']=='editor'){
  428. //自动提取摘要
  429. if(isset($postdata['add_description']) && $postdata['description'] == '' && isset($postdata['content'])) {
  430. $content = stripslashes($postdata['content']);
  431. $description_length = intval($postdata['description_length']);
  432. $postdata['description'] = str_cut(str_replace(array("\r\n","\t",'[page]','[/page]','&ldquo;','&rdquo;'), '', strip_tags($content)),$description_length);
  433. $postdata['description'] = addslashes_array($postdata['description']);
  434. }
  435. //自动提取缩略图
  436. if(isset($postdata['auto_thumb']) && $postdata['thumb'] == '' && isset($postdata['content'])) {
  437. $content = $content ? $content : stripslashes($postdata['content']);
  438. $auto_thumb_no = intval($postdata['auto_thumb_no']) * 3;
  439. if(preg_match_all("/(src)=([\"|']?)([^ \"'>]+\.(gif|jpg|jpeg|bmp|png))\\2/i", $content, $matches)) {
  440. $postdata['thumb'] = $matches[$auto_thumb_no][0];
  441. }
  442. }
  443. }elseif($fields[$key]['type']=='title' || $fields[$key]['type']=='text'){
  444. $postdata[$key] = safe_replace(strip_tags($postdata[$key]));
  445. }
  446. }
  447. return $postdata;
  448. }
  449. function string2array($info) {
  450. if($info == '') return array();
  451. $info=stripcslashes($info);
  452. eval("\$r = $info;");
  453. return $r;
  454. }
  455. function array2string($info) {
  456. if($info == '') return '';
  457. if(!is_array($info)) $string = stripslashes($info);
  458. foreach($info as $key => $val) $string[$key] = stripslashes($val);
  459. return addslashes(var_export($string, TRUE));
  460. }
  461. /**
  462. +----------------------------------------------------------
  463. * 产生随机字串,可用来自动生成密码
  464. * 默认长度6位 字母和数字混合 支持中文
  465. +----------------------------------------------------------
  466. * @param string $len 长度
  467. * @param string $type 字串类型
  468. * 0 字母 1 数字 其它 混合
  469. * @param string $addChars 额外字符
  470. +----------------------------------------------------------
  471. * @return string
  472. +----------------------------------------------------------
  473. */
  474. function rand_string($len = 6, $type = '', $addChars = '') {
  475. $str = '';
  476. switch ($type) {
  477. case 0 :
  478. $chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz' . $addChars;
  479. break;
  480. case 1 :
  481. $chars = str_repeat ( '0123456789', 3 );
  482. break;
  483. case 2 :
  484. $chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZ' . $addChars;
  485. break;
  486. case 3 :
  487. $chars = 'abcdefghijklmnopqrstuvwxyz' . $addChars;
  488. break;
  489. default :
  490. // 默认去掉了容易混淆的字符oOLl和数字01,要添加请使用addChars参数
  491. $chars = 'ABCDEFGHIJKMNPQRSTUVWXYZabcdefghijkmnpqrstuvwxyz23456789' . $addChars;
  492. break;
  493. }
  494. if ($len > 10) { //位数过长重复字符串一定次数
  495. $chars = $type == 1 ? str_repeat ( $chars, $len ) : str_repeat ( $chars, 5 );
  496. }
  497. if ($type != 4) {
  498. $chars = str_shuffle ( $chars );
  499. $str = substr ( $chars, 0, $len );
  500. } else {
  501. // 中文随机字
  502. for($i = 0; $i < $len; $i ++) {
  503. $str .= msubstr ( $chars, floor ( mt_rand ( 0, mb_strlen ( $chars, 'utf-8' ) - 1 ) ), 1 );
  504. }
  505. }
  506. return $str;
  507. }
  508. function sysmd5($str,$key='',$type='sha1'){
  509. $key = $key ? $key : C('ADMIN_ACCESS');
  510. return hash ( $type, $str.$key );
  511. }
  512. function pwdHash($password, $type = 'md5') {
  513. return hash ( $type, $password );
  514. }
  515. /**
  516. * @param string $string 原文或者密文
  517. * @param string $operation 操作(ENCODE | DECODE), 默认为 DECODE
  518. * @param string $key 密钥
  519. * @param int $expiry 密文有效期, 加密时候有效, 单位 秒,0 为永久有效
  520. * @return string 处理后的 原文或者 经过 base64_encode 处理后的密文
  521. *
  522. * @example
  523. *
  524. * $a = authcode('abc', 'ENCODE', 'key');
  525. * $b = authcode($a, 'DECODE', 'key'); // $b(abc)
  526. *
  527. * $a = authcode('abc', 'ENCODE', 'key', 3600);
  528. * $b = authcode('abc', 'DECODE', 'key'); // 在一个小时内,$b(abc),否则 $b 为空
  529. */
  530. function authcode($string, $operation = 'DECODE', $key = '', $expiry = 0)
  531. {
  532. $ckey_length = 4;
  533. // 随机密钥长度 取值 0-32;
  534. // 加入随机密钥,可以令密文无任何规律,即便是原文和密钥完全相同,加密结果也会每次不同,增大破解难度。
  535. // 取值越大,密文变动规律越大,密文变化 = 16 的 $ckey_length 次方
  536. // 当此值为 0 时,则不产生随机密钥
  537. $keya = md5(substr($key, 0, 16));
  538. $keyb = md5(substr($key, 16, 16));
  539. $keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, 0, $ckey_length): substr(md5(microtime()), -$ckey_length)) : '';
  540. $cryptkey = $keya.md5($keya.$keyc);
  541. $key_length = strlen($cryptkey);
  542. $string = $operation == 'DECODE' ? base64_decode(substr($string, $ckey_length)) : sprintf('%010d', $expiry ? $expiry + time() : 0).substr(md5($string.$keyb), 0, 16).$string;
  543. $string_length = strlen($string);
  544. $result = '';
  545. $box = range(0, 255);
  546. $rndkey = array();
  547. for($i = 0; $i <= 255; $i++)
  548. {
  549. $rndkey[$i] = ord($cryptkey[$i % $key_length]);
  550. }
  551. for($j = $i = 0; $i < 256; $i++)
  552. {
  553. $j = ($j + $box[$i] + $rndkey[$i]) % 256;
  554. $tmp = $box[$i];
  555. $box[$i] = $box[$j];
  556. $box[$j] = $tmp;
  557. }
  558. for($a = $j = $i = 0; $i < $string_length; $i++)
  559. {
  560. $a = ($a + 1) % 256;
  561. $j = ($j + $box[$a]) % 256;
  562. $tmp = $box[$a];
  563. $box[$a] = $box[$j];
  564. $box[$j] = $tmp;
  565. $result .= chr(ord($string[$i]) ^ ($box[($box[$a] + $box[$j]) % 256]));
  566. }
  567. if($operation == 'DECODE')
  568. {
  569. if((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) && substr($result, 10, 16) == substr(md5(substr($result, 26).$keyb), 0, 16))
  570. {
  571. return substr($result, 26);
  572. }
  573. else
  574. {
  575. return '';
  576. }
  577. }
  578. else
  579. {
  580. return $keyc.str_replace('=', '', base64_encode($result));
  581. }
  582. }
  583. //字符串截取
  584. function str_cut($sourcestr,$cutlength,$suffix='...')
  585. {
  586. $str_length = strlen($sourcestr);
  587. if($str_length <= $cutlength) {
  588. return $sourcestr;
  589. }
  590. $returnstr='';
  591. $n = $i = $noc = 0;
  592. while($n < $str_length) {
  593. $t = ord($sourcestr[$n]);
  594. if($t == 9 || $t == 10 || (32 <= $t && $t <= 126)) {
  595. $i = 1; $n++; $noc++;
  596. } elseif(194 <= $t && $t <= 223) {
  597. $i = 2; $n += 2; $noc += 2;
  598. } elseif(224 <= $t && $t <= 239) {
  599. $i = 3; $n += 3; $noc += 2;
  600. } elseif(240 <= $t && $t <= 247) {
  601. $i = 4; $n += 4; $noc += 2;
  602. } elseif(248 <= $t && $t <= 251) {
  603. $i = 5; $n += 5; $noc += 2;
  604. } elseif($t == 252 || $t == 253) {
  605. $i = 6; $n += 6; $noc += 2;
  606. } else {
  607. $n++;
  608. }
  609. if($noc >= $cutlength) {
  610. break;
  611. }
  612. }
  613. if($noc > $cutlength) {
  614. $n -= $i;
  615. }
  616. $returnstr = substr($sourcestr, 0, $n);
  617. if ( substr($sourcestr, $n, 6)){
  618. $returnstr = $returnstr . $suffix;//超过长度时在尾处加上省略号
  619. }
  620. return $returnstr;
  621. }
  622. function IP($ip='',$file='UTFWry.dat') {
  623. import("@.ORG.IpLocation");
  624. $iplocation = new IpLocation($file);
  625. $location = $iplocation->getlocation($ip);
  626. return $location;
  627. }
  628. function byte_format($input, $dec=0)
  629. {
  630. $prefix_arr = array("B", "K", "M", "G", "T");
  631. $value = round($input, $dec);
  632. $i=0;
  633. while ($value>1024)
  634. {
  635. $value /= 1024;
  636. $i++;
  637. }
  638. $return_str = round($value, $dec).$prefix_arr[$i];
  639. return $return_str;
  640. }
  641. /**
  642. +----------------------------------------------------------
  643. * 获取登录验证码 默认为4位数字
  644. +----------------------------------------------------------
  645. * @param string $fmode 文件名
  646. +----------------------------------------------------------
  647. * @return string
  648. +----------------------------------------------------------
  649. */
  650. function build_verify ($length=4,$mode=1) {
  651. return rand_string($length,$mode);
  652. }
  653. function make_urlrule($url,$lang,$action,$MOREREQUEST=''){
  654. preg_match_all ("/{([\w\$]+)}/",$url, $matches);
  655. //$REQUEST= implode(',',$matches[0]);
  656. if(strstr($url,'{$parentdir') && C('URL_PATHINFO_DEPR')=='/'){
  657. if(APP_LANG){
  658. foreach((array)$lang as $r){
  659. $Category = F('Category_'.$r);
  660. foreach((array)$Category as $key =>$r){
  661. if($r['parentid']==0)$pcatdir[]=$r['catdir'];
  662. }
  663. }
  664. }else{
  665. $Category = F('Category');
  666. foreach((array)$Category as $key =>$r){
  667. if($r['parentid']==0)$pcatdir[]=$r['catdir'];
  668. }
  669. }
  670. unset($Category);
  671. $parent_rule = '('.implode('|',$pcatdir).')\/';
  672. //if(preg_match("/^[\w]+$/",$str)){ }
  673. }
  674. $REQUEST=str_replace(array('{$parentdir}','{$module}','{$moduleid}','{$catdir}','{$year}','{$month}','{$day}','{$catid}','{$id}','{$page}'),array('','module','moduleid','catdir','year','month','day','catid','id',C('VAR_PAGE')),$matches[0]);
  675. $rule=str_replace(array('{$parentdir}','{$module}','{$moduleid}','{$catdir}','{$year}','{$month}','{$day}','{$catid}','{$id}','{$page}','/',C('URL_HTML_SUFFIX')),array('','([A-Z]{1}[a-z]+)','(\d+)','([\w^_]+)','(\d+)','(\d+)','(\d+)','(\d+)','(\d+)','(\d+)','\/',''),$url);
  676. $i=0;$j=1;$k=2;$n=3;$m=4;
  677. foreach($REQUEST as $key =>$r){
  678. if($r){
  679. $i=$i+1;
  680. $request .=$r.'=:'.$i.'&';
  681. $j=$j+1;
  682. $request_lang .=$r.'=:'.$j.'&';
  683. $k=$k+1;
  684. $request_lang_2 .=$r.'=:'.$k.'&'; //二级
  685. $n=$n+1;
  686. $request_lang_3 .=$r.'=:'.$n.'&'; //三级
  687. }
  688. }
  689. if(APP_LANG){
  690. $langrule = '('.implode('|',$lang).')\/';
  691. if($parent_rule){
  692. $data[] = '\'/^'.$langrule.$parent_rule.'([\w^_]+)\/'.$rule.'$/\' => \'Urlrule/'.$action.'?l=:1&parentdir=:2&'.$request_lang_3.$MOREREQUEST.$langrequest.'\'';
  693. $data[] = '\'/^'.$langrule.$parent_rule.$rule.'$/\' => \'Urlrule/'.$action.'?l=:1&parentdir=:2&'.$request_lang_2.$MOREREQUEST.$langrequest.'\'';
  694. $data[] = '\'/^'.$parent_rule.'([\w^_]+)\/'.$rule.'$/\' => \'Urlrule/'.$action.'?parentdir=:1&'.$request_lang_2.$MOREREQUEST.$langrequest.'\'';
  695. $data[] = '\'/^'.$parent_rule.$rule.'$/\' => \'Urlrule/'.$action.'?parentdir=:1&'.$request_lang.$MOREREQUEST.$langrequest.'\'';
  696. if(strstr($url,'{$page')){
  697. $data[] = '\'/^'.$langrule.$parent_rule.'(\d+)$/\' => \'Urlrule/'.$action.'?l=:1&catdir=:2&p=:3\'';
  698. $data[] = '\'/^'.$parent_rule.'(\d+)$/\' => \'Urlrule/'.$action.'?catdir=:1&p=:2\'';
  699. }else{
  700. $data[] = '\'/^'.$langrule.$parent_rule.'$/\' => \'Urlrule/'.$action.'?l=:1&catdir=:2\'';
  701. $data[] = '\'/^'.$parent_rule.'$/\' => \'Urlrule/'.$action.'?catdir=:1\'';
  702. }
  703. }else{
  704. $data[] = '\'/^'.$langrule.$rule.'$/\' => \'Urlrule/'.$action.'?l=:1&'.$request_lang.$MOREREQUEST.$langrequest.'\'';
  705. $data[]='\'/^'.$rule.'$/\' => \'Urlrule/'.$action.'?'.$request.$MOREREQUEST.'\'';
  706. }
  707. $data = str_replace('\/$','$',$data);
  708. $data= implode(",\n",$data);
  709. }else{
  710. if($parent_rule){
  711. $data[] = '\'/^'.$parent_rule.'([\w^_]+)\/'.$rule.'$/\' => \'Urlrule/'.$action.'?parentdir=:1&'.$request_lang_2.$MOREREQUEST.$langrequest.'\'';
  712. $data[] = '\'/^'.$parent_rule.$rule.'$/\' => \'Urlrule/'.$action.'?parentdir=:1&'.$request_lang.$MOREREQUEST.$langrequest.'\'';
  713. if(strstr($url,'{$page')){
  714. $data[] = '\'/^'.$parent_rule.'(\d+)$/\' => \'Urlrule/'.$action.'?catdir=:1&p=:2\'';
  715. }else{
  716. $data[] = '\'/^'.$parent_rule.'$/\' => \'Urlrule/'.$action.'?catdir=:1\'';
  717. }
  718. }else{
  719. $urlrule='\'/^'.$rule.'$/\' => \'Urlrule/'.$action.'?'.$request.$MOREREQUEST.'\'';
  720. $data = str_replace('\/$','$',$urlrule);
  721. }
  722. }
  723. return $data;
  724. }
  725. function routes_cache($URL_URLRULE=''){
  726. $urlstr .= '\':l'.C('URL_PATHINFO_DEPR').'Tags'.C('URL_PATHINFO_DEPR').':module'.C('URL_PATHINFO_DEPR').':tag'.C('URL_PATHINFO_DEPR').':p\' => \'Home/Tags/index\','."\n";
  727. $urlstr .= '\':l'.C('URL_PATHINFO_DEPR').'Tags'.C('URL_PATHINFO_DEPR').':tag'.C('URL_PATHINFO_DEPR').':p\' => \'Home/Tags/index\','."\n";
  728. $urlstr .= '\':l'.C('URL_PATHINFO_DEPR').'Tags'.C('URL_PATHINFO_DEPR').':module'.C('URL_PATHINFO_DEPR').':tag\' => \'Home/Tags/index\','."\n";
  729. $urlstr .= '\':l'.C('URL_PATHINFO_DEPR').'Tags'.C('URL_PATHINFO_DEPR').':p\d\' => \'Home/Tags/index\','."\n";
  730. $urlstr .= '\':l'.C('URL_PATHINFO_DEPR').'Tags'.C('URL_PATHINFO_DEPR').':tag\' => \'Home/Tags/index\','."\n";
  731. $urlstr .= '\':l'.C('URL_PATHINFO_DEPR').'Tags\' => \'Home/Tags/index\','."\n";
  732. $urlstr .= '\'Tags'.C('URL_PATHINFO_DEPR').':module'.C('URL_PATHINFO_DEPR').':tag'.C('URL_PATHINFO_DEPR').':p\' => \'Home/Tags/index\','."\n";
  733. $urlstr .= '\'Tags'.C('URL_PATHINFO_DEPR').':tag'.C('URL_PATHINFO_DEPR').':p\' => \'Home/Tags/index\','."\n";
  734. $urlstr .= '\'Tags'.C('URL_PATHINFO_DEPR').':module'.C('URL_PATHINFO_DEPR').':tag\' => \'Home/Tags/index\','."\n";
  735. $urlstr .= '\'Tags'.C('URL_PATHINFO_DEPR').':p\d\' => \'Home/Tags/index\','."\n";
  736. $urlstr .= '\'Tags'.C('URL_PATHINFO_DEPR').':tag\' => \'Home/Tags/index\','."\n";
  737. $urlstr .= '\'Tags\' => \'Home/Tags/index\','."\n";
  738. /*
  739. $urlstr .= '\'^Tags$\' => \'Home/Tags/index\','."\n";
  740. $urlstr .= '\'/^Tags\/(\d+).html$/\' => \'Home/Tags/index?p=:1\','."\n";
  741. */
  742. if(APP_LANG){
  743. $Lang=F('Lang');
  744. foreach((array)$Lang as $key =>$r){$langarr[]=$key;}
  745. $urlstr .= '\'/^('.implode('|',$langarr).')$/\' => \'Index/index?l=:1\','."\n";
  746. }
  747. $URL_URLRULE = $URL_URLRULE ? $URL_URLRULE : C('URL_URLRULE');
  748. $urlrule = is_array($URL_URLRULE) ? $URL_URLRULE : explode(':::',$URL_URLRULE);
  749. $list=explode('|',$urlrule[1]);
  750. $show=explode('|',$urlrule[0]);
  751. $listurls[]= make_urlrule($show[1],$langarr,'show');
  752. $listurls[]= make_urlrule($show[0],$langarr,'show');
  753. $listurls[]= make_urlrule($list[1],$langarr,'index');
  754. $listurls[]= make_urlrule($list[0],$langarr,'index');
  755. $url = implode(",\n",$listurls);
  756. file_put_contents(DATA_PATH.'Routes.php', "<?php\nreturn array(\n" . $urlstr.$url . "\n);\n?>");
  757. if(is_file(RUNTIME_PATH.'~runtime.php'))@unlink(RUNTIME_PATH.'~runtime.php');
  758. if(is_file(RUNTIME_PATH.'~allinone.php'))@unlink(RUNTIME_PATH.'~allinone.php');
  759. }
  760. function HOMEURL($lang){
  761. if(C('URL_M')==1)$index='/index.php/';
  762. $lang= C('URL_LANG')!=$lang ? $lang : '';
  763. if(C('URL_M') > 0){
  764. $url =$lang ? __ROOT__.$index.$lang.'/' : __ROOT__.'/';
  765. }else{
  766. if(C('HOME_ISHTML')){
  767. $url = $lang ? '/'.$lang.'/' : '/';
  768. }else{
  769. $url =$lang ? __ROOT__.'/index.php?l='.$lang : __ROOT__.'/';
  770. }
  771. }
  772. return $url;
  773. }
  774. function URL($url='',$params=array()) {
  775. if(APP_LANG)$lang = getlang();
  776. if(!empty($url)){
  777. list($path, $query) = explode('?',$url);
  778. list($group, $a) = explode('/',$path);
  779. list($g, $m) = explode('-',$group);
  780. $params= http_build_query($params);
  781. $params = !empty($params) ? '&' . $params : '';
  782. $query = !empty($query) ? '&'.$query : '';
  783. //parse_str($_SERVER['QUERY_STRING'],$urlarr);
  784. if($lang) $langurl = '&l='.$lang;
  785. if (strcasecmp($g,'Home')== 0){
  786. $url = __ROOT__.'/index.php?m='.$m.'&a='.$a.$query.$params.$langurl;
  787. }else{
  788. $url = __ROOT__.'/index.php?g='.$g.'&m='.$m.'&a='.$a.$query.$params.$langurl;
  789. }
  790. }else{
  791. if(C('URL_M')==1)$index='/index.php/';
  792. if(C('URL_M') > 0){
  793. $url = $lang ? __ROOT__.$index.$lang.'/' : __ROOT__.'/';
  794. }else{
  795. $url = $lang ? __ROOT__.'/index.php?l='.$lang : __ROOT__.'/';
  796. }
  797. }
  798. return $url;
  799. }
  800. function TAGURL($data,$p=''){
  801. $index= C('URL_M')==1 ? __ROOT__.'index.php/' : __ROOT__.'/';
  802. if(APP_LANG)$lang=getlang();
  803. if(C('URL_M')==0){
  804. if($data['moduleid'] > 0 && $data['moduleid']!=2) $params['moduleid']=$data['moduleid'] ;
  805. if($data['slug']) $params['tag']=$data['slug'] ;
  806. if($lang)$params['l']=$lang;
  807. $url=URL('Home-Tags/index',$params);
  808. if($p)$url=$url.'&p={$page}';
  809. }else{
  810. $tag = $data['slug'] ? '/'.$data['slug'] : '';
  811. $module = ($data['moduleid'] > 0 && $data['moduleid']!=2) ? '/'.$data['module'] : '';
  812. $langurl = $lang ? $lang.'/' : '' ;
  813. $url=$index.$langurl.'Tags'.$module.$tag.'/';
  814. if($p)$url=$url.'{$page}'.C('URL_HTML_SUFFIX');
  815. }
  816. return $url;
  817. }
  818. function getlang($have=''){
  819. if($have){
  820. if(strcasecmp(GROUP_NAME,'Admin')== 0)
  821. $lang = LANG_NAME;
  822. else
  823. $lang = $_REQUEST['l'] ? $_REQUEST['l'] : C('URL_LANG');
  824. }else{
  825. if(strcasecmp(GROUP_NAME,'Admin')== 0)
  826. $lang = C('URL_LANG')!= LANG_NAME ? LANG_NAME : '';
  827. else
  828. $lang = $_REQUEST['l'] && C('URL_LANG')!=$_REQUEST['l'] ? $_REQUEST['l'] : '';
  829. }
  830. return $lang;
  831. }
  832. function geturl($cat,$data='',$Urlrule=''){
  833. //$Urlrule =F('Urlrule');
  834. $id=$data['id'];
  835. $URL_MODEL =C('URL_M');
  836. if(APP_LANG)$lang = getlang();
  837. $parentdir = $cat['parentdir'];
  838. $catdir = $cat['catdir'];
  839. $year = date('Y',$data['createtime']);
  840. $month = date('m',$data['createtime']);
  841. $day = date('d',$data['createtime']);
  842. $module = $cat['module'];
  843. $moduleid =$cat['moduleid'];
  844. $catid=$cat['id'];
  845. if($cat['ishtml']){
  846. if($cat['urlruleid'] && $Urlrule){
  847. $showurlrule = $Urlrule[$cat['urlruleid']]['showurlrule'];
  848. $listurlrule = $Urlrule[$cat['urlruleid']]['listurlrule'];
  849. }else{
  850. echo 'This cat has not urlruleid or no Urlrule.';exit;
  851. }
  852. }else{
  853. if($URL_MODEL==0){
  854. $langurl = $lang ? '&l='.LANG_NAME : '';
  855. if($id){
  856. $url[] = U("Home/$cat[module]/show?id=$id".$langurl);
  857. $url[] = U("Home/$cat[module]/show?id=".$id.$langurl.'&'.C('VAR_PAGE').'={$page}');
  858. }else{
  859. $url[] = U("Home/$cat[module]/index?id=$cat[id]".$langurl);
  860. $url[] = U("Home/$cat[module]/index?id=$cat[id]$langurl&".C('VAR_PAGE').'={$page}');
  861. }
  862. $urls = str_replace('g=Admin&','',$url);
  863. $urls = str_replace('g=Home&','',$url);
  864. }else{
  865. $urlrule = explode(':::',C('URL_URLRULE'));
  866. $showurlrule = $urlrule[0];
  867. $listurlrule = $urlrule[1];
  868. }
  869. }
  870. if(empty($urls)){
  871. $index = $URL_MODEL==1 ? __ROOT__.'/index.php/' : __ROOT__.'/';
  872. $langurl = $lang ? $lang.'/' : '';
  873. if($id){
  874. $urls = str_replace(array('{$parentdir}','{$module}','{$moduleid}','{$catdir}','{$year}','{$month}','{$day}','{$catid}','{$id}'),array($parentdir,$module,$moduleid,$catdir,$year,$month,$day,$catid,$id),$showurlrule);
  875. }else{
  876. $urls = str_replace(array('{$parentdir}','{$module}','{$moduleid}','{$catdir}','{$year}','{$month}','{$day}','{$catid}','{$id}'),array($parentdir,$module,$moduleid,$catdir,$year,$month,$day,$catid,$id),$listurlrule);
  877. }
  878. $urls = explode('|',$urls);
  879. $urls[0]=$index.$langurl.$urls[0];
  880. $urls[1]=$index.$langurl.$urls[1];
  881. }
  882. return $urls;
  883. }
  884. function content_pages($num, $p,$pageurls) {
  885. $multipage = '';
  886. $page = 11;
  887. $offset = 4;
  888. $pages = $num;
  889. $from = $p - $offset;
  890. $to = $p + $offset;
  891. $more = 0;
  892. if($page >= $pages) {
  893. $from = 2;
  894. $to = $pages-1;
  895. } else {
  896. if($from <= 1) {
  897. $to = $page-1;
  898. $from = 2;
  899. } elseif($to >= $pages) {
  900. $from = $pages-($page-2);
  901. $to = $pages-1;
  902. }
  903. $more = 1;
  904. }
  905. if($p>0) {
  906. $perpage = $p == 1 ? 1 : $p-1;
  907. if($perpage==1){
  908. $multipage .= '<a class="a1" href="'.$pageurls[$perpage][0].'">'.L('previous').'</a>';
  909. }else{
  910. $multipage .= '<a class="a1" href="'.$pageurls[$perpage][1].'">'.L('previous').'</a>';
  911. }
  912. if($p==1) {
  913. $multipage .= ' <span>1</span>';
  914. } elseif($p>6 && $more) {
  915. $multipage .= ' <a href="'.$pageurls[1][0].'">1</a>..';
  916. } else {
  917. $multipage .= ' <a href="'.$pageurls[1][0].'">1</a>';
  918. }
  919. }
  920. for($i = $from; $i <= $to; $i++) {
  921. if($i != $p) {
  922. $multipage .= ' <a href="'.$pageurls[$i][1].'">'.$i.'</a>';
  923. } else {
  924. $multipage .= ' <span>'.$i.'</span>';
  925. }
  926. }
  927. if($p<$pages) {
  928. if($p<$pages-5 && $more) {
  929. $multipage .= ' ..<a href="'.$pageurls[$pages][1].'">'.$pages.'</a> <a class="a1" href="'.$pageurls[$p+1][1].'">'.L('next').'</a>';
  930. } else {
  931. $multipage .= ' <a href="'.$pageurls[$pages][1].'">'.$pages.'</a> <a class="a1" href="'.$pageurls[$p+1][1].'">'.L('next').'</a>';
  932. }
  933. } elseif($p==$pages) {
  934. $multipage .= ' <span>'.$pages.'</span> <a class="a1" href="'.$pageurls[$p][1].'">'.L('next').'</a>';
  935. }
  936. return $multipage;
  937. }
  938. function thumb($f, $tw=300, $th=300 ,$autocat=0, $nopic = 'nopic.jpg',$t=''){
  939. if(strstr($f,'://')) return $f;
  940. if(empty($f)) return __ROOT__.'/Public/Images/'.$nopic;
  941. $f= '.'.str_replace(__ROOT__,'',$f);
  942. $temp = array(1=>'gif', 2=>'jpeg', 3=>'png');
  943. list($fw, $fh, $tmp) = getimagesize($f);
  944. if(empty($t)){
  945. if($fw>$tw && $fh>$th){
  946. $pathinfo = pathinfo($f);
  947. $t = $pathinfo['dirname'].'/thumb_'.$tw.'_'.$th.'_'.$pathinfo['basename'];
  948. if(is_file($t)){
  949. return __ROOT__.substr($t,1);
  950. }
  951. }else{
  952. return __ROOT__.substr($f,1);
  953. }
  954. }
  955. if(!$temp[$tmp]){ return false; }
  956. if($autocat){
  957. if($fw/$tw > $fh/$th){
  958. $fw = $tw * ($fh/$th);
  959. }else{
  960. $fh = $th * ($fw/$tw);
  961. }
  962. }else{
  963. $scale = min($tw/$fw, $th/$fh); // 计算缩放比例
  964. if($scale>=1) {
  965. // 超过原图大小不再缩略
  966. $tw = $fw;
  967. $th = $fh;
  968. }else{
  969. // 缩略图尺寸
  970. $tw = (int)($fw*$scale);
  971. $th = (int)($fh*$scale);
  972. }
  973. }
  974. $tmp = $temp[$tmp];
  975. $infunc = "imagecreatefrom$tmp";
  976. $outfunc = "image$tmp";
  977. $fimg = $infunc($f);
  978. if($tmp != 'gif' && function_exists('imagecreatetruecolor')){
  979. $timg = imagecreatetruecolor($tw, $th);
  980. }else{
  981. $timg = imagecreate($tw, $th);
  982. }
  983. if(function_exists('imagecopyresampled'))
  984. imagecopyresampled($timg, $fimg, 0,0, 0,0, $tw,$th, $fw,$fh);
  985. else
  986. imagecopyresized($timg, $fimg, 0,0, 0,0, $tw,$th, $fw,$fh);
  987. if($tmp=='gif' || $tmp=='png') {
  988. $background_color = imagecolorallocate($timg, 0, 255, 0); // 指派一个绿色
  989. imagecolortransparent($timg, $background_color); // 设置为透明色,若注释掉该行则输出绿色的图
  990. }
  991. $outfunc($timg, $t);
  992. imagedestroy($timg);
  993. imagedestroy($fimg);
  994. return __ROOT__.substr($t,1);
  995. }
  996. /*!
  997. * ubb2html support for php
  998. * @requires xhEditor
  999. *
  1000. * @author Yanis.Wang<yanis.wang@gmail.com>
  1001. * @site http://xheditor.com/
  1002. * @licence LGPL(http://www.opensource.org/licenses/lgpl-license.php)
  1003. *
  1004. * @Version: 0.9.10 (build 110801)
  1005. */
  1006. function ubb2html($sUBB)
  1007. {
  1008. $sHtml=$sUBB;
  1009. global $emotPath,$cnum,$arrcode,$bUbb2htmlFunctionInit;$cnum=0;$arrcode=array();
  1010. $emotPath='../xheditor_emot/';//表情根路径
  1011. if(!$bUbb2htmlFunctionInit){
  1012. function saveCodeArea($match)
  1013. {
  1014. global $cnum,$arrcode;
  1015. $cnum++;$arrcode[$cnum]=$match[0];
  1016. return "[\tubbcodeplace_".$cnum."\t]";
  1017. }}
  1018. $sHtml=preg_replace_callback('/\[code\s*(?:=\s*((?:(?!")[\s\S])+?)(?:"[\s\S]*?)?)?\]([\s\S]*?)\[\/code\]/i','saveCodeArea',$sHtml);
  1019. $sHtml=preg_replace("/&/",'&amp;',$sHtml);
  1020. $sHtml=preg_replace("/</",'&lt;',$sHtml);
  1021. $sHtml=preg_replace("/>/",'&gt;',$sHtml);
  1022. $sHtml=preg_replace("/\r?\n/",'<br />',$sHtml);
  1023. $sHtml=preg_replace("/\[(\/?)(b|u|i|s|sup|sub)\]/i",'<$1$2>',$sHtml);
  1024. $sHtml=preg_replace('/\[color\s*=\s*([^\]"]+?)(?:"[^\]]*?)?\s*\]/i','<span style="color:$1;">',$sHtml);
  1025. if(!$bUbb2htmlFunctionInit){
  1026. function getSizeName($match)
  1027. {
  1028. $arrSize=array('10px','13px','16px','18px','24px','32px','48px');
  1029. if(preg_match("/^\d+$/",$match[1]))$match[1]=$arrSize[$match[1]-1];
  1030. return '<span style="font-size:'.$match[1].';">';
  1031. }}
  1032. $sHtml=preg_replace_callback('/\[size\s*=\s*([^\]"]+?)(?:"[^\]]*?)?\s*\]/i','getSizeName',$sHtml);
  1033. $sHtml=preg_replace('/\[font\s*=\s*([^\]"]+?)(?:"[^\]]*?)?\s*\]/i','<span style="font-family:$1;">',$sHtml);
  1034. $sHtml=preg_replace('/\[back\s*=\s*([^\]"]+?)(?:"[^\]]*?)?\s*\]/i','<span style="background-color:$1;">',$sHtml);
  1035. $sHtml=preg_replace("/\[\/(color|size|font|back)\]/i",'</span>',$sHtml);
  1036. for($i=0;$i<3;$i++)$sHtml=preg_replace('/\[align\s*=\s*([^\]"]+?)(?:"[^\]]*?)?\s*\](((?!\[align(?:\s+[^\]]+)?\])[\s\S])*?)\[\/align\]/','<p align="$1">$2</p>',$sHtml);
  1037. $sHtml=preg_replace('/\[img\]\s*(((?!")[\s\S])+?)(?:"[\s\S]*?)?\s*\[\/img\]/i','<img src="$1" alt="" />',$sHtml);
  1038. if(!$bUbb2htmlFunctionInit){
  1039. function getImg($match)
  1040. {
  1041. $alt=$match[1];$p1=$match[2];$p2=$match[3];$p3=$match[4];$src=$match[5];
  1042. $a=$p3?$p3:(!is_numeric($p1)?$p1:'');
  1043. return '<img src="'.$src.'" alt="'.$alt.'"'.(is_numeric($p1)?' width="'.$p1.'"':'').(is_numeric($p2)?' height="'.$p2.'"':'').($a?' align="'.$a.'"':'').' />';
  1044. }}
  1045. $sHtml=preg_replace_callback('/\[img\s*=([^,\]]*)(?:\s*,\s*(\d*%?)\s*,\s*(\d*%?)\s*)?(?:,?\s*(\w+))?\s*\]\s*(((?!")[\s\S])+?)(?:"[\s\S]*)?\s*\[\/img\]/i','getImg',$sHtml);
  1046. if(!$bUbb2htmlFunctionInit){
  1047. function getEmot($match)
  1048. {
  1049. global $emotPath;
  1050. $arr=split(',',$match[1]);
  1051. if(!isset($arr[1])){$arr[1]=$arr[0];$arr[0]='default';}
  1052. $path=$emotPath.$arr[0].'/'.$arr[1].'.gif';
  1053. return '<img src="'.$path.'" alt="'.$arr[1].'" />';
  1054. }}
  1055. $sHtml=preg_replace_callback('/\[emot\s*=\s*([^\]"]+?)(?:"[^\]]*?)?\s*\/\]/i','getEmot',$sHtml);
  1056. $sHtml=preg_replace('/\[url\]\s*(((?!")[\s\S])*?)(?:"[\s\S]*?)?\s*\[\/url\]/i','<a href="$1">$1</a>',$sHtml);
  1057. $sHtml=preg_replace('/\[url\s*=\s*([^\]"]+?)(?:"[^\]]*?)?\s*\]\s*([\s\S]*?)\s*\[\/url\]/i','<a href="$1">$2</a>',$sHtml);
  1058. $sHtml=preg_replace('/\[email\]\s*(((?!")[\s\S])+?)(?:"[\s\S]*?)?\s*\[\/email\]/i','<a href="mailto:$1">$1</a>',$sHtml);
  1059. $sHtml=preg_replace('/\[email\s*=\s*([^\]"]+?)(?:"[^\]]*?)?\s*\]\s*([\s\S]+?)\s*\[\/email\]/i','<a href="mailto:$1">$2</a>',$sHtml);
  1060. $sHtml=preg_replace("/\[quote\]([\s\S]*?)\[\/quote\]/i",'<blockquote>$1</blockquote>',$sHtml);
  1061. if(!$bUbb2htmlFunctionInit){
  1062. function getFlash($match)
  1063. {
  1064. $w=$match[1];$h=$match[2];$url=$match[3];
  1065. if(!$w)$w=480;if(!$h)$h=400;
  1066. return '<embed type="application/x-shockwave-flash" src="'.$url.'" wmode="opaque" quality="high" bgcolor="#ffffff" menu="false" play="true" loop="true" width="'.$w.'" height="'.$h.'" />';
  1067. }}
  1068. $sHtml=preg_replace_callback('/\[flash\s*(?:=\s*(\d+)\s*,\s*(\d+)\s*)?\]\s*(((?!")[\s\S])+?)(?:"[\s\S]*?)?\s*\[\/flash\]/i','getFlash',$sHtml);
  1069. if(!$bUbb2htmlFunctionInit){
  1070. function getMedia($match)
  1071. {
  1072. $w=$match[1];$h=$match[2];$play=$match[3];$url=$match[4];
  1073. if(!$w)$w=480;if(!$h)$h=400;
  1074. return '<embed type="application/x-mplayer2" src="'.$url.'" enablecontextmenu="false" autostart="'.($play=='1'?'true':'false').'" width="'.$w.'" height="'.$h.'" />';
  1075. }}
  1076. $sHtml=preg_replace_callback('/\[media\s*(?:=\s*(\d+)\s*,\s*(\d+)\s*(?:,\s*(\d+)\s*)?)?\]\s*(((?!")[\s\S])+?)(?:"[\s\S]*?)?\s*\[\/media\]/i','getMedia',$sHtml);
  1077. if(!$bUbb2htmlFunctionInit){
  1078. function getTable($match)
  1079. {
  1080. return '<table'.(isset($match[1])?' width="'.$match[1].'"':'').(isset($match[2])?' bgcolor="'.$match[2].'"':'').'>';
  1081. }}
  1082. $sHtml=preg_replace_callback('/\[table\s*(?:=(\d{1,4}%?)\s*(?:,\s*([^\]"]+)(?:"[^\]]*?)?)?)?\s*\]/i','getTable',$sHtml);
  1083. if(!$bUbb2htmlFunctionInit){
  1084. function getTR($match){return '<tr'.(isset($match[1])?' bgcolor="'.$match[1].'"':'').'>';}}
  1085. $sHtml=preg_replace_callback('/\[tr\s*(?:=(\s*[^\]"]+))?(?:"[^\]]*?)?\s*\]/i','getTR',$sHtml);
  1086. if(!$bUbb2htmlFunctionInit){
  1087. function getTD($match){
  1088. $col=isset($match[1])?$match[1]:0;$row=isset($match[2])?$match[2]:0;$w=isset($match[3])?$match[3]:null;
  1089. return '<td'.($col>1?' colspan="'.$col.'"':'').($row>1?' rowspan="'.$row.'"':'').($w?' width="'.$w.'"':'').'>';
  1090. }}
  1091. $sHtml=preg_replace_callback("/\[td\s*(?:=\s*(\d{1,2})\s*,\s*(\d{1,2})\s*(?:,\s*(\d{1,4}%?))?)?\s*\]/i",'getTD',$sHtml);
  1092. $sHtml=preg_replace("/\[\/(table|tr|td)\]/i",'</$1>',$sHtml);
  1093. $sHtml=preg_replace("/\[\*\]((?:(?!\[\*\]|\[\/list\]|\[list\s*(?:=[^\]]+)?\])[\s\S])+)/i",'<li>$1</li>',$sHtml);
  1094. if(!$bUbb2htmlFunctionInit){
  1095. function getUL($match)
  1096. {
  1097. $str='<ul';
  1098. if(isset($match[1]))$str.=' type="'.$match[1].'"';
  1099. return $str.'>';
  1100. }}
  1101. $sHtml=preg_replace_callback('/\[list\s*(?:=\s*([^\]"]+))?(?:"[^\]]*?)?\s*\]/i','getUL',$sHtml);
  1102. $sHtml=preg_replace("/\[\/list\]/i",'</ul>',$sHtml);
  1103. $sHtml=preg_replace("/\[hr\/\]/i",'<hr />',$sHtml);
  1104. for($i=1;$i<=$cnum;$i++)$sHtml=str_replace("[\tubbcodeplace_".$i."\t]", $arrcode[$i],$sHtml);
  1105. if(!$bUbb2htmlFunctionInit){
  1106. function fixText($match)
  1107. {
  1108. $text=$match[2];
  1109. $text=preg_replace("/\t/",'&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;',$text);
  1110. $text=preg_replace("/ /",'&nbsp;',$text);
  1111. return $match[1].$text;
  1112. }}
  1113. $sHtml=preg_replace_callback('/(^|<\/?\w+(?:\s+[^>]*?)?>)([^<$]+)/i','fixText',$sHtml);
  1114. $bUbb2htmlFunctionInit=true;
  1115. return $sHtml;
  1116. }
  1117. function Pinyin($_String) {
  1118. $_DataKey = "a|ai|an|ang|ao|ba|bai|ban|bang|bao|bei|ben|beng|bi|bian|biao|bie|bin|bing|bo|bu|ca|cai|can|cang|cao|ce|ceng|cha".
  1119. "|chai|chan|chang|chao|che|chen|cheng|chi|chong|chou|chu|chuai|chuan|chuang|chui|chun|chuo|ci|cong|cou|cu|".
  1120. "cuan|cui|cun|cuo|da|dai|dan|dang|dao|de|deng|di|dian|diao|die|ding|diu|dong|dou|du|duan|dui|dun|duo|e|en|er".
  1121. "|fa|fan|fang|fei|fen|feng|fo|fou|fu|ga|gai|gan|gang|gao|ge|gei|gen|geng|gong|gou|gu|gua|guai|guan|guang|gui".
  1122. "|gun|guo|ha|hai|han|hang|hao|he|hei|hen|heng|hong|hou|hu|hua|huai|huan|huang|hui|hun|huo|ji|jia|jian|jiang".
  1123. "|jiao|jie|jin|jing|jiong|jiu|ju|juan|jue|jun|ka|kai|kan|kang|kao|ke|ken|keng|kong|kou|ku|kua|kuai|kuan|kuang".
  1124. "|kui|kun|kuo|la|lai|lan|lang|lao|le|lei|leng|li|lia|lian|liang|liao|lie|lin|ling|liu|long|lou|lu|lv|luan|lue".
  1125. "|lun|luo|ma|mai|man|mang|mao|me|mei|men|meng|mi|mian|miao|mie|min|ming|miu|mo|mou|mu|na|nai|nan|nang|nao|ne".
  1126. "|nei|nen|neng|ni|nian|niang|niao|nie|nin|ning|niu|nong|nu|nv|nuan|nue|nuo|o|ou|pa|pai|pan|pang|pao|pei|pen".
  1127. "|peng|pi|pian|piao|pie|pin|ping|po|pu|qi|qia|qian|qiang|qiao|qie|qin|qing|qiong|qiu|qu|quan|que|qun|ran|rang".
  1128. "|rao|re|ren|reng|ri|rong|rou|ru|ruan|rui|run|ruo|sa|sai|san|sang|sao|se|sen|seng|sha|shai|shan|shang|shao|".
  1129. "she|shen|sheng|shi|shou|shu|shua|shuai|shuan|shuang|shui|shun|shuo|si|song|sou|su|suan|sui|sun|suo|ta|tai|".
  1130. "tan|tang|tao|te|teng|ti|tian|tiao|tie|ting|tong|tou|tu|tuan|tui|tun|tuo|wa|wai|wan|wang|wei|wen|weng|wo|wu".
  1131. "|xi|xia|xian|xiang|xiao|xie|xin|xing|xiong|xiu|xu|xuan|xue|xun|ya|yan|yang|yao|ye|yi|yin|ying|yo|yong|you".
  1132. "|yu|yuan|yue|yun|za|zai|zan|zang|zao|ze|zei|zen|zeng|zha|zhai|zhan|zhang|zhao|zhe|zhen|zheng|zhi|zhong|".
  1133. "zhou|zhu|zhua|zhuai|zhuan|zhuang|zhui|zhun|zhuo|zi|zong|zou|zu|zuan|zui|zun|zuo";
  1134. $_DataValue = "-20319|-20317|-20304|-20295|-20292|-20283|-20265|-20257|-20242|-20230|-20051|-20036|-20032|-20026|-20002|-19990".
  1135. "|-19986|-19982|-19976|-19805|-19784|-19775|-19774|-19763|-19756|-19751|-19746|-19741|-19739|-19728|-19725".
  1136. "|-19715|-19540|-19531|-19525|-19515|-19500|-19484|-19479|-19467|-19289|-19288|-19281|-19275|-19270|-19263".
  1137. "|-19261|-19249|-19243|-19242|-19238|-19235|-19227|-19224|-19218|-19212|-19038|-19023|-19018|-19006|-19003".
  1138. "|-18996|-18977|-18961|-18952|-18783|-18774|-18773|-18763|-18756|-18741|-18735|-18731|-18722|-18710|-18697".
  1139. "|-18696|-18526|-18518|-18501|-18490|-18478|-18463|-18448|-18447|-18446|-18239|-18237|-18231|-18220|-18211".
  1140. "|-18201|-18184|-18183|-18181|-18012|-17997|-17988|-17970|-17964|-17961|-17950|-17947|-17931|-17928|-17922".
  1141. "|-17759|-17752|-17733|-17730|-17721|-17703|-17701|-17697|-17692|-17683|-17676|-17496|-17487|-17482|-17468".
  1142. "|-17454|-17433|-17427|-17417|-17202|-17185|-16983|-16970|-16942|-16915|-16733|-16708|-16706|-16689|-16664".
  1143. "|-16657|-16647|-16474|-16470|-16465|-16459|-16452|-16448|-16433|-16429|-16427|-16423|-16419|-16412|-16407".
  1144. "|-16403|-16401|-16393|-16220|-16216|-16212|-16205|-16202|-16187|-16180|-16171|-16169|-16158|-16155|-15959".
  1145. "|-15958|-15944|-15933|-15920|-15915|-15903|-15889|-15878|-15707|-15701|-15681|-15667|-15661|-15659|-15652".
  1146. "|-15640|-15631|-15625|-15454|-15448|-15436|-15435|-15419|-15416|-15408|-15394|-15385|-15377|-15375|-15369".
  1147. "|-15363|-15362|-15183|-15180|-15165|-15158|-15153|-15150|-15149|-15144|-15143|-15141|-15140|-15139|-15128".
  1148. "|-15121|-15119|-15117|-15110|-15109|-14941|-14937|-14933|-14930|-14929|-14928|-14926|-14922|-14921|-14914".
  1149. "|-14908|-14902|-14894|-14889|-14882|-14873|-14871|-14857|-14678|-14674|-14670|-14668|-14663|-14654|-14645".
  1150. "|-14630|-14594|-14429|-14407|-14399|-14384|-14379|-14368|-14355|-14353|-14345|-14170|-14159|-14151|-14149".
  1151. "|-14145|-14140|-14137|-14135|-14125|-14123|-14122|-14112|-14109|-14099|-14097|-14094|-14092|-14090|-14087".
  1152. "|-14083|-13917|-13914|-13910|-13907|-13906|-13905|-13896|-13894|-13878|-13870|-13859|-13847|-13831|-13658".
  1153. "|-13611|-13601|-13406|-13404|-13400|-13398|-13395|-13391|-13387|-13383|-13367|-13359|-13356|-13343|-13340".
  1154. "|-13329|-13326|-13318|-13147|-13138|-13120|-13107|-13096|-13095|-13091|-13076|-13068|-13063|-13060|-12888".
  1155. "|-12875|-12871|-12860|-12858|-12852|-12849|-12838|-12831|-12829|-12812|-12802|-12607|-12597|-12594|-12585".
  1156. "|-12556|-12359|-12346|-12320|-12300|-12120|-12099|-12089|-12074|-12067|-12058|-12039|-11867|-11861|-11847".
  1157. "|-11831|-11798|-11781|-11604|-11589|-11536|-11358|-11340|-11339|-11324|-11303|-11097|-11077|-11067|-11055".
  1158. "|-11052|-11045|-11041|-11038|-11024|-11020|-11019|-11018|-11014|-10838|-10832|-10815|-10800|-10790|-10780".
  1159. "|-10764|-10587|-10544|-10533|-10519|-10331|-10329|-10328|-10322|-10315|-10309|-10307|-10296|-10281|-10274".
  1160. "|-10270|-10262|-10260|-10256|-10254";
  1161. $_TDataKey = explode('|', $_DataKey);
  1162. $_TDataValue = explode('|', $_DataValue);
  1163. $_Data = array_combine($_TDataKey, $_TDataValue);
  1164. arsort($_Data);
  1165. reset($_Data);
  1166. $_String= auto_charset($_String,'utf-8','gbk');
  1167. $_Res = '';
  1168. for($i=0; $i<strlen($_String); $i++) {
  1169. $_P = ord(substr($_String, $i, 1));
  1170. if($_P>160) { $_Q = ord(substr($_String, ++$i, 1)); $_P = $_P*256 + $_Q - 65536; }
  1171. $_Res .= _Pinyin($_P, $_Data);
  1172. }
  1173. return preg_replace("/[^a-z0-9]*/", '', $_Res);
  1174. }
  1175. // 自动转换字符集 支持数组转换
  1176. function auto_charset($fContents, $from='gbk', $to='utf-8') {
  1177. $from = strtoupper($from) == 'UTF8' ? 'utf-8' : $from;
  1178. $to = strtoupper($to) == 'UTF8' ? 'utf-8' : $to;
  1179. if (strtoupper($from) === strtoupper($to) || empty($fContents) || (is_scalar($fContents) && !is_string($fContents))) {
  1180. //如果编码相同或者非字符串标量则不转换
  1181. return $fContents;
  1182. }
  1183. if (is_string($fContents)) {
  1184. if (function_exists('mb_convert_encoding')) {
  1185. return mb_convert_encoding($fContents, $to, $from);
  1186. } elseif (function_exists('iconv')) {
  1187. return iconv($from, $to, $fContents);
  1188. } else {
  1189. return $fContents;
  1190. }
  1191. } elseif (is_array($fContents)) {
  1192. foreach ($fContents as $key => $val) {
  1193. $_key = auto_charset($key, $from, $to);
  1194. $fContents[$_key] = auto_charset($val, $from, $to);
  1195. if ($key != $_key)
  1196. unset($fContents[$key]);
  1197. }
  1198. return $fContents;
  1199. }
  1200. else {
  1201. return $fContents;
  1202. }
  1203. }
  1204. function _Pinyin($_Num, $_Data) {
  1205. if ($_Num>0 && $_Num<160 ) return chr($_Num);
  1206. elseif($_Num<-20319 || $_Num>-10247) return '';
  1207. else {
  1208. foreach($_Data as $k=>$v){ if($v<=$_Num) break; }
  1209. return $k;
  1210. }
  1211. }
  1212. function return_url($code){
  1213. $config = APP_LANG ? F('Config_'.LANG_NAME) : F('Config');
  1214. return $config['site_url'].'/index.php?g=User&m=Pay&a=respond&code='.$code;
  1215. }
  1216. function order_pay_status($sn,$value){
  1217. $cart['status'] =1;
  1218. $cart['pay_status'] =$value;
  1219. if($value==2)$cart['pay_time'] =time();
  1220. $r = M('Order')->where("sn='{$sn}'")->save($cart);
  1221. return $r;
  1222. }
  1223. function addslashes_array($array){
  1224. if(get_magic_quotes_gpc())return $array;
  1225. if(!is_array($array))return addslashes($array);
  1226. foreach($array as $k => $val) $array[$k] = addslashes_array($val);
  1227. return $array;
  1228. }
  1229. function stripslashes_array($array) {
  1230. if(!is_array($array)) return stripslashes($array);
  1231. foreach($array as $k => $val) $array[$k] = stripslashes_array($val);
  1232. return $array;
  1233. }
  1234. function htmlspecialchars_array($array) {
  1235. if(!is_array($array)) return htmlspecialchars($array,ENT_QUOTES);
  1236. foreach($array as $k => $val) $array[$k] = htmlspecialchars_array($val);
  1237. return $array;
  1238. }
  1239. function safe_replace($string) {
  1240. $string = trim($string);
  1241. $string = str_replace(array('\\',';','\'','%2527','%27','%20','&', '"', '<', '>'), array('','','','','','','&amp;', '&quot;', '&lt;', '&gt;'), $string);
  1242. $string=nl2br($string);
  1243. return $string;
  1244. }
  1245. function get_safe_replace($array){
  1246. if(!is_array($array)) return safe_replace(strip_tags($array));
  1247. foreach($array as $k => $val) $array[$k] = get_safe_replace($val);
  1248. return $array;
  1249. }
  1250. function sql_split($sql,$tablepre) {
  1251. if($tablepre != "aina_") $sql = str_replace("aina_", $tablepre, $sql);
  1252. //$sql = preg_replace("/TYPE=(InnoDB|MyISAM|MEMORY)( DEFAULT CHARSET=[^; ]+)?/", "ENGINE=\\1 DEFAULT CHARSET=utf8",$sql);
  1253. if($r_tablepre != $s_tablepre) $sql = str_replace($s_tablepre, $r_tablepre, $sql);
  1254. $sql = str_replace("\r", "\n", $sql);
  1255. $ret = array();
  1256. $num = 0;
  1257. $queriesarray = explode(";\n", trim($sql));
  1258. unset($sql);
  1259. foreach($queriesarray as $query)
  1260. {
  1261. $ret[$num] = '';
  1262. $queries = explode("\n", trim($query));
  1263. $queries = array_filter($queries);
  1264. foreach($queries as $query)
  1265. {
  1266. $str1 = substr($query, 0, 1);
  1267. if($str1 != '#' && $str1 != '-') $ret[$num] .= $query;
  1268. }
  1269. $num++;
  1270. }
  1271. return $ret;
  1272. }
  1273. function prevnext($mod,$id,$catid,$num=''){
  1274. $prev = D($mod)->where("id < $id and catid = $catid")->order("id desc")->find();
  1275. $next = D($mod)->where("id > $id and catid = $catid")->order("id asc")->find();
  1276. if(!$prev){
  1277. $prev[content] = '没有了';
  1278. }else{
  1279. if($num){
  1280. $prev[sort_title] = str_cut($prev[title],$num);
  1281. }else{
  1282. $prev[sort_title] = $prev[title];
  1283. }
  1284. $prev[content] = '<a href="'.$prev[url].'" title="'.$prev[title].'">'.$prev[sort_title].'</a>';
  1285. }
  1286. if(!$next){
  1287. $next[content] = '没有了';
  1288. }else{
  1289. if($num){
  1290. $next[sort_title] = str_cut($next[title],$num);
  1291. }else{
  1292. $next[sort_title] = $next[title];
  1293. }
  1294. $next[content] = '<a href="'.$next[url].'" title="'.$next[title].'">'.$next[sort_title].'</a>';
  1295. }
  1296. $prevnext = "<p class=\"fl\">上一篇:$prev[content]</p><p class=\"fr\">下一篇:$next[content]</p>";
  1297. return $prevnext;
  1298. }
  1299. //导出excel功能
  1300. function exportexcel($data=array(),$title=array(),$filename='report'){
  1301. header("Content-type:application/octet-stream");
  1302. header("Accept-Ranges:bytes");
  1303. header("Content-type:application/vnd.ms-excel");
  1304. header("Content-Disposition:attachment;filename=".$filename.".xls");
  1305. header("Pragma: no-cache");
  1306. header("Expires: 0");
  1307. //导出xls 开始
  1308. if (!empty($title)){
  1309. foreach ($title as $k => $v) {
  1310. $title[$k]=iconv("UTF-8", "GB2312",$v);
  1311. }
  1312. $title= implode("\t", $title);
  1313. echo "$title\n";
  1314. }
  1315. if (!empty($data)){
  1316. foreach($data as $key=>$val){
  1317. foreach ($val as $ck => $cv) {
  1318. $data[$key][$ck]=iconv("UTF-8", "GB2312", $cv);
  1319. }
  1320. $data[$key]=implode("\t", $data[$key]);
  1321. }
  1322. echo implode("\n",$data);
  1323. }
  1324. }
  1325. // Xml 转 数组, 包括根键,忽略空元素和属性,尚有重大错误
  1326. function xml_to_array($xml)
  1327. {
  1328. $reg = "/<(\\w+)[^>]*?>([\\x00-\\xFF]*?)<\\/\\1>/";
  1329. if(preg_match_all($reg, $xml, $matches))
  1330. {
  1331. $count = count($matches[0]);
  1332. $arr = array();
  1333. for($i = 0; $i < $count; $i++)
  1334. {
  1335. $key = $matches[1][$i];
  1336. $val = $this->xml_to_array( $matches[2][$i] ); // 递归
  1337. if(array_key_exists($key, $arr)){
  1338. if(is_array($arr[$key])){
  1339. if(!array_key_exists(0,$arr[$key])){
  1340. $arr[$key] = array($arr[$key]);
  1341. }
  1342. }else{
  1343. $arr[$key] = array($arr[$key]);
  1344. }
  1345. $arr[$key][] = $val;
  1346. }else{
  1347. $arr[$key] = $val;
  1348. }
  1349. }
  1350. return $arr;
  1351. }else{
  1352. return $xml;
  1353. }
  1354. }
  1355. // Xml 转 数组, 不包括根键
  1356. function xmltoarray( $xml )
  1357. {
  1358. $arr = $this->xml_to_array($xml);
  1359. $key = array_keys($arr);
  1360. return $arr[$key[0]];
  1361. }
  1362. //为了方便多选判断是否选中 $arr为数组,$key为当前的value
  1363. function checked($arr,$key){
  1364. if(in_array($key,$arr)){
  1365. return "checked";
  1366. }
  1367. }
  1368. ?>