亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > PHP > 正文

必須收藏的23個php實用代碼片段

2020-03-22 20:03:43
字體:
來源:轉載
供稿:網友
在編寫代碼的時候有個神奇的工具總是好的!下面這里收集了 40+ PHP 代碼片段,可以幫助你開發 PHP 項目。
這些 PHP 片段對于 PHP 初學者也非常有幫助,非常容易學習,讓我們開始學習吧~
1. 發送 SMS
在開發 Web 或者移動應用的時候,經常會遇到需要發送 SMS 給用戶,或者因為登錄原因,或者是為了發送信息。下面的 PHP 代碼就實現了發送 SMS 的功能。
為了使用任何的語言發送 SMS,需要一個 SMS gateway。大部分的 SMS 會提供一個 API,這里是使用 MSG91 作為 SMS gateway。
function send_sms($mobile,$msg)$authKey = "XXXXXXXXXXX";date_default_timezone_set("Asia/Kolkata");$date = strftime("%Y-%m-%d %H:%M:%S");//Multiple mobiles numbers separated by comma$mobileNumber = $mobile;//Sender ID,While using route4 sender id should be 6 characters long.$senderId = "IKOONK";//Your message to send, Add URL encoding here.$message = urlencode($msg);//Define route$route = "template";//Prepare you post parameters$postData = array( 'authkey' = $authKey, 'mobiles' = $mobileNumber, 'message' = $message, 'sender' = $senderId, 'route' = $route//API URL$url="https://control.msg91.com/sendhttp.php";// init the resource$ch = curl_init();curl_setopt_array($ch, array( CURLOPT_URL = $url, CURLOPT_RETURNTRANSFER = true, CURLOPT_POST = true, CURLOPT_POSTFIELDS = $postData //,CURLOPT_FOLLOWLOCATION = true
curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);
其中“$authKey = "XXXXXXXXXXX";”需要你輸入你的密碼,“$senderId = "IKOONK";”需要你輸入你的 SenderID。當輸入移動號碼的時候需要指定國家代碼 (比如,美國是 1,印度是 91 )。
語法:
$message = "Hello World";$mobile = "918112998787";send_sms($mobile,$message);2. 使用 mandrill 發送郵件
Mandrill 是一款強大的 SMTP 提供器。開發者傾向于使用一個第三方 SMTP provider 來獲取更好的收件交付。
下面的函數中,你需要把 “Mandrill.php” 放在同一個文件夾,作為 PHP 文件,這樣就可以使用TA來發送郵件。
function send_email($to_email,$subject,$message1)require_once 'Mandrill.php';$apikey = 'XXXXXXXXXX'; //specify your api key here$mandrill = new Mandrill($apikey);$message = new stdClass();$message- html = $message1;$message- text = $message1;$message- subject = $subject;$message- from_email = "blog@koonk.com";//Sender Email$message- from_name = "KOONK";//Sender Name$message- to = array(array("email" = $to_email));$message- track_opens = true;$response = $mandrill- messages- send($message);$apikey = 'XXXXXXXXXX'; //specify your api key here”這里需要你指定你的 API 密鑰(從 Mandrill 賬戶中獲得)。
語法:
$to = "abc@example.com";$subject = "This is a test email";$message = "Hello World!";send_email($to,$subject,$message);為了達到最好的效果,最好按照 Mandrill 的教程去配置 DNS。3. PHP 函數:阻止 SQL 注入
SQL 注入或者 SQLi 常見的攻擊網站的手段,使用下面的代碼可以幫助你防止這些工具。
function clean($input) if (is_array($input)) foreach ($input as $key = $val) $output[$key] = clean($val); // $output[$key] = $this- clean($val); else $output = (string) $input; // if magic quotes is on then use strip slashes if (get_magic_quotes_gpc()) $output = stripslashes($output); // $output = strip_tags($output); $output = htmlentities($output, ENT_QUOTES, 'UTF-8');// return the clean text return $output;語法:
$text = " script alert(1) /script $text = clean($text);echo $text;4. 檢測用戶位置
使用下面的函數,可以檢測用戶是在哪個城市訪問你的網站
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;語法:
$ip = $_SERVER['REMOTE_ADDR'];$city = detect_city($ip);echo $city;5. 獲取 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";語法:
$url = "http://blog.koonk.com";$source = display_sourcecode($url);echo $source;6. 計算喜歡你的 Facebook 頁面的用戶
function fb_fan_count($facebook_name) $data = json_decode(file_get_contents("https://graph.facebook.com/".$facebook_name)); $likes = $data- likes; return $likes;語法:
$page = "koonktechnologies";$count = fb_fan_count($page);echo $count;7. 確定任意圖片的主導顏色
function dominant_color($image)$i = imagecreatefromjpeg($image);for ($x=0;$x imagesx($i);$x++) { for ($y=0;$y imagesy($i);$y++) { $rgb = imagecolorat($i,$x,$y); $r = ($rgb 16) $g = ($rgb $b = $rgb $rTotal += $r; $gTotal += $g; $bTotal += $b; $total++;$rAverage = round($rTotal/$total);$gAverage = round($gTotal/$total);$bAverage = round($bTotal/$total);8. whois 查詢
使用下面的函數可以獲取任何域名用戶的完整細節
function whois_query($domain) { // fix the domain name: $domain = strtolower(trim($domain)); $domain = preg_replace('/^http://///i', '', $domain); $domain = preg_replace('/^www/./i', '', $domain); $domain = explode('/', $domain); $domain = trim($domain[0]); // split the TLD from domain name $_domain = explode('.', $domain); $lst = count($_domain)-1; $ext = $_domain[$lst]; // You find resources and lists // like these on wikipedia: // http://de.wikipedia.org/wiki/Whois $servers = array( "biz" = "whois.neulevel.biz", "com" = "whois.internic.net", "us" = "whois.nic.us", "coop" = "whois.nic.coop", "info" = "whois.nic.info", "name" = "whois.nic.name", "net" = "whois.internic.net", "gov" = "whois.nic.gov", "edu" = "whois.internic.net", "mil" = "rs.internic.net", "int" = "whois.iana.org", "ac" = "whois.nic.ac", "ae" = "whois.uaenic.ae", "at" = "whois.ripe.net", "au" = "whois.aunic.net", "be" = "whois.dns.be", "bg" = "whois.ripe.net", "br" = "whois.registro.br", "bz" = "whois.belizenic.bz", "ca" = "whois.cira.ca", "cc" = "whois.nic.cc", "ch" = "whois.nic.ch", "cl" = "whois.nic.cl", "cn" = "whois.cnnic.net.cn", "cz" = "whois.nic.cz", "de" = "whois.nic.de", "fr" = "whois.nic.fr", "hu" = "whois.nic.hu", "ie" = "whois.domainregistry.ie", "il" = "whois.isoc.org.il", "in" = "whois.ncst.ernet.in", "ir" = "whois.nic.ir", "mc" = "whois.ripe.net", "to" = "whois.tonic.to", "tv" = "whois.tv", "ru" = "whois.ripn.net", "org" = "whois.pir.org", "aero" = "whois.information.aero", "nl" = "whois.domain-registry.nl" if (!isset($servers[$ext])){ die('Error: No matching nic server found!'); $nic_server = $servers[$ext]; $output = ''; // connect to whois server: if ($conn = fsockopen ($nic_server, 43)) { fputs($conn, $domain."/r/n"); while(!feof($conn)) { $output .= fgets($conn,128); fclose($conn); else { die('Error: Could not connect to ' . $nic_server . '!'); } return $output;語法:
$domain = "http://www.blog.koonk.com";$result = whois_query($domain);print_r($result);9. 驗證郵箱地址
有時候,當在網站填寫表單,用戶可能會輸入錯誤的郵箱地址,這個函數可以驗證郵箱地址是否有效。
function is_validemail($email)$check = 0;if(filter_var($email,FILTER_VALIDATE_EMAIL))$check = 1;return $check;語法:
$email = "blog@koonk.com";$check = is_validemail($email);echo $check;// If the output is 1, then email is valid.10. 獲取用戶的真實 IP
function getRealIpAddr() if (!emptyempty($_SERVER['HTTP_CLIENT_IP'])) $ip=$_SERVER['HTTP_CLIENT_IP']; elseif (!emptyempty($_SERVER['HTTP_X_FORWARDED_FOR'])) //to check ip is pass from proxy $ip=$_SERVER['HTTP_X_FORWARDED_FOR']; else $ip=$_SERVER['REMOTE_ADDR']; return $ip; 語法:
$ip = getRealIpAddr();echo $ip;11. 轉換 URL:從字符串變成超鏈接
如果你正在開發論壇,博客或者是一個常規的表單提交,很多時候都要用戶訪問一個網站。使用這個函數,URL 字符串就可以自動的轉換為超鏈接。
function makeClickableLinks($text) $text = eregi_replace('(((f|ht){1}tp://)[-a-zA-Z0-9@:%_+.~# &//=]+)', ' a href="/1" /1 /a ', $text); $text = eregi_replace('([[:space:]()[{}])(www.[-a-zA-Z0-9@:%_+.~# &//=]+)', '/1 a href="http:///2" /2 /a ', $text); $text = eregi_replace('([_.0-9a-z-]+@([0-9a-z][0-9a-z-]+.)+[a-z]{2,3})', ' a href="mailto:/1" /1 /a ', $text); return $text; 語法:
$text = "This is my first post on http://blog.koonk.com";$text = makeClickableLinks($text);echo $text;12. 阻止多個 IP 訪問你的網站
這個代碼片段可以方便你禁止某些特定的 IP 地址訪問你的網站
if ( !file_exists('blocked_ips.txt') ) { $deny_ips = array( '127.0.0.1', '192.168.1.1', '83.76.27.9', '192.168.1.163'} else { $deny_ips = file('blocked_ips.txt');// read user ip adress:$ip = isset($_SERVER['REMOTE_ADDR']) trim($_SERVER['REMOTE_ADDR']) : '';// search current IP in $deny_ips arrayif ( (array_search($ip, $deny_ips))!== FALSE ) { // address is blocked: echo 'Your IP adress ('.$ip.') was blocked!'; exit;13. 強制性文件下載
如果你需要下載特定的文件而不用另開新窗口,下面的代碼片段可以幫助你。
function force_download($file) $dir = "../log/exports/"; if ((isset($file))&&(file_exists($dir.$file))) { header("Content-type: application/force-download"); header('Content-Disposition: inline; filename="' . $dir.$file . '"'); header("Content-Transfer-Encoding: Binary"); header("Content-length: ".filesize($dir.$file)); header('Content-Type: application/octet-stream'); header('Content-Disposition: attachment; filename="' . $file . '"'); readfile("$dir$file"); } else { echo "No file selected";語法:
force_download("image.jpg");14. 創建 JSON 數據
使用下面的 PHP 片段可以創建 JSON 數據,可以方便你創建移動應用的 Web 服務
$json_data = array ('id'= 1,'name'= "Mohit");echo json_encode($json_data);15. 壓縮 zip 文件
使用下面的 PHP 片段可以即時壓縮 zip 文件
function create_zip($files = array(),$destination = '',$overwrite = false) { //if the zip file already exists and overwrite is false, return false if(file_exists($destination) && !$overwrite) { return false; } //vars $valid_files = array(); //if files were passed in... if(is_array($files)) { //cycle through each file foreach($files as $file) { //make sure the file exists if(file_exists($file)) { $valid_files[] = $file; //if we have good files... if(count($valid_files)) { //create the archive $zip = new ZipArchive(); if($zip- open($destination,$overwrite ZIPARCHIVE::OVERWRITE : ZIPARCHIVE::CREATE) !== true) { return false; //add the files foreach($valid_files as $file) { $zip- addFile($file,$file); //debug //echo 'The zip archive contains ',$zip- numFiles,' files with a status of ',$zip- status; //close the zip -- done! $zip- close(); //check to make sure the file exists return file_exists($destination); else return false; 語法:
$files=array('file1.jpg', 'file2.jpg', 'file3.gif'); create_zip($files, 'myzipfile.zip', true);16. 解壓文件
function unzip($location,$newLocation) if(exec("unzip $location",$arr)){ mkdir($newLocation); for($i = 1;$i count($arr);$i++){ $file = trim(preg_replace("~inflating: ~","",$arr[$i])); copy($location.'/'.$file,$newLocation.'/'.$file); unlink($location.'/'.$file); return TRUE; }else{ return FALSE;
$im2 = imagecreatetruecolor($newx, $newy); imagecopyresized($im2, $im, 0, 0, 0, 0, floor($newx), floor($newy), $x, $y); return $im2; 18. 使用 mail() 發送郵件
之前我們提供了如何使用 Mandrill 發送郵件的 PHP 代碼片段,但是如果你不想使用第三方服務,那么可以使用下面的 PHP 代碼片段。
function send_mail($to,$subject,$body)$headers = "From: KOONK/r/n";$headers .= "Reply-To: blog@koonk.com/r/n";$headers .= "Return-Path: blog@koonk.com/r/n";$headers .= "X-Mailer: PHP5/n";$headers .= 'MIME-Version: 1.0' . "/n";$headers .= 'Content-type: text/html; charset=iso-8859-1' . "/r/n";mail($to,$subject,$body,$headers);語法:
$to = "admin@koonk.com";$subject = "This is a test mail";$body = "Hello World!";send_mail($to,$subject,$body);19. 把秒轉換成天數,小時數和分鐘
function secsToStr($secs) { if($secs =86400){$days=floor($secs/86400);$secs=$secs%86400;$r=$days.' day';if($days 1){$r.='s';}if($secs 0){$r.=', ';}} if($secs =3600){$hours=floor($secs/3600);$secs=$secs%3600;$r.=$hours.' hour';if($hours 1){$r.='s';}if($secs 0){$r.=', ';}} if($secs =60){$minutes=floor($secs/60);$secs=$secs%60;$r.=$minutes.' minute';if($minutes 1){$r.='s';}if($secs 0){$r.=', ';}} $r.=$secs.' second';if($secs 1){$r.='s';} return $r;語法:
$seconds = "56789";$output = secsToStr($seconds);echo $output;20. 數據庫連接
連接 MySQL 數據庫
$DBNAME = 'koonk';$HOST = 'localhost';$DBUSER = 'root';$DBPASS = 'koonk';$CONNECT = mysql_connect($HOST,$DBUSER,$DBPASS);if(!$CONNECT) echo 'MySQL Error: '.mysql_error();$SELECT = mysql_select_db($DBNAME);if(!$SELECT) echo 'MySQL Error: '.mysql_error();21. 目錄清單
使用下面的 PHP 代碼片段可以在一個目錄中列出所有文件和文件夾
function list_files($dir) if(is_dir($dir)) if($handle = opendir($dir)) while(($file = readdir($handle)) !== false) if($file != "." && $file != ".." && $file != "Thumbs.db"/*pesky windows, images..*/) echo ' a target="_blank" href="'.$dir.$file.'" '.$file.' /a '."/n"; closedir($handle);語法:
list_files("images/"); //This will list all files of images folder22. 檢測用戶語言
使用下面的 PHP 代碼片段可以檢測用戶瀏覽器所使用的語言
function get_client_language($availableLanguages, $default='en'){ if (isset($_SERVER['HTTP_ACCEPT_LANGUAGE'])) { $langs=explode(',',$_SERVER['HTTP_ACCEPT_LANGUAGE']); foreach ($langs as $value){ $choice=substr($value,0,2); if(in_array($choice, $availableLanguages)){ return $choice; return $default;23. 查看 CSV 文件
function readCSV($csvFile){ $file_handle = fopen($csvFile, 'r'); while (!feof($file_handle) ) { $line_of_text[] = fgetcsv($file_handle, 1024); fclose($file_handle); return $line_of_text;語法:
$csvFile = "test.csv";$csv = readCSV($csvFile);$a = csv[0][0]; // This will get value of Column 1 & Row 1 以上就是本文的全部內容,希望對大家的學習有所幫助。PHP教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
色婷婷av一区二区三区在线观看| 26uuu另类亚洲欧美日本一| 国产精品美女在线| 成人在线精品视频| 亚洲欧美一区二区精品久久久| 激情成人在线视频| 欧美激情a∨在线视频播放| 欧美激情精品久久久久久黑人| 国产69精品久久久久99| 亚洲毛片在线观看| 久久精品人人做人人爽| 在线观看不卡av| 欧美丰满老妇厨房牲生活| 欧美黑人巨大精品一区二区| 日韩免费观看视频| 色琪琪综合男人的天堂aⅴ视频| 美女国内精品自产拍在线播放| 国产精品久久久久久av下载红粉| 精品成人乱色一区二区| 欧美夫妻性生活xx| 国产精品自产拍在线观看中文| 亚洲欧美三级伦理| 国产欧美精品在线| 91久久在线观看| 亚洲欧洲免费视频| 国产97在线亚洲| 久久精品青青大伊人av| 国语自产在线不卡| 成人综合国产精品| 亚洲欧美精品中文字幕在线| 欧美一区三区三区高中清蜜桃| 日韩中文字幕国产精品| 亚洲欧美国产精品va在线观看| 奇门遁甲1982国语版免费观看高清| 亚洲第一区第二区| 亚洲欧美日韩第一区| 亚洲美女精品久久| 国产精品亚洲精品| 欧美怡红院视频一区二区三区| 91精品久久久久久久久久久久久久| 在线观看欧美www| 成人精品一区二区三区| 亚洲精品小视频| 国产一区深夜福利| 国产精品久久久久久中文字| 亚洲精品久久久久久下一站| 亚洲欧洲激情在线| 久久久国产一区二区三区| 亚洲精品美女视频| 日韩精品日韩在线观看| 日韩成人中文字幕| 日韩电影在线观看中文字幕| 国产亚洲综合久久| 久久国产天堂福利天堂| 欧美人成在线视频| 精品久久久久久久久久| 成人国产精品一区二区| 国产不卡av在线| 亚洲精品电影在线| 亚洲精品短视频| 久久久久久久网站| 国产精品网站大全| 久久精品影视伊人网| 日韩中文在线视频| 国产成人精品视频在线| 亚洲国产精品va在线| 久久久精品一区二区| 国产日韩欧美影视| 久久精品国产一区| 综合av色偷偷网| 中文国产成人精品久久一| 最新的欧美黄色| 亚洲国产精品成人va在线观看| 欧美精品久久久久| 色婷婷亚洲mv天堂mv在影片| 久久久久免费视频| 国产精品青草久久久久福利99| 欧美最顶级的aⅴ艳星| 欧美日韩国产综合视频在线观看中文| 91精品国产精品| 97精品在线观看| 欧美专区福利在线| 欧美丰满少妇xxxxx| 国产精品自在线| 日韩一二三在线视频播| 成人午夜两性视频| 国产精品永久免费在线| 日韩av有码在线| 久久久这里只有精品视频| 97av在线视频免费播放| 日韩电影在线观看免费| 亚洲色无码播放| 日韩av片电影专区| 欧美猛少妇色xxxxx| 久久99热精品这里久久精品| 欧美在线一级视频| 日韩在线视频网站| 欧美激情亚洲视频| 久久久中精品2020中文| 视频一区视频二区国产精品| 欧美性猛交xxxx免费看久久久| 精品国偷自产在线视频99| 亚洲韩国欧洲国产日产av| 日韩中文字幕av| 欧美成人精品在线| 青青草精品毛片| 黑人狂躁日本妞一区二区三区| 国产精品三级美女白浆呻吟| 91精品国产乱码久久久久久蜜臀| 在线日韩欧美视频| 欧美在线性视频| 57pao成人永久免费视频| 亚洲丁香婷深爱综合| 欧美性色19p| 91精品久久久久久久久久| 成人黄色免费网站在线观看| 欧美激情videos| 国产精品成人久久久久| 欧美资源在线观看| 欧美国产一区二区三区| 清纯唯美亚洲激情| 久久的精品视频| 国产精品青草久久久久福利99| 一区二区三区无码高清视频| 精品欧美国产一区二区三区| 91视频国产高清| 一本色道久久88综合日韩精品| 最近2019年中文视频免费在线观看| 亚洲毛片在线免费观看| 中文字幕亚洲一区二区三区| 国产精品视频网| 国产精品美腿一区在线看| 欧美极品少妇xxxxⅹ裸体艺术| 51精品在线观看| 国产精品高潮在线| 中文字幕日韩在线观看| 国产精品极品美女在线观看免费| 中文字幕日韩综合av| 久久精品国产2020观看福利| 国产精品丝袜一区二区三区| 亚洲欧美精品在线| 日韩成人中文字幕在线观看| 日韩高清人体午夜| 亚洲欧美三级在线| 国产精品一区二区三| 久久久视频免费观看| 国产精品亚洲综合天堂夜夜| 在线视频欧美日韩精品| 97人人做人人爱| 成人黄色av网站| 国产乱人伦真实精品视频| 在线观看欧美日韩国产| 国产午夜精品免费一区二区三区| 2021久久精品国产99国产精品| 国产欧美久久久久久| 黑人极品videos精品欧美裸| 亚洲精品suv精品一区二区| 亚洲欧洲国产一区| 亚洲深夜福利在线| 国产日韩欧美视频在线| 成人免费网站在线观看| 色小说视频一区| 91在线免费看网站| 亚洲最大福利网|