必须收藏的php实用代码片段
程序员文章站
2024-04-01 11:27:04
在编写代码的时候有个神奇的工具总是好的!下面这里收集了 40+ php 代码片段,可以帮助你开发php 项目。 之前已经为大家分享了《必须收藏的23个php实用代码片段》。...
在编写代码的时候有个神奇的工具总是好的!下面这里收集了 40+ php 代码片段,可以帮助你开发php 项目。 之前已经为大家分享了《必须收藏的23个php实用代码片段》。
这些php 片段对于php 初学者也非常有帮助,非常容易学习,让我们开始学习吧~
24. 从 php 数据创建 csv 文件
function generatecsv($data, $delimiter = ',', $enclosure = '"') { $handle = fopen('php://temp', 'r+'); foreach ($data as $line) { fputcsv($handle, $line, $delimiter, $enclosure); } rewind($handle); while (!feof($handle)) { $contents .= fread($handle, 8192); } fclose($handle); return $contents; }
语法:
<?php $data[0] = "apple"; $data[1] = "oranges"; generatecsv($data, $delimiter = ',', $enclosure = '"'); ?>
25. 解析 xml 数据
$xml_string="<?xml version='1.0'?> <moleculedb> <molecule name='benzine'> <symbol>ben</symbol> <code>a</code> </molecule> <molecule name='water'> <symbol>h2o</symbol> <code>k</code> </molecule> </moleculedb>"; //load the xml string using simplexml function $xml = simplexml_load_string($xml_string); //loop through the each node of molecule foreach ($xml->molecule as $record) { //attribute are accessted by echo $record['name'], ' '; //node are accessted by -> operator echo $record->symbol, ' '; echo $record->code, ''; }
26. 解析 json 数据
$json_string='{"id":1,"name":"rolf","country":"russia","office":["google","oracle"]} '; $obj=json_decode($json_string); //print the parsed data echo $obj->name; //displays rolf echo $obj->office[0]; //displays google
27. 获取当前页面 url
这个 php 片段可以帮助你让用户登录后直接跳转到之前浏览的页面
function current_url() { $url = "http://" . $_server['http_host'] . $_server['request_uri']; $validurl = str_replace("&", "&", $url); return validurl; }
语法:
<?php echo "currently you are on: ".current_url(); ?>
28. 从任意的 twitter 账号获取最新的 tweet
function my_twitter($username) { $no_of_tweets = 1; $feed = "http://search.twitter.com/search.atom?q=from:" . $username . "&rpp=" . $no_of_tweets; $xml = simplexml_load_file($feed); foreach($xml->children() as $child) { foreach ($child as $value) { if($value->getname() == "link") $link = $value['href']; if($value->getname() == "content") { $content = $value . ""; echo '<p class="twit">'.$content.' <a class="twt" href="'.$link.'" title=""> </a></p>'; } } } }
语法:
<?php $handle = "koonktech"; my_twitter($handle); ?>
29. 转发数量
使用这个 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://blog.koonk.com"; $count = tweetcount($url); return $count; ?>
30. 计算两个日期的差
<?php $date1 = date( 'y-m-d' ); $date2 = "2015-12-04"; $diff = abs(strtotime($date2) - strtotime($date1)); $years = floor($diff / (365*60*60*24)); $months = floor(($diff - $years * 365*60*60*24) / (30*60*60*24)); $days = floor(($diff - $years * 365*60*60*24 - $months*30*60*60*24)/ (60*60*24)); printf("%d years, %d months, %d days\n", $years, $months, $days); -------------------------------------------------------- or $date1 = new datetime("2007-03-24"); $date2 = new datetime("2009-06-26"); $interval = $date1->diff($date2); echo "difference " . $interval->y . " years, " . $interval->m." months, ".$interval->d." days "; // shows the total amount of days (not divided into years, months and days like above) echo "difference " . $interval->days . " days "; -------------------------------------------------------- or /** * calculate differences between two dates with precise semantics. based on phps datetime::diff() * implementation by derick rethans. ported to php by emil h, 2011-05-02. no rights reserved. * * see here for original code: * http://svn.php.net/viewvc/php/php-src/trunk/ext/date/lib/tm2unixtime.c?revision=302890&view=markup * http://svn.php.net/viewvc/php/php-src/trunk/ext/date/lib/interval.c?revision=298973&view=markup */ function _date_range_limit($start, $end, $adj, $a, $b, $result) { if ($result[$a] < $start) { $result[$b] -= intval(($start - $result[$a] - 1) / $adj) + 1; $result[$a] += $adj * intval(($start - $result[$a] - 1) / $adj + 1); } if ($result[$a] >= $end) { $result[$b] += intval($result[$a] / $adj); $result[$a] -= $adj * intval($result[$a] / $adj); } return $result; } function _date_range_limit_days($base, $result) { $days_in_month_leap = array(31, 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31); $days_in_month = array(31, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31); _date_range_limit(1, 13, 12, "m", "y", &$base); $year = $base["y"]; $month = $base["m"]; if (!$result["invert"]) { while ($result["d"] < 0) { $month--; if ($month < 1) { $month += 12; $year--; } $leapyear = $year % 400 == 0 || ($year % 100 != 0 && $year % 4 == 0); $days = $leapyear ? $days_in_month_leap[$month] : $days_in_month[$month]; $result["d"] += $days; $result["m"]--; } } else { while ($result["d"] < 0) { $leapyear = $year % 400 == 0 || ($year % 100 != 0 && $year % 4 == 0); $days = $leapyear ? $days_in_month_leap[$month] : $days_in_month[$month]; $result["d"] += $days; $result["m"]--; $month++; if ($month > 12) { $month -= 12; $year++; } } } return $result; } function _date_normalize($base, $result) { $result = _date_range_limit(0, 60, 60, "s", "i", $result); $result = _date_range_limit(0, 60, 60, "i", "h", $result); $result = _date_range_limit(0, 24, 24, "h", "d", $result); $result = _date_range_limit(0, 12, 12, "m", "y", $result); $result = _date_range_limit_days(&$base, &$result); $result = _date_range_limit(0, 12, 12, "m", "y", $result); return $result; } /** * accepts two unix timestamps. */ function _date_diff($one, $two) { $invert = false; if ($one > $two) { list($one, $two) = array($two, $one); $invert = true; } $key = array("y", "m", "d", "h", "i", "s"); $a = array_combine($key, array_map("intval", explode(" ", date("y m d h i s", $one)))); $b = array_combine($key, array_map("intval", explode(" ", date("y m d h i s", $two)))); $result = array(); $result["y"] = $b["y"] - $a["y"]; $result["m"] = $b["m"] - $a["m"]; $result["d"] = $b["d"] - $a["d"]; $result["h"] = $b["h"] - $a["h"]; $result["i"] = $b["i"] - $a["i"]; $result["s"] = $b["s"] - $a["s"]; $result["invert"] = $invert ? 1 : 0; $result["days"] = intval(abs(($one - $two)/86400)); if ($invert) { _date_normalize(&$a, &$result); } else { _date_normalize(&$b, &$result); } return $result; } $date = "2014-12-04 19:37:22"; echo '<pre>'; print_r( _date_diff( strtotime($date), time() ) ); echo '</pre>'; ?>
31. 删除文件夹内容
function delete($path) { if (is_dir($path) === true) { $files = array_diff(scandir($path), array('.', '..')); foreach ($files as $file) { delete(realpath($path) . '/' . $file); } return rmdir($path); } else if (is_file($path) === true) { return unlink($path); } return false; }
语法:
<?php $path = "images/"; delete($path); // this will delete images folder along with its contents. ?>
32. 搜索和高亮字符串中的关键字
function highlighter_text($text, $words) { $split_words = explode( " " , $words ); foreach($split_words as $word) { $color = "#4285f4"; $text = preg_replace("|($word)|ui" , "<span style=\"color:".$color.";\"><b>$1</b></span>" , $text ); } return $text; }
语法:
<?php $string = "i like chocolates and i like apples"; $words = "apple"; echo highlighter_text($string ,$words); ?>
33. 写入文件
<? $filename = 'blog.csv'; $fp = fopen($filename, 'w'); $output = " hello "; $output .= " world! "; $output .= "\r\n"; fputs($fp, $output); fclose($fp); ?>
34. 根据 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); ?>
35. 检测 url 是否有效
function isvalidurl($url) { $check = 0; if (filter_var($url, filter_validate_url) !== false) { $check = 1; } return $check; }
语法:
<?php $url = "http://koonk.com"; $check = checkvalidurl($url); echo $check; //if returns 1 then url is valid. ?>
36. 生成二维码
function qr_code($data, $type = "txt", $size ='150', $ec='l', $margin='0') { $types = array("url" =--> "http://", "tel" => "tel:", "txt"=>"", "email" => "mailto:"); if(!in_array($type,array("url", "tel", "txt", "email"))) { $type = "txt"; } if (!preg_match('/^'.$types[$type].'/', $data)) { $data = str_replace("\\", "", $types[$type]).$data; } $ch = curl_init(); $data = urlencode($data); curl_setopt($ch, curlopt_url, 'http://chart.apis.google.com/chart'); curl_setopt($ch, curlopt_post, true); curl_setopt($ch, curlopt_postfields, 'chs='.$size.'x'.$size.'&cht=qr&chld='.$ec.'|'.$margin.'&chl='.$data); curl_setopt($ch, curlopt_returntransfer, true); curl_setopt($ch, curlopt_header, false); curl_setopt($ch, curlopt_timeout, 30); $response = curl_exec($ch); curl_close($ch); return $response; }
语法:
<?php header("content-type: image/png"); echo qr_code("http://koonk.com", "url"); ?>
37. 计算两个地图坐标之间的距离
function getdistancebetweenpointsnew($latitude1, $longitude1, $latitude2, $longitude2) { $theta = $longitude1 - $longitude2; $miles = (sin(deg2rad($latitude1)) * sin(deg2rad($latitude2))) + (cos(deg2rad($latitude1)) * cos(deg2rad($latitude2)) * cos(deg2rad($theta))); $miles = acos($miles); $miles = rad2deg($miles); $miles = $miles * 60 * 1.1515; $feet = $miles * 5280; $yards = $feet / 3; $kilometers = $miles * 1.609344; $meters = $kilometers * 1000; return compact('miles','feet','yards','kilometers','meters'); }
语法:
<?php $point1 = array('lat' => 40.770623, 'long' => -73.964367); $point2 = array('lat' => 40.758224, 'long' => -73.917404); $distance = getdistancebetweenpointsnew($point1['lat'], $point1['long'], $point2['lat'], $point2['long']); foreach ($distance as $unit => $value) { echo $unit.': '.number_format($value,4).''; } ?>
38. 获取一个特定话题标签的所有 tweets
function gettweets($hash_tag) { $url = 'http://search.twitter.com/search.atom?q='.urlencode($hash_tag) ; echo "<p>connecting to <strong>$url</strong> ...</p>"; $ch = curl_init($url); curl_setopt ($ch, curlopt_returntransfer, true); $xml = curl_exec ($ch); curl_close ($ch); //if you want to see the response from twitter, uncomment this next part out: //echo "<p>response:</p>"; //echo "<pre>".htmlspecialchars($xml)."</pre>"; $affected = 0; $twelement = new simplexmlelement($xml); foreach ($twelement->entry as $entry) { $text = trim($entry->title); $author = trim($entry->author->name); $time = strtotime($entry->published); $id = $entry->id; echo "<p>tweet from ".$author.": <strong>".$text."</strong> <em>posted ".date('n/j/y g:i a',$time)."</em></p>"; } return true ; }
39. 添加 th,st,nd 或者 rd 作为数字的后缀
friday the 13th function ordinal($cdnl){ $test_c = abs($cdnl) % 10; $ext = ((abs($cdnl) %100 < 21 && abs($cdnl) %100 > 4) ? 'th' : (($test_c < 4) ? ($test_c < 3) ? ($test_c < 2) ? ($test_c < 1) ? 'th' : 'st' : 'nd' : 'rd' : 'th')); return $cdnl.$ext; }
语法:
<?php $number = 10; echo ordinal($number); //output is 10th ?>
40. 限制文件下载的速度
<?php // local file that should be send to the client $local_file = 'test-file.zip'; // filename that the user gets as default $download_file = 'your-download-name.zip'; // set the download rate limit (=> 20,5 kb/s) $download_rate = 20.5; if(file_exists($local_file) && is_file($local_file)) { // send headers header('cache-control: private'); header('content-type: application/octet-stream'); header('content-length: '.filesize($local_file)); header('content-disposition: filename='.$download_file); // flush content flush(); // open file stream $file = fopen($local_file, "r"); while(!feof($file)) { // send the current file part to the browser print fread($file, round($download_rate * 1024)); // flush the content to the browser flush(); // sleep one second sleep(1); } // close file stream fclose($file);} else { die('error: the file '.$local_file.' does not exist!'); } ?>
41. 把文本转换成图片
<?php header("content-type: image/png"); $string = $_get['text']; $im = imagecreatefrompng("images/button.png"); $color = imagecolorallocate($im, 255, 255, 255); $px = (imagesx($im) - 7.5 * strlen($string)) / 2; $py = 9; $fontsize = 1; imagestring($im, fontsize, $px, $py, $string, $color); imagepng($im); imagedestroy($im); ?>
42. 获取远程文件的大小
function remote_filesize($url, $user = "", $pw = "") { ob_start(); $ch = curl_init($url); curl_setopt($ch, curlopt_header, 1); curl_setopt($ch, curlopt_nobody, 1); if(!empty($user) && !empty($pw)) { $headers = array('authorization: basic ' . base64_encode("$user:$pw")); curl_setopt($ch, curlopt_httpheader, $headers); } $ok = curl_exec($ch); curl_close($ch); $head = ob_get_contents(); ob_end_clean(); $regex = '/content-length:\s([0-9].+?)\s/'; $count = preg_match($regex, $head, $matches); return isset($matches[1]) ? $matches[1] : "unknown"; }
语法
<?php $file = "http://koonk.com/images/logo.png"; $size = remote_filesize($url); echo $size; ?>
43. 使用 imagebrick 进行 pdf 到图像的转换
<?php $pdf_file = './pdf/demo.pdf'; $save_to = './jpg/demo.jpg'; //make sure that apache has permissions to write in this folder! (common problem) //execute imagemagick command 'convert' and convert pdf to jpg with applied settings exec('convert "'.$pdf_file.'" -colorspace rgb -resize 800 "'.$save_to.'"', $output, $return_var); if($return_var == 0) { //if exec successfuly converted pdf to jpg print "conversion ok"; } else print "conversion failed.".$output; ?>
44. 使用 tinyurl 生成短网址
function get_tiny_url($url) { $ch = curl_init(); $timeout = 5; curl_setopt($ch,curlopt_url,'http://tinyurl.com/api-create.php?url='.$url); curl_setopt($ch,curlopt_returntransfer,1); curl_setopt($ch,curlopt_connecttimeout,$timeout); $data = curl_exec($ch); curl_close($ch); return $data; }
语法:
<?php $url = "http://blog.koonk.com/2015/07/hello-world"; $tinyurl = get_tiny_url($url); echo $tinyurl; ?>
45. youtube 下载链接生成器
使用下面的 php 片段可以让你的用户下载 youtube 视频
function str_between($string, $start, $end) { $string = " ".$string; $ini = strpos($string,$start); if ($ini == 0) return ""; $ini += strlen($start); $len = strpos($string,$end,$ini) - $ini; return substr($string,$ini,$len); } function get_youtube_download_link(){ $youtube_link = $_get['youtube']; $youtube_page = file_get_contents($youtube_link); $v_id = str_between($youtube_page, "&video_id=", "&"); $t_id = str_between($youtube_page, "&t=", "&"); $flv_link = "http://www.youtube.com/get_video?video_id=$v_id&t=$t_id"; $hq_flv_link = "http://www.youtube.com/get_video?video_id=$v_id&t=$t_id&fmt=6"; $mp4_link = "http://www.youtube.com/get_video?video_id=$v_id&t=$t_id&fmt=18"; $threegp_link = "http://www.youtube.com/get_video?video_id=$v_id&t=$t_id&fmt=17"; echo "\t\tdownload (right-click > save as):\n\t\t"; echo "<a href=\"$flv_link\">flv</a>\n\t\t"; echo "<a href=\"$hq_flv_link\">hq flv (if available)</a>\n\t\t"; echo "<a href=\"$mp4_link\">mp4</a>\n\t\t"; echo "<a href=\"$threegp_link\">3gp</a>\n"; }
46. facebook 样式的时间戳
facebook (x mins age, y hours ago etc) function nicetime($date) { if(empty($date)) { return "no date provided"; } $periods = array("second", "minute", "hour", "day", "week", "month", "year", "decade"); $lengths = array("60","60","24","7","4.35","12","10"); $now = time(); $unix_date = strtotime($date); // check validity of date if(empty($unix_date)) { return "bad date"; } // is it future date or past date if($now > $unix_date) { $difference = $now - $unix_date; $tense = "ago"; } else { $difference = $unix_date - $now; $tense = "from now"; } for($j = 0; $difference >= $lengths[$j] && $j < count($lengths)-1; $j++) { $difference /= $lengths[$j]; } $difference = round($difference); if($difference != 1) { $periods[$j].= "s"; } return "$difference $periods[$j] {$tense}"; }
语法:
<?php $date = "2015-07-05 03:45"; $result = nicetime($date); // 2 days ago ?>
以上就是本文的全部内容,希望对大家的学习有所帮助。