亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

一些php項目中比較通用的php自建函數有哪些

發布時間:2021-10-14 09:34:39 來源:億速云 閱讀:134 作者:小新 欄目:開發技術

這篇文章主要介紹了一些php項目中比較通用的php自建函數有哪些,具有一定借鑒價值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

以下一些php函數是我們it動力最常用的項目開發函數,這些函數還算是在比較多的項目中使用到的,也是比較通用的。
1.請求接口的處理函數

復制代碼 代碼如下:


/**
 * curl訪問程序接口
 * @param string
 * @return array
 */ 
function getCurlDate($url, $datas, $key) { 
    $datas['time'] = $_SERVER['REQUEST_TIME'] + 300; 
    $post_data['post'] = urlencode(authcode(serialize($datas), "ENCODE", $key)); 
//    echo $url; 
    $ch = curl_init(); 
    curl_setopt($ch, CURLOPT_URL, $url); 
    curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1); 
    // 我們在POST數據哦! 
    curl_setopt($ch, CURLOPT_POST, 1); 
    // 把post的變量加上 
    curl_setopt($ch, CURLOPT_POSTFIELDS, $post_data); 
    $output = curl_exec($ch); 
 //   dump(curl_error($ch)); 
    curl_close($ch); 
    return json_decode($output, true); 


2.獲取文件擴展名

復制代碼 代碼如下:


/**
 * @獲取文件擴展名
 * @$pic string 圖片路徑
 */ 
