首页 > 编程技术 > php

preg_match正则匹配提示pcre.backtrack_limit解决办法

发布时间:2016-11-25 17:39

本文章介绍了关于preg_match正则匹配提示pcre.backtrack_limit解决办法,有需要的朋友可参考一下。


用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('memory_limit', '64M'); , 这样就比较稳妥妥嘎。

 代码如下 复制代码
ini_set('pcre.recursion_limit', 99999);

 


其它解决办法参考文献

 代码如下 复制代码

pcre.backtrack_limit=-1

更多详细内容请查看:http://www.111cn.net/phper/31/42927.htm

我的页面是用UTF-8编码的,要怎么做才能保证导出的excel不会发生乱码?而且不同操作系统上面难道由于系统编码不同,所以一定要提供不同编码格式的文件进行下载吗?

1、定义文件名

2、填充Excel数据

这两个过程中可能会出现一些PHP导出Excel乱码问题,下面我来说一下解决办法:


解决Excel内数据的PHP导出Excel乱码

PHP导出Excel乱码原因:网页编码与Excel编码不一致。

解决办法:既然编码不一致,那让其一致了就OK了。定义Excel的字符集:

 代码如下 复制代码
header(“Content-Type: application/vnd.ms-excel; charset=UTF-8″)

,看到charset=UTF-8了吧,让其与您网页编码一致即可解决Excel内数据乱码的问题了,这个比较简单!

附一个php导出Excel类

 代码如下 复制代码

<?php
/*
 * Created on 2012-2-26
 *
 * To change the template for this generated file go to
 * Window - Preferences - PHPeclipse - PHP - Code Templates
 */
header("Content-type:application/vnd.ms-excel");
header("Content-Disposition:filename=php100.xls");
?>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
<table>
 <tr>
  <td colspan="4"><font color="red" align="center">class infomation</font></td>
 </tr>
 <tr>
  <td><?php echo iconv("UTF-8", "GBK", "编号"); ?></td>
  <td><?php echo iconv("UTF-8", "GBK", "姓名"); ?></td>
  <td><?php echo iconv("UTF-8", "GBK", "学号"); ?></td>
  <td><?php echo iconv("UTF-8", "GBK", "性别"); ?></td>
 </tr>
</table>

总结

导出之前需要转换为GBK

 代码如下 复制代码

iconv("UTF-8", "GBK", $value);

其它方法

最后我采用phpMyAdmin的做法.用HTMLExcel, HTML我们比较熟悉,格式如下.

 代码如下 复制代码

<html xmlns:o="urn:schemas-microsoft-com:office:office"
xmlns:x="urn:schemas-microsoft-com:office:excel"
xmlns="http://www.w3.org/TR/REC-html40">
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
 <head>
  <meta http-equiv="Content-type" content="text/html;charset=UTF-8" />
  <style id="Classeur1_16681_Styles"></style>
 </head>
 <body>
  <div id="Classeur1_16681" align=center x:publishsource="Excel">
   <table x:str border=0 cellpadding=0 cellspacing=0 width=100% style="border-collapse: collapse">
    <tr><td class=xl2216681 nowrap>1234</td><td class=xl2216681 nowrap>Robbin会吐口水</td></tr>
    <tr><td class=xl2216681 nowrap>5678</td><td class=xl2216681 nowrap>javaeye网站</td></tr>
   </table>
  </div>
 </body>
</html>

这下可以直接echo了,又不需要iconv转码,只要设置好HTML里的Content-type(这里用的是UTF-8),是不是有舒服的感觉呢? 当然header还是要加上

Php代码 
 

 代码如下 复制代码
header("Content-type:application/vnd.ms-excel");  
header("Content-Disposition:attachment;filename=export_data.xls"); 

如果是导出中文名字也有可能出现乱码

解决文件名的PHP导出Excel乱码:

乱码原因:客户使用的中文版Windows系统平台,而Windows平台的文件名编码为gb2312(gbk),而我们网页编码为了跟进现存潮流一般都采用utf-8(国际化)编码,这时当我们:

 代码如下 复制代码
header(“Content-Disposition: inline; filename=”" . $filename . “.xls”")

时就会出现乱码,假如你的网页编码就是gb2312那就不用考虑编码问题了。

解决办法:

对$filename转码,执行:

 代码如下 复制代码
iconv(‘utf-8″, “gb2312″, $filename)

。假如你的环境不支持iconv函数可以换别的函数,只要能将$filename的编码转为gbk就行。
但是这样问题又会来了,linux用户又会出现文件名乱码(因为linux平台文件名不是gbk编码)。

考虑到这个问题我采用两个办法:第一:放弃一部分客户,毕竟windows系统用户占绝大部分。第二:像gmail一样,提供两个下载地址。一个文件名gbk编码,一个文件名utf-8编码。

