也许有同学会说,wordpress具有强大的主题切换能力,通过一个简单的主题预览插件就可以实现不同主题显示不同的内容,接口就在另一个主题下实现!
没错,这种方式确实可以,但是由于wordpress目前cms功能越来越强大,很多网站都使用了自定义模板、register_post_type、register_nav_menus等功能,wordpress的主题切换不能很好的兼容这些地方(即使register_post_type代码照搬)。即使克服了以上的困难,如果以后网站增加版块或者新功能,要维护就得同时改动网站主题和api主题模板,工作量巨大。
那么有没有什么简单的方法呢?
以下这个方法可以在原有的主题基础上进行方便的接口开发。
如何做呢?
首先在网站所用主题的functions.php文件中增加以下代码:
if(isset($_GET['json'])){ add_filter('template_include','wp_my_api'); } function wp_my_api($template){ return preg_replace('#([^/]+\.php)#','api/$1',$template); }
然后在网站当前所用主题目录下新建一个文件夹,名字为“api”。然后把主题下的模板文件复制进api文件夹里,就可以对这些模板进行接口数据转化了。比如输出json或者xml等。
这种方法原理就是将wordpress的模板重新定义到api文件下寻找同名模板文件。如果你愿意做更多的探寻,还可以实现更加智能的接口模板匹配功能出来。我这里就展示了最简单的方法。
这种方法完全不影响网站原有的模板文件,不需要改动任何原有模板,接口的实现在api文件夹下的同名文件里实现。使用示例
要将你的主题下的page.php模板进行json化输出,只需要在api文件下新建一个叫page.php的模板(或者复制page.php过来),里面写入:
<?php //这里偷懒了,直接将wordpress的$wp_query对象json化输出,实际中最好提取自己需要的内容输出,以减少http传输量 header("Content-type:application/json"); if(isset($_GET['debug'])){ print_r($wp_query); }else echo json_encode($wp_query);
比如网站有个页面,地址是http://yoursite.com/pagename,其对应的接口地址就是http://yoursite.com/pagename?json。如果要调试,查看json接口,可以加上debug参数,如http://yoursite.com/pagename?json&debug。
是不是很简单呢?如果你的网站不需要这个接口了,只需要直接删除api文件夹就行了。
当然你也可以使用插件来完成接口的配置。