您现在的位置是:首页 > cms教程 > phpcms教程phpcms教程
WordPress转PHPCMS数据库完美转换的方法
听寒2025-05-27phpcms教程已有人查阅
导读WordPress的访问速度不可恭维?那就试试能够生成纯静态的PHPCMS,保证能够让你的网页访问速度有一个质分飞升!为什么选择PHPCMS?见 选择PHPCMS的理由首先我们得分析出,转换过程中
WordPress的访问速度不可恭维?那就试试能够生成纯静态的PHPCMS,保证能够让你的网页访问速度有一个质分飞升!
为什么选择PHPCMS?见 选择PHPCMS的理由首先我们得分析出,转换过程中必须要面对的几个问题。
以下是我的分析
文章ID必须一致,因为大多数情况下文章的URL都是根据ID生成的,为了保证原文章可以继续访问,这一点必须做到。
文章URL必须一致,有些用WP的小伙伴用了postname来定义文章URL,也没有关系,在PHPCMS中也做一个URL自定义的字段(见 phpcms文章内容页如何自定义url),然后再根据我的方法转换下。
发布时间较好相近,你不希望用户看到你整个网站的文章都是同一天转过来的吧?所以要把WP的文章发布时间也转过来。
最重要的就是文章标题和内容了,这2样也搬过来后基本上转移就完成了。
数据库转换工作开始
进入WP后台,选择工具-导出,选择文章,状态为已发布,之后下载导出的文件,我们得到了一个xml文件,我把他命名为wp.xml
本来上面那一步我想通过数据库来导出的,但是WP数据库中存在草稿,最近版本,图像等乱七八糟的信息,虽然也可以通过设置条件来导出,不过总没有上面的方法来的方便吧。
现在WP的所有重要文章都已经导出来了,打开wp.xml,咱们需要把该文件的数据通过PHP保存到数组,好方便导入到PHPCMS的数据库中。但是读取该文件时有些数据是无法识别的,所以必须先做替换工作,使数据标准化。
我们所要的数据中 文章ID <wp:post_id> 内容 <content:encoded> 以及 发布时间 <wp:post_date> 是无法识别的,所以搜索 'wp:post_id'替换为'post_id' 搜索'content:encoded'替换为'content';搜索'wp:post_date'替换为'post_date',现在我们所需要的数据都已经符合标准了,开始撰写PHP代码
下一步,我们需要连接数据库,并按照PHPCMS的数据库入库规则,把对应的参数填进去。在?>之前加入以下代码
为什么选择PHPCMS?见 选择PHPCMS的理由首先我们得分析出,转换过程中必须要面对的几个问题。
以下是我的分析
文章ID必须一致,因为大多数情况下文章的URL都是根据ID生成的,为了保证原文章可以继续访问,这一点必须做到。
文章URL必须一致,有些用WP的小伙伴用了postname来定义文章URL,也没有关系,在PHPCMS中也做一个URL自定义的字段(见 phpcms文章内容页如何自定义url),然后再根据我的方法转换下。
发布时间较好相近,你不希望用户看到你整个网站的文章都是同一天转过来的吧?所以要把WP的文章发布时间也转过来。
最重要的就是文章标题和内容了,这2样也搬过来后基本上转移就完成了。
数据库转换工作开始
进入WP后台,选择工具-导出,选择文章,状态为已发布,之后下载导出的文件,我们得到了一个xml文件,我把他命名为wp.xml
本来上面那一步我想通过数据库来导出的,但是WP数据库中存在草稿,最近版本,图像等乱七八糟的信息,虽然也可以通过设置条件来导出,不过总没有上面的方法来的方便吧。
现在WP的所有重要文章都已经导出来了,打开wp.xml,咱们需要把该文件的数据通过PHP保存到数组,好方便导入到PHPCMS的数据库中。但是读取该文件时有些数据是无法识别的,所以必须先做替换工作,使数据标准化。
我们所要的数据中 文章ID <wp:post_id> 内容 <content:encoded> 以及 发布时间 <wp:post_date> 是无法识别的,所以搜索 'wp:post_id'替换为'post_id' 搜索'content:encoded'替换为'content';搜索'wp:post_date'替换为'post_date',现在我们所需要的数据都已经符合标准了,开始撰写PHP代码
<?php
$doc = new DOMDocument();
$doc->load('wp.xml'); //读取xml文件
$items = $doc->getElementsByTagName( "item" );
foreach( $items as $item )
{
$post_ids = $item->getElementsByTagName( "post_id" );
$post_id = $post_ids->item(0)->nodeValue;
$titles = $item->getElementsByTagName( "title" );
$title = $titles->item(0)->nodeValue;
$contents = $item->getElementsByTagName( "content" );
$content = $contents->item(0)->nodeValue;
$post_dates = $item->getElementsByTagName( "post_date" );
$post_date = $post_dates->item(0)->nodeValue;
$links = $item->getElementsByTagName( "link" );
$link = $links->item(0)->nodeValue;
$arr[]=array($post_id,$title,$content,$link,$post_date);
}
print_r($arr);
?>
这时我们要的数据已经在浏览器中打印出来的,为了看到更清晰的结构,请在网页源代码模式下查看效果。下一步,我们需要连接数据库,并按照PHPCMS的数据库入库规则,把对应的参数填进去。在?>之前加入以下代码
mysql_connect("localhost", "root", "");
mysql_select_db("pc");
mysql_query("set names 'utf8'");
for($i=0;$i<count($arr);$i++){
$id=$arr[$i][0];
$title=$arr[$i][1];
$content=$arr[$i][2];
$link=$arr[$i][3];
$time=strtotime($arr[$i][4]);
$views=rand(100,10000);
mysql_query("INSERT INTO `v9_news` (`id`, `catid`, `typeid`, `title`, `style`, `thumb`, `keywords`, `description`, `posids`, `url`, `listorder`, `status`, `sysadd`, `islink`, `username`, `inputtime`, `updatetime`) VALUES('$id', 6, 0, '$title', '', '', '', '', 0, '$link', 0, 99, 1, 0, 'phpcms', '$time', '$time')");
mysql_query("INSERT INTO `v9_news_data` (`id`, `content`, `readpoint`, `groupids_view`, `paginationtype`, `maxcharperpage`, `template`, `paytype`, `relation`, `voteid`, `allow_comment`, `copyfrom`) VALUES('$id', '$content', 0, '', 0, 10000, '', 0, '', 0, 1, '|0')");
mysql_query("INSERT INTO `v9_hits` (`hitsid`, `catid`, `views`, `yesterdayviews`, `dayviews`, `weekviews`, `monthviews`, `updatetime`) VALUES
('c-1-$id','6', '$views', 0, 0, 0, 0, '$time')");
}
PHPCMS的数据库入库规则,我已经在另一篇文章中详细分析过,见PHPCMS数据库入库模块制作教程上面有一个catid的字段,我的默认分类为ID6,根据自身情况自行修改。之后进入PHPCMS后台,把URL规则改成跟原先WordPress中的固定链接相同就完成了。
本文标签:
很赞哦! ()
相关教程
图文教程
phpcmsv9的$CATEGORYS栏目数组使用方法
首先如果不能用$CATEGORYS这个数组或调不出来内容应加入$CATEGORYS 是一个二维数组,主要用来保存当前频道或者模块所以栏目的基本配置信息。
phpcms生成静态页面的步骤方法
phpcms如何生成静态页面1、进入PHPCMSV9后台设置,找到分类栏目,位置:内容->管理栏目->添加栏目(或者管理栏目、点击对应栏目“修改”):
phpcms模板制作方法
1、首先需要有html基础,divcss然后一些常见的JavaScript语法要懂。2、然后在他们的基础上按照phpcms的语法规则去调用对应的数据。
PHPCMS中PNG水印不显示的解决方法
PHPCMS中PNG水印不显示解决方法:首先打开“phpcms_model_field”和“phpcms_module”数据表;然后将“setting”字段中的“gif”修改成“png”
相关源码
-
(响应式)wordpress模板VieuV4.5主题资讯自媒体博客源码Vieu主题专注于个人博客与企业展示场景,采用响应式设计确保在手机、电脑、平板等多设备上的展示。主题集成会员中心、投稿系统、内容保护等实用功能,满足现代博客网站的建设需求。查看源码 -
(自适应响应式)门窗定制门业带视频功能pbootcms模板下载本模板采用PbootCMS内核开发,为门窗制造、定制安装企业打造,通过可视化后台管理系统快速构建品牌官网。自适应设计确保在手机、平板、电脑等设备上均能获得优质浏览体验查看源码 -
(自适应响应式)法律咨询律师事务所法务pbootcms源码下载为律师事务所、法律咨询机构设计,特别适合展示法律服务、律师团队和成功案例。采用响应式技术,确保在不同设备上都能提供专业的法律信息展示和咨询服务。查看源码 -
帝国CMS7.5养生生活健康网模板完整带会员中心可封装APP本套模板为生活服务类网站设计,适用于两性健康、减肥瘦身、生活资讯等领域。采用帝国CMS7.5核心开发,结构清晰合理,视觉体验舒适,能够有效满足相关行业的建站需求。查看源码 -
帝国cms大气淘宝客网站源码带手机版带火车头采集本款创意礼物导购网站模板为礼物类电商平台设计,采用清爽简约的界面风格,具备完善的商品导购功能。系统支持在文章攻略中灵活插入商品购买链接,实现内容与电商的结合。查看源码 -
(自适应响应式)HTML5电脑手机电子数码产品配件pbootcms模板下载本模板为电脑配件、手机配件及数码周边产品企业设计,基于PbootCMS内核开发。采用现代化响应式布局,适配各类移动设备,能够专业展示各类电子产品配件参数、应用场景和技术特点。模板内置多种产品展示模块,满足不同类型配件企业的展示需求。查看源码
| 分享笔记 (共有 篇笔记) |
