WordPress 常用接口
像素鱼丸
2024-05-04
553
0

简介

WordPress v4.4以后,已经内置了WP REST API。

接口文档:https://developer.wordpress.org/rest-api/

The WordPress REST API provides an interface for applications to interact with your WordPress site by sending and receiving data as JSON (JavaScript Object Notation) objects. It is the foundation of the WordPress Block Editor, and can likewise enable your theme, plugin or custom application to present new, powerful interfaces for managing and publishing your site content.

RESTful API 路由地址

所有接口地址都以 /wp-json/ 开始,比如获取文章列表的地址是 http://oursite.com/wp-json/wp/v2/posts

Posts	                /wp/v2/posts
Post Revisions	        /wp/v2/posts//revisions
Categories	            /wp/v2/categories
Tags	                /wp/v2/tags
Pages	                /wp/v2/pages
Page Revisions	        /wp/v2/pages//revisions
Comments	            /wp/v2/comments
Taxonomies	            /wp/v2/taxonomies
Media	                /wp/v2/media
Users	                /wp/v2/users
Post Types	            /wp/v2/types
Post Statuses	        /wp/v2/statuses
Settings	            /wp/v2/settings
Themes	                /wp/v2/themes
Search	                /wp/v2/search
Block Types	            /wp/v2/block-types
Blocks	                /wp/v2/blocks
Block Revisions	        /wp/v2/blocks//autosaves/
Block Renderer	        /wp/v2/block-renderer
Block Directory Items	/wp/v2/block-directory/search
Plugins	                /wp/v2/plugins

输出友好数据

在 /wp-inclue/functions.php 中找到该函数,添加 JSON_UNESCAPED_UNICODE。

function wp_json_encode( $data, $options = 0, $depth = 512 ) {
	// $json = json_encode( $data, $options, $depth );
	$json = json_encode( $data, JSON_UNESCAPED_UNICODE, $depth );

	.....

	// return json_encode( $data, $options, $depth );
	return json_encode( $data, JSON_UNESCAPED_UNICODE, $depth );
}

常用接口

1、文章

1) 获取最新文章默认获取到最新的10篇文章

http://test.com/wp-json/wp/v2/posts

http://test.com/wp-json/wp/v2/posts?page=1&per_page=5

效果相同,page用于指定页数,WP REST API 默认返回10条数据,用page指定数据获取的游标。如

http://test.com/wp-json/wp/v2/posts?page=2

可取回最新的第11条数据到第20条数据,以此类推。

2) 设置获取的每页文章数量及分页

http://test.com/wp-json/wp/v2/posts?filter[posts_per_page]=5

filter[posts_per_page]=5 用于指定返回文章每页的数量,这里指定每页数量为5篇。

filter[posts_per_page]与page联合使用:

http://test.com/wp-json/wp/v2/posts?filter[posts_per_page]=5&page=2

3) 获取指定分类的文章

http://test.com/wp-json/wp/v2/posts?filter[cat]=2

filter[cat]=2 指定分类ID为2 ,返回分类ID为2的文章。

分类ID是每个分类目录在创建时自动生成的ID,在wordpress后台“文章”==》“分类目录”中,把鼠标放在分类名称上面,页面下方会出现一个网址,网址中的参数tag_ID=2就是这个分类名称的分类ID。如果没有出现网址,可以点击分类名称下的“编辑”,然后查看网页地址栏,同样可以得到tag_ID=2。下面的标签ID的获得方法也一样。

4) 获取指定标签的文章

http://test.com/wp-json/wp/v2/posts?filter[tag]=library

filter[tag]=library 指定标签名为“library”的文章

5) 获取指定分类和有指定标签的文章

http://test.com/wp-json/wp/v2/posts?filter[cat]=2&filter[tag]=library

上面两个结合一起,可以得到更具体精确的文章。

6) 获取指定日期的文章

http://test.com/wp-json/wp/v2/posts?filter[year]=2016&filter[monthnum]=03

filter[year]=2016&filter[monthnum]=03 设置指定的日期

7) 获取指定作者的文章

http://test.com/wp-json/wp/v2/posts?filter[author_name]=jinyun

filter[author_name]=jinyun设置指定作者名字

8) 按关键词搜索文章

http://test.com/wp-json/wp/v2/posts?filter[s]=金云

filter[s]=金云 :按给定的关键词搜索文章,返回包含“金云”关键词的文章。

9) 获取随机文章

