六个有用的 PHP 片段或技巧,
网上有很多 PHP 代码片段可以提高开发效率,也可以学习一下其中的技巧而应用在自己的项目中,下面 就精选了几个比较有用的 PHP 片段。
从网页中提取关键词
从指定页面中提取关键词并显示出来。
$meta = get_meta_tags('http://blog.wpjam.com/');$keywords = $meta['keywords'];// 分割关键词$keywords = explode(',', $keywords );// 整理$keywords = array_map( 'trim', $keywords );// 去掉空内容$keywords = array_filter( $keywords );print_r( $keywords );
得到页面中所有的链接
下面代码可以使用 PHP DOM 获取指定页面中的所有链接,仅作抛砖引玉,具体使用自由发挥。
$html = file_get_contents('http://www.example.com');$dom = new DOMDocument();@$dom->loadHTML($html);$xpath = new DOMXPath($dom);$hrefs = $xpath->evaluate("/html/body//a");for ($i = 0; $i < $hrefs->length; $i++) { $href = $hrefs->item($i); $url = $href->getAttribute('href'); echo $url.'<br />';}
自动把页面中的 URL 转换成可点击的超链接
如果你发表一些文章或者做一些页面,要想放上一个超链接,必须编写一个 a 标签。使用下面这段代码可以方便的将 URL 转换成超链接输出。实现方法比较简单,大体思路就是用正则匹配出来 URL 然后处理输出超链接。
function _make_url_clickable_cb($matches) {$ret = '';$url = $matches[2];if ( empty($url) )return $matches[0];// 去掉 URL 后面的标点符号if ( in_array(substr($url, -1), array('.', ',', ';', ':')) === true ) {$ret = substr($url, -1);$url = substr($url, 0, strlen($url)-1);}return $matches[1] . "<a href=\"$url\" rel=\"nofollow\">$url</a>" . $ret;}function _make_web_ftp_clickable_cb($matches) {$ret = '';$dest = $matches[2];$dest = 'http://' . $dest;if ( empty($dest) )return $matches[0];if ( in_array(substr($dest, -1), array('.', ',', ';', ':')) === true ) {$ret = substr($dest, -1);$dest = substr($dest, 0, strlen($dest)-1);}return $matches[1] . "<a href=\"$dest\" rel=\"nofollow\">$dest</a>" . $ret;}function _make_email_clickable_cb($matches) {$email = $matches[2] . '@' . $matches[3];return $matches[1] . "<a href=\"mailto:$email\">$email</a>";}function make_clickable($ret) {$ret = ' ' . $ret;$ret = preg_replace_callback('#([\s>])([\w]+?://[\w\\x80-\\xff\#$%&~/.\-;:=,?@\[\]+]*)#is', '_make_url_clickable_cb', $ret);$ret = preg_replace_callback('#([\s>])((www|ftp)\.[\w\\x80-\\xff\#$%&~/.\-;:=,?@\[\]+]*)#is', '_make_web_ftp_clickable_cb', $ret);$ret = preg_replace_callback('#([\s>])([.0-9a-z_+-]+)@(([0-9a-z-]+\.)+[0-9a-z]{2,})#i', '_make_email_clickable_cb', $ret);$ret = preg_replace("#(<a( [^>]+?>|>))<a [^>]+?>([^>]+?)</a></a>#i", "$1$3</a>", $ret);$ret = trim($ret);return $ret;}
用 PHP 生成 Data URI 代码
通常把图片编码成 Data URI 格式用在网页中来减少 HTTP 请求来提升前端性能。同时还有一些其他的用途。下面代码可以将文件编码成 Data URI。
function data_uri($file, $mime) { $contents=file_get_contents($file); $base64=base64_encode($contents); echo "data:$mime;base64,$base64";}
将远程图片下载到本地服务器
特别是转载文章等,为了防止对方网站关掉而导致图片丢失,通常会在发表文章的时候,将远程服务器上的图片下载到本地服务器上。下面代码简单的实现了这个需求,更多的储存位置、遍历链接还需要你自己自定义:
$image = file_get_contents('http://www.url.com/image.jpg');file_put_contents('/images/image.jpg', $image);
去掉文中的无用标签
当从一些文本编辑器(例如 Word)中将文本复制到网页编辑器中时,可能会有一些额外的无用标签,例如一些指定文字样式的 style 等。下面代码可以通过正则匹配来去掉这些无用标签,净化文本:
function cleanHTML($html) {// 首先去掉无用的标签(可以自定义更多需要清除的标签)$html = ereg_replace("<(/)?(font|span|del|ins)[^>]*>","",$html);// 然后再运行两遍去掉无用属性$html = ereg_replace("<([^>]*)(class|lang|style|size|face)=("[^"]*"|'[^']*'|[^>]+)([^>]*)>","<\1>",$html);$html = ereg_replace("<([^>]*)(class|lang|style|size|face)=("[^"]*"|'[^']*'|[^>]+)([^>]*)>","<\1>",$html);return $html}
如果你也收藏了一些有用的 PHP 代码,也可以向 我爱水煮鱼 投稿哦 😀
本站推荐使用的主机:,国外主机建议使用。
声明:本站所有文章和内容,如无特殊说明或标注,均为本站原创发布或者来源互联网投稿,内容仅限个人本地测试使用非商用,请于获取后24小时内删除,如若本站内容侵犯了原著者的合法权益,可联系我们进行删除处理。本站所有文章和软件均免费获取和阅读,本站不收取任何费用,但因内容和软件获取链接会占用本站资源,故会收取资源占用费用,用户若不同意支付费用可选择关闭网页。