全球使用量最大的网站系统wordpress
大概是从4.5内置了wordpress rest api
的功能,使wordpress
与其他系统进行集成变得非常方便,这套接口几乎涵盖了日常用到的所有功能。
需求
说回正题,最近上公众号后台发现经常有人直接输入电影名称,大概是想直接查这个电影相关的东西,但是目前公众号只会憨憨的回复用户:“您的消息已经收到,管理员会第一时间联系您。”,然后我并没有时间去查看,当然也没有去联系您。
既然wordpress
提供了这样一套rest api
接口可用,而公众号上又有相关的需要,那就集成一下就好了。需求就是根据用户在公众号里的留言,去搜索电影站上的文字title
,然后返回链接给客户就好了。
实现
首先读一下wordpress rest api文档,找到我们需要的主接口:
curl https://example.com/wp-json/wp/v2/posts
带上一个search
参数就可以进行关键词检索了:
curl https://example.com/wp-json/wp/v2/posts?search=赎罪
但是这个返回的结果是这样的:
与我们需求不太一致,有两个问题:
- 关键词匹配了文章的很多属性,包括标题,内容等,所以会匹配出很多我们不需要的文章来,而我们只想搜索标题。
- 返回了一篇文章全量的数据,而我们只需要链接,标题即可。
优化检索
解决问题1
我们需要定制一种检索形式,只检索文章的title
。具体实现步骤:
这样,我们使用自定义的过滤条件queryByTitle
再发送一个请求试试:
curl https://www.m1910.com/wp-json/wp/v2/posts?filter[queryByTitle]=赎罪
这样的返回才是我们需要的:
解决问题2
对于返回字段进行过滤,只需要加入一个_fields
参数就可以了,这里我们只需要title
和link
就行了,这样发请求:
curl https://www.m1910.com/wp-json/wp/v2/posts?filter[queryByTitle]=赎罪&_fields=link,title
可以看到,返回变成了我们想要的样子:
[
{
link: "https://www.m1910.com/atonement-2007.html",
title: {
rendered: "赎罪 Atonement(2007)_结局应该是死亡还是永恒"
}
}
]
如果返回多个结果,循环输出就好了。然后把这个优化后的接口集成到公众号的关键词回复中即可。