http://test.com/wp-json/wp/v2/posts?filter[orderby]=rand

其中orderby还可以为指定的字段排序

10) 获取相关文章

在网站中,在做SEO优化和页面内容布局时,获取相关文章是比较常见的,可以通过以上几个条件组合来达到获取相关文章的效果。

按标签获取相关文章:

http://test.com/wp-json/wp/v2/posts?filter[orderby]=rand&filter[tag]=library&filter[posts_per_page]=6

按分类获取相关文章:

http://test.com/wp-json/wp/v2/posts?filter[orderby]=rand&filter[cat]=2&filter[posts_per_page]=6

11) 获取指定文章的数据

http://test.com/wp-json/wp/v2/posts/189

得到ID为189的文章数据

2、分类和标签

1) 获取所有的分类

http://test.com/wp-json/wp/v2/categories

2) 获取指定分类ID的分类信息

http://test.com/wp-json/wp/v2/categories/2

3) 获取所有的标签

http://test.com/wp-json/wp/v2/tags

4) 获取指定标签ID的标签信息

http://test.com/wp-json/wp/v2/tags/3

3、媒体文件

1) 获取所有的媒体信息

http://test.com/wp-json/wp/v2/media

2) 获取指定媒体ID的媒体信息

http://test.com/wp-json/wp/v2/media/17

4、页面

1) 获取所有的页面信息

http://test.com/wp-json/wp/v2/pages

2) 获取指定页面ID的页面信息

http://test.com/wp-json/wp/v2/pages/289

5、类型

1) 获取当前wordpress所有的内容类型

http://test.com/wp-json/wp/v2/types

一般情况下会返回post,page和attachment三种类型

2) 获取指定类型

http://test.com/wp-json/wp/v2/types/post

6、评论

1) 获取所有评论信息

http://test.com/wp-json/wp/v2/comments

2) 获取指定评论ID的单条评论信息

http://test.com/wp-json/wp/v2/comments/2

7、用户

1) 获取所有的用户信息

http://test.com/wp-json/wp/v2/users

2) 获取指定用户ID的用户信息

http://test.com/wp-json/wp/v2/users/1

备注:

WordPress 默认的接口汉字默认是转换为 中文不转为unicode,把 WP_REST_Server -> serve_request json_encode() 的函数,添加一下,JSON_UNESCAPED_UNICODE 中文不转为unicode ,对应的数字 256。

参考:

http://developer.wordpress.org/rest-api/

收藏
打赏
WordPress 添加文章浏览次数
上一篇
PHP 语法
下一篇

发表评论

注册不是必须的

像素鱼丸
150 文章
0 评论
4 喜欢
最新文章

宝塔 Nginx 拦截了 WordPress 返回 404 的状态

REST api 接口中,有段代码返回404,但是没有正常返回错误json: $wp_response = new \WP_REST_Response(array('error'=>'没有找到数据')); $wp_response->set_status(404); return $wp_response; 返回内容是: <html> <head><tit […]

Mirage 主题 v2.93.0 发布

更新内容: refactor 移除图片高宽比开关 refactor 移除全局的TOC生成开关 refactor 优化 header.php 中的seo模块和样式覆盖 feat 主题启用的时候,移除非当前主题注册的小工具 fix 修复分类小工具的bug feat 管理员打开后台,检查最当前设置首页布局的模块,如果缺少最新模块,就添加到隐藏模块列表中 fix 优化链接卡片样式 fix 优化热门文章样式 […]

如何使用 WordPress Setting API

使用 WordPress 的 Setting API 是在插件或主题中创建和管理设置页面的标准方式。它提供了一种结构化、安全的方式来保存和获取用户配置的选项。 ✅ 一、Setting API 简介 WordPress 的 Setting API 允许你: 创建设置页面(Settings Page) 注册设置字段(Settings Field) 验证和保存设置数据 使用表单提交来更新设置 ✅ 二、基 […]

详解 WordPress 的评论设置

好的,我们来详细梳理并总结 WordPress 中关于文章评论的两个核心控制层级:全局设置和单篇设置。理解这两者的关系(优先级)是管理网站评论的关键。 1. 全局设置 (Global Settings) —— 网站的“默认规则” 这是整个网站评论系统的总开关和默认行为准则。它决定了新发布的文章默认是什么样子的。 位置:WordPress 后台仪表盘 -> 设置 (Settings) -> […]
生成中...
扫描二维码
扫描二维码
用户登录