先看如图
解决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', '中文') 'zh-gb2312-utf-8' => array('zh|chinese simplified latin1', 'chinese_simplified-gb2312', 'zh', '中文') |
注:中文 代表是“中文”两个字。
二、再搜索 $mysql_charset_map 找到这个数组,将其中的一项值 'gb2312' => 'gb2312' 改成 'gb2312' => 'latin1'。
三、重新打开phpmyadmin。语言选择 中文 - Chinese simplified latin1
这时再打开latin1编码的表,就可以看到乱码已经不在了:
用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
本文章收集了关于在使用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 |
这个问题就解决了。
今天把php版本升级了一下,突然就出现了Deprecated: Function set_magic_quotes_runtime() is deprecated 错误,下面我们总结了原因分析:
最近升级了PHP版本,新版本的PHP对set_magic_quotes_runtime()已经关闭
在PHP5.3后此特性(set_magic_quotes_runtime())已经关闭。
而且在PHP6中已经完全移除此特性。
解决办法
你可以注释或者删除掉出错的行,或者是在set_magic_quotes_runtime()前面加@符号。
也可以在程序中如下操作
代码如下 | 复制代码 |
find: replace: |
这样问题就解决了。