快速为wordpress网站开发对外的数据接口

也许有同学会说,wordpress具有强大的主题切换能力,通过一个简单的主题预览插件就可以实现不同主题显示不同的内容,接口就在另一个主题下实现!

没错,这种方式确实可以,但是由于wordpress目前cms功能越来越强大,很多网站都使用了自定义模板、register_post_type、register_nav_menus等功能,wordpress的主题切换不能很好的兼容这些地方(即使register_post_type代码照搬)。即使克服了以上的困难,如果以后网站增加版块或者新功能,要维护就得同时改动网站主题和api主题模板,工作量巨大。

那么有没有什么简单的方法呢?

以下这个方法可以在原有的主题基础上进行方便的接口开发。

如何做呢?

首先在网站所用主题的functions.php文件中增加以下代码:

  1.    if(isset($_GET['json'])){
  2.      add_filter('template_include','wp_my_api');
  3.    }
  4.    function wp_my_api($template){
  5.       return preg_replace('#([^/]+\.php)#','api/$1',$template);
  6.    }

然后在网站当前所用主题目录下新建一个文件夹,名字为“api”。然后把主题下的模板文件复制进api文件夹里,就可以对这些模板进行接口数据转化了。比如输出json或者xml等。

这种方法原理就是将wordpress的模板重新定义到api文件下寻找同名模板文件。如果你愿意做更多的探寻,还可以实现更加智能的接口模板匹配功能出来。我这里就展示了最简单的方法。

这种方法完全不影响网站原有的模板文件,不需要改动任何原有模板,接口的实现在api文件夹下的同名文件里实现。

使用示例
要将你的主题下的page.php模板进行json化输出,只需要在api文件下新建一个叫page.php的模板(或者复制page.php过来),里面写入:

  1. <?php //这里偷懒了,直接将wordpress的$wp_query对象json化输出,实际中最好提取自己需要的内容输出,以减少http传输量
  2.     header("Content-type:application/json");
  3.     if(isset($_GET['debug'])){
  4.         print_r($wp_query);
  5.      }else echo json_encode($wp_query);

比如网站有个页面,地址是http://yoursite.com/pagename,其对应的接口地址就是http://yoursite.com/pagename?json。如果要调试,查看json接口,可以加上debug参数,如http://yoursite.com/pagename?json&debug。
是不是很简单呢?如果你的网站不需要这个接口了,只需要直接删除api文件夹就行了。

当然你也可以使用插件来完成接口的配置。

原文 百度知道By du若冰


发布日期:

所属分类: Wordpress, Wordpress 综合 标签: