【转】WordPress转PHPCMS策略

发布时间:2025-08-09 13:14

职业转型指导:跨领域技能转移策略 #生活技巧# #自我提升技巧# #职业发展培训#

来源:http://www.sjyhome.com/php/wp-to-pc-sql.html

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代码

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

<?php

$doc = new DOMDocument();

$doc->load('wp.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的数据库入库规则,把对应的参数填进去。在?>之前加入以下代码

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

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中的固定链接相同就完成了。

欢迎转载,但请保留原文地址 http://www.sjyhome.com/php/wp-to-pc-sql.html

网址:【转】WordPress转PHPCMS策略 https://klqsh.com/news/view/128932

相关内容

你现在是一名拥有10年经验的wordpress网站seo专家,我准备写一篇关于wordpress技术的文章,请给我一些建议标题,我希望标题要 – 赛文市场营销
WordPress › 错误
新手必读:独立站SEO优化全流程指南——从建设到推广的系统化策略
韩国综艺《转学者》
>如何玩转自媒体
商家如何玩转小红书
SEO优化系列教程:如何构建一个有趣的页面标题来吸引更多的点击量?
转啊转啊转啊转 正着转反过来继续转~ 一开始摄像staff还跟着他转着拍
游戏新手攻略与高级策略详解
“小众爱好”向“大众生活”的转变路径研究.docx

随便看看