根据我的经验php与mysql中出现乱码一般都是文档编码的问题如 gbk,uft8,gb2312等与页面编码不一致,下面我总结了phpMyAdmin显示中文乱码的解决方法。

先看如图

解决1

php.ini没有extension=php_mysql.dll

碰到这个问题后一般打开phpmyadmin就会出现

乱码错误

我们把php里面的libmysql.dll复制到c:\windows\system32或者c:\winnt\system32

然后重新启动电脑就行

解决2

下面是我的修改过程:
打开 phpMyAdmin 根目录中 libraries/select_lang.lib.php 文件;
找到:

 

 代码如下 复制代码
'zh-gb2312'         => array('zh|chinese simplified', 'chinese_simplified-gb2312', 'zh', '中文'),


将其改为:

 

 代码如下 复制代码
'zh-gb2312-utf-8'         => array('zh|chinese simplified-UTF8', 'chinese_simplified-gb2312', 'zh', '中文'),


再找到:

 

 代码如下 复制代码
'gb2312'       => 'gb2312',


将其改为:

 

 代码如下 复制代码
'gb2312'       => 'latin1',

保存文件退出。

然后从浏览器打开 phpMyAdmin ,在首页选择 Language 为:中文 -Chinese simplified-UTF8

然后打开数据表看看里面的中文是不是已经可以正常显示了:)


解决三


Mysql中的表默认是使用latin1编码的,但内容如果是通过mysql命令等进行添加操作,一般都是gb2312编码插入的,直接在phpmyadmin上 使用语言:中文 - Chinese simplified 下查看是乱码

一、打开 libraries/select_lang.lib.php,查找 $available_languages 数组,在其最后添加一项数据:

Php代码

 代码如下 复制代码
1.'zh-gb2312-utf-8' => array('zh|chinese simplified latin1', 'chinese_simplified-gb2312', 'zh', '&#20013;&#25991;')  
'zh-gb2312-utf-8' => array('zh|chinese simplified latin1', 'chinese_simplified-gb2312', 'zh', '&#20013;&#25991;')

注:&#20013;&#25991; 代表是“中文”两个字。

二、再搜索 $mysql_charset_map 找到这个数组,将其中的一项值 'gb2312' => 'gb2312' 改成 'gb2312' => 'latin1'。

三、重新打开phpmyadmin。语言选择 中文 - Chinese simplified latin1


这时再打开latin1编码的表,就可以看到乱码已经不在了:

本文章收集了关于在使用php时出现错误提示 PHP“内存位置访问无效”的解决方法总结,有需要的朋友可参考一下。

新配置的PHP环境,或者刚做过配置改动,比如新加载的DLL扩展,访问页面,可能会出现“内存位置访问无效。”的错误。主要原因是DLL扩展加载失败。

我们就需要找到是哪一个DLL文件加载出现了问题。排查方法是:

将php.ini中

 代码如下 复制代码

display_startup_errors = Off
改为

display_startup_errors = On 。

这时访问php页面,服务器上会弹出php错误的提示对话框,你就可以明确看到是哪一个dll文件加载失败,有时会有多个dll文件加载失败,需要你先分号(;)注释掉php.ini中提示那个dll后继续访问如此反复排查。

如我打开

 代码如下 复制代码
display_startup_errors = On

出现

Warning  Cannot load module ‘SQLite’ because required module ‘pdo’ is no loaded


解决办法也很简单了,因为加载php_sqlite.dll时未加载到php_pdo.dll文件,所以运行phpinfo()函数时提示内存 位置访问无效。找到php.ini配置文件,然后去掉

 代码如下 复制代码
”;extension=php_pdo.dll”前面的分号, extension=php_sqlite.dll


把出问题的dll都用分号(;)注释掉后,php就可以正常运行了。

如果上面方法无法解决,可参考下面方法

打开php目录开始调试……花了一点时间总算找到了根源

如果你也碰到这个问题那么你也来试一下以下我的解决方案:

打开php的安装目录编辑php.ini这个文件

搜索下面的字段

 代码如下 复制代码

extension=php_exif.dll

找到后在前面加一个;分号

如下:

 代码如下 复制代码

;extension=php_exif.dll

保存重启iis再访问一下php文件看看能否打开了 是否没有出现内存位置访问无效了

我用的linux系统,今天使用phpmyadmin时出现Wrong permissions on configuration file, should not be world writable!错误提示,

查资料一看,原来phpMyAdmin要在755权限下才能正常工作(777不行)。

所以解决办法也就来了:

cd到phpMyAdmin上级目录,

 代码如下 复制代码

chmod -R 755 phpMyAdmin

在我的linux系统用

用以下命令

 代码如下 复制代码
chmod -R 755 /home/wwwroot/phpmyadmin

这个问题就解决了。

标签:[!--infotagslink--]

您可能感兴趣的文章: