php常用代碼片段

1. 檢測用戶位置 
使用下面的函數,可以檢測用戶是在哪個城市訪問你的網站

function detect_city($ip) {
                  
        $default = 'UNKNOWN';
           
        $curlopt_useragent = 'Mozilla/5.0 (Windows; U; Windows NT 5.1; en-US; rv:1.9.2) Gecko/20100115 Firefox/3.6 (.NET CLR 3.5.30729)';
                  
        $url = 'http://ipinfodb.com/ip_locator.php?ip=' . urlencode($ip);
        $ch = curl_init();
                  
        $curl_opt = array(
            CURLOPT_FOLLOWLOCATION  => 1,
            CURLOPT_HEADER      => 0,
            CURLOPT_RETURNTRANSFER  => 1,
            CURLOPT_USERAGENT   => $curlopt_useragent,
            CURLOPT_URL       => $url,
            CURLOPT_TIMEOUT         => 1,
            CURLOPT_REFERER         => 'http://' . $_SERVER['HTTP_HOST'],
        );
                  
        curl_setopt_array($ch, $curl_opt);
                  
        $content = curl_exec($ch);
                  
        if (!is_null($curl_info)) {
            $curl_info = curl_getinfo($ch);
        }
                  
        curl_close($ch);
                  
        if ( preg_match('{<li>City : ([^<]*)</li>}i', $content, $regs) )  {
            $city = $regs[1];
        }
        if ( preg_match('{<li>State/Province : ([^<]*)</li>}i', $content, $regs) )  {
            $state = $regs[1];
        }
           
        if( $city!='' && $state!='' ){
          $location = $city . ', ' . $state;
          return $location;
        }else{
          return $default; 
        }
                  
    }
// 調用
<?php
$ip = $_SERVER['REMOTE_ADDR'];
$city = detect_city($ip);
echo $city;
?>

2.獲取 Web 頁面的源代碼 
使用下面的函數,可以獲取任意 Web 頁面的 HTML 代碼 

function display_sourcecode($url)
{
$lines = file($url);
$output = "";
foreach ($lines as $line_num => $line) { 
    // loop thru each line and prepend line numbers
    $output.= "Line #<b>{$line_num}</b> : " . htmlspecialchars($line) . "\n";
}
}
<?php
$url = "http://www.yuanzhea.xyz";
$source = display_sourcecode($url);
echo $source;
?>

3.驗證郵箱地址 
有時候,當在網站填寫表單,用戶可能會輸入錯誤的郵箱地址,這個函數可以驗證郵箱地址是否有效。

function is_validemail($email)
{
$check = 0;
if(filter_var($email,FILTER_VALIDATE_EMAIL))
{
$check = 1;
}
return $check;
}
調用語法:
<?php
$email = "[email protected]";
$check = is_validemail($email);
echo $check;
// If the output is 1, then email is valid.
?>

4.轉發數量 
使用這個 PHP 片段可以檢測你的頁面 URL 有多少轉發數量 

function tweetCount($url) {
    $content = file_get_contents("http://api.tweetmeme.com/url_info?url=".$url);
    $element = new SimpleXmlElement($content);
    $retweets = $element->story->url_count;
    if($retweets){
        return $retweets;
    } else {
        return 0;
    }
}
調用語法:
<?php
$url = "http://www.yuanzhea.xyz";
$count = tweetCount($url);
return $count;
?>

5.根據 URL 下載圖片

function imagefromURL($image,$rename)
{
$ch = curl_init($image);
curl_setopt($ch, CURLOPT_HEADER, 0);
curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
curl_setopt($ch, CURLOPT_BINARYTRANSFER,1);
$rawdata=curl_exec ($ch);
curl_close ($ch);
$fp = fopen("$rename",'w');
fwrite($fp, $rawdata); 
fclose($fp);
}
<?php
$url = "http://koonk.com/images/logo.png";
$rename = "koonk.png";
imagefromURL($url,$rename);
?>

6.身份證號碼的正則驗證