function get_file_ext($pic) { 
    return substr($pic, strrpos($pic, '.') + 1); 


3.可逆的加密、解密函數

復制代碼 代碼如下:


/**
 * 字符串加密
 * @param   $string     需加密的字符
 * @param   $operation  加密或解密
 * @param   $key        網站加密key,防止破解
 * @return  string
 */ 
function authcode($string, $operation = 'DECODE', $key = '', $expiry = 0) { 
    $ckey_length = 4; 
    $key = md5($key ? $key : '^www.itokit.com$'); 
    $keya = md5(substr($key, 0, 16)); 
    $keyb = md5(substr($key, 16, 16)); 
    $keyc = $ckey_length ? ($operation == 'DECODE' ? substr($string, 0, $ckey_length) : substr(md5(microtime()), -$ckey_length)) : ''; 

    $cryptkey = $keya . md5($keya . $keyc); 
    $key_length = strlen($cryptkey); 

    $string = $operation == 'DECODE' ? base64_decode(substr($string, $ckey_length)) : sprintf('%010d', $expiry ? $expiry + time() : 0) . substr(md5($string . $keyb), 0, 16) . $string; 
    $string_length = strlen($string); 

    $result = ''; 
    $box = range(0, 255); 

    $rndkey = array(); 
    for ($i = 0; $i <= 255; $i++) { 
        $rndkey[$i] = ord($cryptkey[$i % $key_length]); 
    } 

    for ($j = $i = 0; $i < 256; $i++) { 
        $j = ($j + $box[$i] + $rndkey[$i]) % 256; 
        $tmp = $box[$i]; 
        $box[$i] = $box[$j]; 
        $box[$j] = $tmp; 
    } 

    for ($a = $j = $i = 0; $i < $string_length; $i++) { 
        $a = ($a + 1) % 256; 
        $j = ($j + $box[$a]) % 256; 
        $tmp = $box[$a]; 
        $box[$a] = $box[$j]; 
        $box[$j] = $tmp; 
        $result .= chr(ord($string[$i]) ^ ($box[($box[$a] + $box[$j]) % 256])); 
    } 

    if ($operation == 'DECODE') { 
        if ((substr($result, 0, 10) == 0 || substr($result, 0, 10) - time() > 0) && substr($result, 10, 16) == substr(md5(substr($result, 26) . $keyb), 0, 16)) { 
            return substr($result, 26); 
        } else { 
            return ''; 
        } 
    } else { 
        return $keyc . str_replace('=', '', base64_encode($result)); 
    } 


4.字符串轉十六進制

復制代碼 代碼如下:


/**
* 字符串轉十六進制
* @param unknown_type $s
*/ 
function str2hex($s) { 
  $r = ""; 
  $hexes = array ("0","1","2","3","4","5","6","7","8","9","a","b","c","d","e","f"); 
  for ($i=0; $i<strlen($s); $i++) 
  $r .= ($hexes [(ord($s{$i}) >> 4)] . $hexes [(ord($s{$i}) & 0xf)]); 
  return $r; 
}


5.十六進制轉字符串

復制代碼 代碼如下:


/**
* 十六進制轉字符串
* @param unknown_type $s
*/ 
function hex2str($s) { 
  $r = ""; 
  for ( $i = 0; $i<strlen($s); $i += 2) 
  { 
    $x1 = ord($s{$i}); 
    $x1 = ($x1>=48 && $x1<58) ? $x1-48 : $x1-97+10; 
    $x2 = ord($s{$i+1}); 
    $x2 = ($x2>=48 && $x2<58) ? $x2-48 : $x2-97+10; 
    $r .= chr((($x1 << 4) & 0xf0) | ($x2 & 0x0f)); 
  } 
  return $r; 


6.返回經addslashes處理過的字符串或數組

復制代碼 代碼如下:


/**
* 返回經addslashes處理過的字符串或數組
* @param $string 需要處理的字符串或數組
* @return mixed
*/ 
function new_addslashes($string){ 
  if(!is_array($string)) return addslashes($string); 
  foreach($string as $key => $val) $string[$key] = new_addslashes($val); 
  return $string; 


/**/ 
function addslashes_deep($string) 

  return is_array($string) ? array_map('addslashes_deep', $string) : addslashes($string); 


7.返回經stripslashes處理過的字符串或數組

復制代碼 代碼如下:


/**
* 返回經stripslashes處理過的字符串或數組
* @param $string 需要處理的字符串或數組
* @return mixed
*/ 
function new_stripslashes($string) { 
  if(!is_array($string)) return stripslashes($string); 
  foreach($string as $key => $val) $string[$key] = new_stripslashes($val); 
  return $string; 

/**/ 
function stripslashes_deep($string) 

  return is_array($string) ? array_map('stripslashes_deep', $string) : stripslashes($string); 


8.返回經 htmlspecialchars 處理過的字符串或數組

復制代碼 代碼如下:


/**
* 返回經 htmlspecialchars 處理過的字符串或數組
* @param $string 需要處理的字符串或數組
* @return mixed
*/ 
function new_html_special_chars($string) { 
  if(!is_array($string)) return htmlspecialchars($string); 
  foreach($string as $key => $val) $string[$key] = new_html_special_chars($val); 
  return $string; 


9.獲取請求ip

復制代碼 代碼如下:


/**
 * 獲取請求ip
 *
 * @return ip地址
 */ 
function ip() { 
  if(getenv('HTTP_CLIENT_IP') && strcasecmp(getenv('HTTP_CLIENT_IP'), 'unknown')) { 
    $ip = getenv('HTTP_CLIENT_IP'); 
  } elseif(getenv('HTTP_X_FORWARDED_FOR') && strcasecmp(getenv('HTTP_X_FORWARDED_FOR'), 'unknown')) { 
    $ip = getenv('HTTP_X_FORWARDED_FOR'); 
  } elseif(getenv('REMOTE_ADDR') && strcasecmp(getenv('REMOTE_ADDR'), 'unknown')) { 
    $ip = getenv('REMOTE_ADDR'); 
  } elseif(isset($_SERVER['REMOTE_ADDR']) && $_SERVER['REMOTE_ADDR'] && strcasecmp($_SERVER['REMOTE_ADDR'], 'unknown')) { 
    $ip = $_SERVER['REMOTE_ADDR']; 
  } 
  return preg_match ( '/[\d\.]{7,15}/', $ip, $matches ) ? $matches [0] : ''; 


10.字符截取 支持UTF8/GBK

復制代碼 代碼如下:


/**
* 字符截取 支持UTF8/GBK
* @param $string
* @param $length
* @param $dot
*/ 
function str_cut($string, $length, $dot = '...') { 
  $strlen = strlen($string); 
  if($strlen <= $length) return $string; 
  $string = str_replace(array(' ',' ', '&', '"', ''', '“', '”', '—', '<', '>', '·', '…'), array('∵',' ', '&', '"', "'", '“', '”', '—', '<', '>', '·', '…'), $string); 
  $strcut = ''; 
  if(strtolower(CHARSET) == 'utf-8') { 
    $length = intval($length-strlen($dot)-$length/3); 
    $n = $tn = $noc = 0; 
    while($n < strlen($string)) { 
      $t = ord($string[$n]); 
      if($t == 9 || $t == 10 || (32 <= $t && $t <= 126)) { 
        $tn = 1; $n++; $noc++; 
      } elseif(194 <= $t && $t <= 223) { 
        $tn = 2; $n += 2; $noc += 2; 
      } elseif(224 <= $t && $t <= 239) { 
        $tn = 3; $n += 3; $noc += 2; 
      } elseif(240 <= $t && $t <= 247) { 
        $tn = 4; $n += 4; $noc += 2; 
      } elseif(248 <= $t && $t <= 251) { 
        $tn = 5; $n += 5; $noc += 2; 
      } elseif($t == 252 || $t == 253) { 
        $tn = 6; $n += 6; $noc += 2; 
      } else { 
        $n++; 
      } 
      if($noc >= $length) { 
        break; 
      } 
    } 
    if($noc > $length) { 
      $n -= $tn; 
    } 
    $strcut = substr($string, 0, $n); 
    $strcut = str_replace(array('∵', '&', '"', "'", '“', '”', '—', '<', '>', '·', '…'), array(' ', '&', '"', ''', '“', '”', '—', '<', '>', '·', '…'), $strcut); 
  } else { 
    $dotlen = strlen($dot); 
    $maxi = $length - $dotlen - 1; 
    $current_str = ''; 
    $search_arr = array('&',' ', '"', "'", '“', '”', '—', '<', '>', '·', '…','∵');
    $replace_arr = array('&',' ', '"', ''', '“', '”', '—', '<', '>', '·', '…',' '); 
    $search_flip = array_flip($search_arr); 
    for ($i = 0; $i < $maxi; $i++) { 
      $current_str = ord($string[$i]) > 127 ? $string[$i].$string[++$i] : $string[$i]; 
      if (in_array($current_str, $search_arr)) { 
        $key = $search_flip[$current_str]; 
        $current_str = str_replace($search_arr[$key], $replace_arr[$key], $current_str); 
      } 
      $strcut .= $current_str; 
    } 
  } 
  return $strcut.$dot; 


11.產生隨機字符串

復制代碼 代碼如下:


/**
* 產生隨機字符串
*
* @param        int                $length    輸出長度 
* @param        string         $chars     可選的 ,默認為 0123456789
* @return     string         字符串
*/ 
function random($length, $chars = '0123456789') { 
  $hash = ''; 
  $max = strlen($chars) - 1; 
  for($i = 0; $i < $length; $i++) { 
    $hash .= $chars[mt_rand(0, $max)]; 
  } 
  return $hash; 


12.將字符串轉換為數組

復制代碼 代碼如下:


/**
* 將字符串轉換為數組
*
* @param  string  $data  字符串
* @return  array  返回數組格式,如果,data為空,則返回空數組
*/ 
function string2array($data) { 
  if($data == '') return array(); 
  eval("\$array = $data;"); 
  return $array; 


13.將數組轉換為字符串

復制代碼 代碼如下:


/**
* 將數組轉換為字符串
*
* @param  array  $data    數組
* @param  bool  $isformdata  如果為0,則不使用new_stripslashes處理,可選參數,默認為1
* @return  string  返回字符串,如果,data為空,則返回空
*/ 
function array2string($data, $isformdata = 1) { 
  if($data == '') return ''; 
  if($isformdata) $data = new_stripslashes($data); 
  return addslashes(var_export($data, TRUE)); 


14.轉換字節數為其他單位

復制代碼 代碼如下:


/**
* 轉換字節數為其他單位
*
*
* @param        string        $filesize        字節大小
* @return        string        返回大小
*/ 
function sizecount($filesize) { 
        if ($filesize >= 1073741824) { 
                $filesize = round($filesize / 1073741824 * 100) / 100 .' GB'; 
        } elseif ($filesize >= 1048576) { 
                $filesize = round($filesize / 1048576 * 100) / 100 .' MB'; 
        } elseif($filesize >= 1024) { 
                $filesize = round($filesize / 1024 * 100) / 100 . ' KB'; 
        } else { 
                $filesize = $filesize.' Bytes'; 
        } 
        return $filesize; 

感謝你能夠認真閱讀完這篇文章,希望小編分享的“一些php項目中比較通用的php自建函數有哪些”這篇文章對大家有幫助,同時也希望大家多多支持億速云,關注億速云行業資訊頻道,更多相關知識等著你來學習!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

php
AI

法库县| 资溪县| 独山县| 绥化市| 安顺市| 福贡县| 绥阳县| 沅陵县| 阜南县| 汪清县| 肃宁县| 昭平县| 武宁县| 黄龙县| 明溪县| 四川省| 阿尔山市| 彭山县| 沙雅县| 建宁县| 兴宁市| 沙河市| 高唐县| 合江县| 香格里拉县| 沈丘县| 鹿邑县| 武功县| 白朗县| 彝良县| 大关县| 双峰县| 钦州市| 新野县| 武乡县| 静海县| 陆川县| 凤台县| 临夏县| 莱西市| 运城市|