代码如下。
<? //删除字符串中html标签 //by http://www. function delete_htm($scr) { for($i=0;$i<strlen($scr);$i++) { if(substr($scr,$i,1)=="<") { while(substr($scr,$i,1)!=">")$i++; $i++; } $str=$str.substr($scr,$i,1); } return($str); } ?>
您可能感兴趣的文章:
php去除HTML标签的二种方法
php 去除多余的HTML标签
php用strip_tags完整去除所有html标签的实例分享
php过滤html标记的函数strip_tags用法举例(图文)
php删除html标签的三种方法分享
php删除html标签及字符串中html标签的代码
去掉内容中 html 标签的代码
提取html标签的php代码
php正则过滤html标签、空格、换行符等的代码示例
php去除html标签获得输入纯文本文档strip_tags
php使HTML标签自动补全闭合函数的代码
php实现html标签自动补全的代码
thinkPHP的Html模板标签的使用方法
例1,用file_get_contents 以get方式获取内容。
<?php $url='http://www./'; $html = file_get_contents($url); //print_r($http_response_header); ec($html); printhr(); printarr($http_response_header); printhr(); ?>
例2,用fopen打开url, 以get方式获取内容。
<? $fp = fopen($url, 'r'); printarr(stream_get_meta_data($fp)); printhr(); while(!feof($fp)) { $result .= fgets($fp, 1024); } echo "url body: $result"; printhr(); fclose($fp); ?>
例3,用file_get_contents函数,以post方式获取url。
<?php $data = array ('foo' => 'bar'); $data = http_build_query($data); $opts = array ( 'http' => array ( 'method' => 'POST', 'header'=> "Content-type: application/x-www-form-urlencoded" . "Content-Length: " . strlen($data) . "", 'content' => $data ), ); $context = stream_context_create($opts); $html = file_get_contents('http://localhost/e/admin/test.html', false, $context); echo $html; ?>
例4,用fsockopen函数打开url,以get方式获取完整的数据,包括header和body。
<? function get_url ($url,$cookie=false) { $url = parse_url(/blog_article/$url/index.html); $query = $url[path]."?".$url[query]; ec("Query:".$query); $fp = fsockopen( $url[host], $url[port]?$url[port]:80 , $errno, $errstr, 30); if (!$fp) { return false; } else { $request = "GET $query HTTP/1.1"; $request .= "Host: $url[host]"; $request .= "Connection: Close"; if($cookie) $request.="Cookie: $cookie\n"; $request.=""; fwrite($fp,$request); while(!@feof($fp)) { $result .= @fgets($fp, 1024); } fclose($fp); return $result; } } //获取url的html部分,去掉header function GetUrlHTML($url,$cookie=false) { $rowdata = get_url(/blog_article/$url,$cookie/index.html); if($rowdata) { $body= stristr($rowdata,""); $body=substr($body,4,strlen($body)); return $body; } return false; } ?>
例5,用fsockopen函数打开url,以POST方式获取完整的数据,包括header和body。
<? function HTTP_Post($URL,$data,$cookie, $referrer="") { // parsing the given URL $URL_Info=parse_url(/blog_article/$URL/index.html); // Building referrer if($referrer=="") // if not given use this script as referrer $referrer="111"; // making string from $data foreach($data as $key=>$value) $values[]="$key=".urlencode($value); $data_string=implode("&",$values); // Find out which port is needed - if not given use standard (=80) if(!isset($URL_Info["port"])) $URL_Info["port"]=80; // building POST-request: $request.="POST ".$URL_Info["path"]." HTTP/1.1\n"; $request.="Host: ".$URL_Info["host"]."\n"; $request.="Referer: $referer\n"; $request.="Content-type: application/x-www-form-urlencoded\n"; $request.="Content-length: ".strlen($data_string)."\n"; $request.="Connection: close\n"; $request.="Cookie: $cookie\n"; $request.="\n"; $request.=$data_string."\n"; $fp = fsockopen($URL_Info["host"],$URL_Info["port"]); fputs($fp, $request); while(!feof($fp)) { $result .= fgets($fp, 1024); } fclose($fp); return $result; } printhr(); ?>
例6,使用curl库,curl库需要在php.ini中开启curl扩展。
<? $ch = curl_init(); $timeout = 5; curl_setopt ($ch, CURLOPT_URL, 'http://www.baidu.com/'); curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt ($ch, CURLOPT_CONNECTTIMEOUT, $timeout); $file_contents = curl_exec($ch); curl_close($ch); echo $file_contents; ?>
关于curl库:
curl官方网站http://curl.haxx.se/
curl 是使用URL语法的传送文件工具,支持FTP、FTPS、HTTP HTPPS SCP SFTP TFTP TELNET DICT FILE和LDAP。curl 支持SSL证书、HTTP POST、HTTP PUT 、FTP 上传,kerberos、基于HTT格式的上传、代理、cookie、用户+口令证明、文件传送恢复、http代理通道和大量其他有用的技巧。
示例代码:
<? function printarr(array $arr) { echo "<br> Row field count: ".count($arr)."<br>"; foreach($arr as $key=>$value) { echo "$key=$value <br>"; } } ?>
7、有些主机商关掉了php的allow_url_fopen选项,此时无法直接使用file_get_contents获取远程web页面的内容。
此时可以使用函数curl。
来看看file_get_contents和curl两个函数实现同样功能的不同方法。
file_get_contents函数:
<?php $file_contents = file_get_contents('http://www./'); echo $file_contents; ?>
curl函数:
<?php $ch = curl_init(); $timeout = 5; curl_setopt ($ch, CURLOPT_URL, 'http://www.'); curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt ($ch, CURLOPT_CONNECTTIMEOUT, $timeout); $file_contents = curl_exec($ch); curl_close($ch); echo $file_contents; ?>
更专业点的实现代码,用function_exists函数来判断某函数是否存在,然后确定用哪个函数来实现。
<?php function vita_get_url_content($url) { if(function_exists('file_get_contents')) { $file_contents = file_get_contents($url); } else { $ch = curl_init(); $timeout = 5; curl_setopt ($ch, CURLOPT_URL, $url); curl_setopt ($ch, CURLOPT_RETURNTRANSFER, 1); curl_setopt ($ch, CURLOPT_CONNECTTIMEOUT, $timeout); $file_contents = curl_exec($ch); curl_close($ch); } return $file_contents; } ?>
有个苦逼的事情要告诉你,如果你的主机商把file_get_contents和curl都关闭了,以上的函数会报错的哦。
number_format函数
number_format(要格式化的数字,保留的小数位数,小数点的字符串,千位分隔符) //共4个参数
number_format 函数的作用是格式化数字.
上面列出的4个参数中,第一个必选项,其他都是可选项.
参数说明:
要格式化的数字 (不解释)
保留的小数位数 (可选项) 格式化数字后准备保留几位小数
小数点字符串 (可选项) 默认是 . 如果想用*号来充当小数点的话,参数值为 * 例如: 189*00 (189保留2位小数,*为小数点)
千位分隔符 (可选项) 默认是 , 如果想指定其他符号来千位分隔,参数值就为要指定的分号 例如:189^000^000.00 这里以符号^ 来充当千位分隔符.
示例:
number_format(288); --输出 288 number_format(365,2); --输出 365.00 number_format(365000000,3,".") (将数字 365000000 保留3位小数,小数点用"."表示) --输出: 365,000,000.000 number_format(365000000,2,".","*") (将数字 365000000 保留2位小数,小数点用"."表示,千位分隔符用"*"表示) --输出: 365*000*000.00