将phpcms转换成HTTPS需要进行以下修改:
1、如果已经安装好phpcms,则需要对caches/configs/system.php中的配置选项做替换,将"http://"全部替换为"https://"。如有必要,数据库中已存在的链接也要完全替换为https开头。
2、程序修改部分:
(1)修改phpcms/modules/admin/site.php 大约45行和128行的正则
('/http:\/\/(.+)\/$/i', $domain))
修改为
('/(http|https):\/\/(.+)\/$/i', $domain))
(2)修改phpcms/modules/admin/templates/setting.tpl.php 大约18行中的正则
http:\/\/(.+)[^/]$
修改为
http?:\/\/(.+)[^/]$
(3)修改phpcms/modules/admin/templates/site_add.tpl.php 大约13行中的正则
http:\/\/(.+)\/$
修改为
http?:\/\/(.+)\/$
(4)修改phpcms/modules/admin/templates/site_edit.tpl.php 大约11行中的正则
http:\/\/(.+)\/$
修改为
http?:\/\/(.+)\/$
(5)修改phpcms/modules/link/index.php 大约41行和51行中的正则
/^http:\/\/(.*)/i
修改为
/^http?:\/\/(.*)/i
(6)修改phpcms/modules/link/templates/link_add.tpl.php 大约10行中的正则
^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&]*([^<>])*$
修改为
^http?:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&]*([^<>])*$
(7)修改phpcms/modules/link/templates/link_edit.tpl.php 大约11行中的正则
^http:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&]*([^<>])*$
修改为
^http?:\/\/[A-Za-z0-9]+\.[A-Za-z0-9]+[\/=\?%\-&]*([^<>])*$
严格按照以上步骤修改后,注册用户 帐号登录等操作完全正常 和PHPSSO通信完全正常,后台添加信息和前台链接URL完全正常
注意:
a.如注册用户提示‘操作失败’,请在后台会员模块设置中关闭‘注册时可选会员模型’或者保证会员不少于两个会员模型
b.在PHP5.6或以上的PHP版本中会出现和PHPSSO无法正常通信的情况,因为PHP5.6及以上fsockopen和file_get_contents等函数openssl需要验证目标的SSL证书是否可信,需要安装openssl根证书才可以,否则openssl会报警告信息 证书验证失败!
3、经过上面修改后,phpcms中的内容可通过https访问,但分页出现错误。解决方法为:
打开文件 phpcms\libs\functions \global.func.php ,找到738行的位置:
$url = str_replace(array('https://','//','~'), array('~','/','https://'), $url);
修改为
$url = str_replace(array('https://','//','~'), array('~','/','https://'), $url);
经过以上三步,phpcms完美支持https,结合页面静态化和url伪静态规则,亲测静态页面也可用https。 以上内容一般百度也能找到,接下来就是修改管理内容链接不对的问题。 打开文件 phpcms\modules\content\templates content_list.tpl.php ,找到大约97行的位置: 将:
elseif(strpos($r['url'],'https://')!==false)
改为
elseif(strpos($r['url'],'https://')!==false)