提示:mb_substr在于php中是默认不被支持的我们需要在在windows目录下找到php.ini打开编辑,搜索mbstring.dll,找到;extension=php_mbstring.dll把前面的;号去掉才可以使用mb_substr函数哦。
Function: mb_substr( $str, $start, $length, $encoding )
$str,需要截断的字符串
$start,截断开始处
$length,长度(注意,这个跟mb_strimwidth不同,1就代表一个中文字符)
$encoding,编码,我设为 utf-8
例:截断文章标题,控制在15个文字
代码如下 | 复制代码 |
echo "mb_substr:" . mb_substr($str, 0, 7, 'utf-8'); echo "mb_strcut:" . mb_strcut($str, 0, 6, 'utf-8'); |
总结出现来他是可以解决截取中文汉字哦
以前我有讲过程关于php判断远程文件是否存在的文章,那里都介绍利用fopen,sockt,curl函数来实现检查远程文件是否存在了,下面我再介绍利用 get_headers来检查远程文件是否存在,有需要了解的朋友可参考。先来简单了解get_headers()函数
get_headers() 返回一个数组,包含有服务器响应一个 HTTP 请求所发送的标头。
get_headers:发送服务器响应HTTP请求
get_headers(字符串url[链接格式])
get_headers()以数组的形式返回服务器HTTP请求。如果执行失败,将返回FALSE和一个错误的水平E_WARNING》。
可选参数设置为1,get_headers()能分析系统的响应速度和集数组中的键。
注意:使用该函数需要把 php.ini里面的allow_url_fopen = On,才能使用
例
代码如下 | 复制代码 |
<?php print_r(get_headers($url)); print_r(get_headers($url, 1)); 返回值 Array Array |
例
代码如下 | 复制代码 |
//判断远程文件是否存在 |
例2
排除重定向的例子:
代码如下 | 复制代码 |
<?php /** * Fetches all the real headers sent by the server in response to a HTTP request without redirects * 获取不包含重定向的报头 */ function get_real_headers($url,$format=0,$follow_redirect=0) { if (!$follow_redirect) { //set new default options $opts = array('http' => array('max_redirects'=>1,'ignore_errors'=>1) ); stream_context_get_default($opts); } //get headers $headers=get_headers($url,$format); //restore default options if (isset($opts)) { $opts = array('http' => array('max_redirects'=>20,'ignore_errors'=>0) ); stream_context_get_default($opts); } //return return $headers; } |
PHP函数split()的基本语法为
array split ( string $pattern, string $string [, int $limit] )。
例
代码如下 | 复制代码 |
<?php list($user, $pass, $uid, $gid, $extra) = split (":", $passwd_line, 5); |
解析可能用斜线,点,或横线分割的日期:
例 2
代码如下 | 复制代码 |
|
str_split() 函数
如果指定了可选的 split_length 参数,返回数组中的每个元素均为一个长度为 split_length 的字符块,否则每个字符块为单个字符。
如果 split_length 小于 1,返回 FALSE。如果 split_length 参数超过了 string 超过了字符串 string 的长度,整个字符串将作为数组仅有的一个元素返回。
代码如下 | 复制代码 |
<?php $str = "Hello Friend"; $arr1 = str_split($str); print_r($arr1); ?> |
以上例程会输出:
代码如下 | 复制代码 |
Array Array |
chunk_split()函数
string chunk_split ( string $body [, int $chunklen [, string $end ]] )
使用此函数将字符串分割成小块非常有用。例如将 base64_encode() 的输出转换成符合 RFC 2045 语义的字符串。它会在每 chunklen(默认为 76)个字符后边插入 end(默认为“ ”)。此函数会返回新的字符串,而不会修改原有字符串。
Example #1 chunk_split() 例子
代码如下 | 复制代码 |
<?php |
explode — 使用一个字符串分割另一个字符串
Example #1 explode() 例子
代码如下 | 复制代码 |
<?php // 示例 2 ?> |
发送一个原始 HTTP 标头[Http Header]到客户端。标头 (header) 是服务器以 HTTP 协义传 HTML 资料到浏览器前所送出的字串,在标头与 HTML 文件之间尚需空一行分隔
例1
代码如下 | 复制代码 |
<?PHP |
禁止页面在IE中缓存
代码如下 | 复制代码 |
<?PHP |
实现文件下载
代码如下 | 复制代码 |
header('Content-Type: application/octet-stream');//设置内容类型 |
php的函数header()可以向浏览器发送Status标头,
如
代码如下 | 复制代码 |
header(”Status: 404 Not Found”)。 |
但是我发现实际上浏览器返回的响应却是:
代码如下 | 复制代码 |
// ok //设置一个404头: //设置地址被永久的重定向
|
注意事项有以下几点:
•Location和":"之间不能有空格,否则会出现错误(注释:我刚测试了,在我本地环境下,没有跳转页面,但是也没有报错,不清楚什么原因);
•在用header前不能有任何的输出(注释:这点大家都知道的,如果header之前有任何的输出,包括空白,就会出现header already sent by xxx的错误);
•header 后面的东西还会执行的;
函数用法
int preg_match_all ( string pattern, string subject, array matches [, int flags] )
例1
代码如下 | 复制代码 |
<?php 本例将输出: |
例2
URL 中取出域名
代码如下 | 复制代码 |
<?php 本例将输出: domain name is: PPP.NET |
preg_match字符串长度问题
preg_match正则提取目标内容,死活有问题,代码测得死去活来。
后来怀疑PHP 的preg_match有字符串长度限制,果然,发现“pcre.backtrack_limit ”的值默认只设了100000。
解决办法:
代码如下 | 复制代码 |
ini_set('pcre.backtrack_limit', 999999999); |
注:这个参数在php 5.2.0版本之后可用。
另外说说关于:pcre.recursion_limit
pcre.recursion_limit是PCRE的递归限制,这个项如果设很大的值,会消耗所有进程的可用堆栈,最后导致PHP崩溃。
也可以通过修改配置来限制:
代码如下 | 复制代码 |
ini_set('pcre.recursion_limit', 99999); |
实际项目应用中,最好也对内存进行限定设置:ini_set('memory_limit', '64M'); , 这样就比较稳妥妥嘎。