Dreamweaver正则表达式彻底解决zencart中的Session\Cookie报错、XML解析错误以及空白页

Dreamweaver正则表达式彻底解决zencart中的Session\Cookie报错、XML解析错误以及空白页
在使用zencart做外贸商城的时候,由于不同版本的bug,会遇到很多问题。一方面,zencart的升级和数据库以及模板等可能不兼容;另外,zencart插件和zencart的版本也不够兼容。因此,目前我们商城还是采用原来的zencart1.38a的版本,而没有升级到最新的zencart1.39h。
今天,我要讲的是这个版本最容易出错也最不好找出错误的错误,网上很多帖子都围绕这个问题展开讨论,但是,解决的不够彻底,没找到最好的通用的解决方法罢了。
zencart可能的错误如下:
1)Session\Cookie报错,比如:
Warning: session_start() [function.session-start]: Cannot send session cookie - headers already sent by (output started at E:\web\Apache\mydalle\index.php:1) in E:\web\Apache\mydalle\functions\sessions.php on line 108
原因:这个错误是zencart在处理函数session-start()、cookie()、header()之前已经有输出,由于index.php范围太广,很难确定是哪个文件报错,尤其是设置一些SEO。
2)、XML解析错误
XML解析错误:xml处理指令不在实体的开始部分
位置:http://www.mydalle.com/index.php?main_page=rss_feed&feed=new_products
行:8,列:1:<?xml version="1.0" encoding="utf-8"?>
^
原因:这个错误是zencart装了rss feed插件后调用rss时在输出XML头部定义时已经有空行或者其他输出了,也可能和1)是差不多为同一个错误,由于一些代码不规范,禁止输出header前面空行等也不是最好的解决方法。
网上有介绍删除includes/languages/english.php最后的两个空行和删除includes/languages/english/meta_tags.php最后的空行,但是如果其他插件以及源代码等产生了空行,问题依然没有解决,这样,就不是火狐的问题,IE也一样的。
又有人说找到/includes/classes/rss_feed.php文件把<?xml version="1.0" encoding="utf-8"?>这一行$feedContent的变量值设置为空,其实,这是错误的解决办法,前面的空行还是存在,错误还是存在,就算运气好解决了,但解决的不彻底就像定时炸弹。
3)、空白页
原因:一般产生于首页或者购物车Add To Cart等页面,这个错误也很可能是由于空行引起的错误。

从上面可以看出,这类错误最根本的原因就是:
函数session-start()、cookie()、header()之前已经有输出,引起严重的错误。但PHP的报错却找不到到底空行从哪里来。
我的办法是用Dreamweaver正则表达式解决这一问题,而且目前得以彻底。
我用的是Dreamweaver,只要点编辑--查找和替换,然后选文件夹,只需要处理includes文件夹就能解决这一问题。然后选源代码,而且选中使用正则表达式的复选框。最后选择替换全部。
方法如下:
第一步,用正则表达式删除所有空白行(其实这一步不一定要做,我只是为了规范和节省代码)
要把
\n[\s| ]*\r
全部替换为
\n
第二步,用正则表达式删除首尾空白行(这一步必须做,就是删除产生错误的输出。)
^[\s| ]*\n|\n[\s| ]*$
全部替换为

(替换为的填写框什么都不要填就可以了)
注意,正则表达式不要多了空格等,可以先用一个文件进行测试一下。最后替换之前备份一次。
以上两步,做好后错误解决。我是把includes里的文件替换后就可以了,其他文件没有处理,大家的情况可能不太一样。

后来,经过我排查,原来是templates这个文件夹的问题,templates是我们经常改动的,在所难免。

大家有什么意见,也可以给我留言,谢谢!

posted on 2010-12-18 12:20  kuphp  阅读(1596)  评论(0编辑  收藏  举报

导航