//=============新的18位身份證號碼各位的含義:=======================
//1-2位省、自治區、直轄市代碼;11-65
//3-4位地級市、盟、自治州代碼;
//5-6位縣、縣級市、區代碼;
//7-14位出生年月日,比如19970401代表1997年4月1日;
//15-17位爲順序號,其中17位男爲單數,女爲雙數;
//18位爲校驗碼,0-9和X,由公式隨機產生。
//舉例:
//412723 19970401 0012這個身份證號的含義: 41爲河南,27爲周口,23爲商水縣,出生日期爲1997年4月1日,順序號爲001,2爲驗證碼
//===========15位身份證號碼各位的含義:=======================
//1-2位省、自治區、直轄市代碼;
//3-4位地級市、盟、自治州代碼;
//5-6位縣、縣級市、區代碼;
//7-12位出生年月日,比如970401代表1997年4月1日,這是和18位號碼的第一個區別;
//13-15位爲順序號,其中15位男爲單數,女爲雙數;
//與18位身份證號的第二個區別:沒有最後一位的驗證碼。
//舉例:
//412723 970401 001的含義; 41爲河南,27爲周口,23爲商水縣,出生日期爲1997年4月1日,順序號爲001。
  // $num爲身份證號碼,$checkSex(性別):1爲男,2爲女,不輸入爲不驗證
 public function checkIdentity($num, $checkSex = '') { // 不是15位或不是18位都是無效身份證號
 if (strlen($num) != 15 && strlen($num) != 18) {
      return false;
 }
   // 是數值
  if (is_numeric($num)) {
  // 如果是15位身份證號
  if (strlen($num) == 15) {
  // 省市縣(6位)
  $areaNum = substr($num, 0, 6);
  // 出生年月(6位)
  $dateNum = substr($num, 6, 6);
  // 性別(3位)
  $sexNum = substr($num, 12, 3);
  } else {
  // 如果是18位身份證號
  // 省市縣(6位)
  $areaNum = substr($num, 0, 6);
  // 出生年月(8位)
  $dateNum = substr($num, 6, 8);
  // 性別(3位)
  $sexNum = substr($num, 14, 3);
  // 校驗碼(1位)
  $endNum = substr($num, 17, 1);
  }
 } else {
  // 不是數值
  if (strlen($num) == 15) {
  return false;
  } else {
  //驗證前17位爲數值,且18位爲字符x
  $check17 = substr($num, 0, 17);
  if (!is_numeric($check17)) {
   return false;
  }
  //省市縣(6位)
  $areaNum = substr($num, 0, 6);
  // 出生年月(8位)
  $dateNum = substr($num, 6, 8);
  // 性別(3位)
  $sexNum = substr($num, 14, 3);
  // 校驗碼(1位)
  $endNum = substr($num, 17, 1);
  if ($endNum != 'x' && $endNum != 'X') {
   return false;
  }
  }
 }
 //驗證地區
 if (isset($areaNum)) {
  if (!$this->checkArea($areaNum)) {
  return false;
  }
 }
 //驗證日期
 if (isset($dateNum)) {
  if (!$this->checkDate($dateNum)) {
  return false;
  }
 }
 // 性別1爲男,2爲女
 if ($checkSex == 1) {
  if (isset($sexNum)) {
  if (!$this->checkSex($sexNum)) {
   return false;
  }
  }
 } elseif ($checkSex == 2) {
  if (isset($sexNum)) {
  if ($this->checkSex($sexNum)) {
   return false;
  }
  }
 }
 //驗證最後一位
 if (isset($endNum)) {
  if (!$this->checkEnd($endNum, $num)) {
  return false;
  }
 }
 return true;
 }
 // 驗證城市
 private function checkArea($area) {
 $num1 = substr($area, 0, 2);
 $num2 = substr($area, 2, 2);
 $num3 = substr($area, 4, 2);
 // 根據GB/T2260—999,省市代碼11到65
 if (10 < $num1 && $num1 < 66) {
  return true;
 } else {
  return false;
 }
 }
 // 驗證出生日期
 private function checkDate($date) {
 if (strlen($date) == 6) {
  $date1 = substr($date, 0, 2);
  $date2 = substr($date, 2, 2);
  $date3 = substr($date, 4, 2);
  $statusY = $this->checkY('19' . $date1);
 } else {
  $date1 = substr($date, 0, 4);
  $date2 = substr($date, 4, 2);
  $date3 = substr($date, 6, 2);
  $nowY = date("Y", time());
  if (1900 < $date1 && $date1 <= $nowY) {
  $statusY = $this->checkY($date1);
  } else {
  return false;
  }
 }
 if (0 < $date2 && $date2 < 13) {
  if ($date2 == 2) {
  // 潤年
  if ($statusY) {
   if (0 < $date3 && $date3 <= 29) {
   return true;
   } else {
   return false;
   }
  } else {
   // 平年
   if (0 < $date3 && $date3 <= 28) {
   return true;
   } else {
   return false;
   }
  }
  } else {
  $maxDateNum = $this->getDateNum($date2);
  if (0 < $date3 && $date3 <= $maxDateNum) {
   return true;
  } else {
   return false;
  }
  }
 } else {
  return false;
 }
 }
 // 驗證性別
 private function checkSex($sex) {
 if ($sex % 2 == 0) {
  return false;
 } else {
  return true;
 }
 }
 // 驗證18位身份證最後一位
 private function checkEnd($end, $num) {
 $checkHou = array(1, 0, 'x', 9, 8, 7, 6, 5, 4, 3, 2);
 $checkGu = array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2);
 $sum = 0;
 for ($i = 0;$i < 17;$i++) {
  $sum+= (int)$checkGu[$i] * (int)$num[$i];
 }
 $checkHouParameter = $sum % 11;
 if ($checkHou[$checkHouParameter] != $num[17]) {
  return false;
 } else {
  return true;
 }
 }
 // 驗證平年潤年,參數年份,返回 true爲潤年 false爲平年
 private function checkY($Y) {
 if (getType($Y) == 'string') {
  $Y = (int)$Y;
 }
 if ($Y % 100 == 0) {
  if ($Y % 400 == 0) {
  return true;
  } else {
  return false;
  }
 } else if ($Y % 4 == 0) {
  return true;
 } else {
  return false;
 }
 }
 // 當月天數 參數月份(不包括2月) 返回天數
 private function getDateNum($month) {
 if ($month == 1 || $month == 3 || $month == 5 || $month == 7 || $month == 8 || $month == 10 || $month == 12) {
  return 31;
 } else if ($month == 2) {
 } else {
  return 30;
 }
 }
}
調用語法: 

<?php
   $num = '230106199202099035'; //此號碼隨機生成
   $test = new check_IdCard();
  $data = $test->checkIdentity($num);
   var_dump($data);
?>

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章