古诗词 API 是一个可以返回一句古诗词名句的接口。它可以通过图片和 JSON 格式调用。古诗词 API 根据不同地点、时间、节日、季节、天气、景观、城市进行智能推荐。 如果您不以我们的接口及其提供的内容盈利,您可以免费的使用我们的 API。使用我们的 API 代表您同意了我们的 使用协议。 |
1. 我应该选择哪个调用方式?
-
普通网站、博客
调用,使用 网站快速安装 -
小程序
调用,使用 小程序 SDK -
Vue
、React
等框架,使用 NPM 快速安装 -
安卓 APP
调用,使用 安卓 SDK -
IOS、桌面端等非浏览器环境,使用 高级 JSON 接口
-
在
论坛
、文章等不支持 HTML 的地方调用,使用 图片形式调用 -
后端调用、服务器调用、微信公众号调用,本接口不支持,可使用 旧API接口
-
浏览器插件、IOS 捷径调用,使用 捷径/浏览器插件接口
为了提高推荐的效果,请您正确选择调用方式。 |
原则上,为了获取到正确的 IP 定位信息,我们的接口都不应在服务端调用。
|
2. 网站快速安装
为了方便您的调用,我们特意开发了一款 JS-SDK 供您快速部署。这款SDK帮您完成了 高级 JSON 接口 的所有步骤。
浏览器能直接打开的网站才能使用本方法部署 |
2.1. 通用简单安装代码
在 HTML 中需要加载诗词的地方放置以下加载代码即可,和 网站统计 的安装方法一致。
<span id="jinrishici-sentence">正在加载今日诗词....</span>
<script src="https://sdk.jinrishici.com/v2/browser/jinrishici.js" charset="utf-8"></script>
SDK 会自动寻找 id 或者 class 为 jinrishici-sentence 的标签,将里面的内容替换为诗词
|
如果需要在多个地方显示诗词,添加多个 class=" jinrishici-sentence " 的 span 即可
|
2.2. 通用高级安装代码
如果你有其他需求(如获取作者、朝代等),可以调用我们提供的加载函数 jinrishici.load
并传入回调函数,每调用一次,会传入一个新的诗词
<script src="https://sdk.jinrishici.com/v2/browser/jinrishici.js" charset="utf-8"></script>
<script type="text/javascript">
jinrishici.load(function(result) {
// 自己的处理逻辑
console.log(result)
});
</script>
result 的 格式见 接口返回结果格式 |
出错我们会帮你打在控制台上,您无需再次处理。 |
使用定制加载时,不要将标签的 id 或者 class 设置为 jinrishici-sentence ,否则SDK会自动加载一次
|
使用 load 之前,请确保 SDK JS 文件已经引入
|
一个高级版的使用例子,可以复制到一个 HTML 文件用浏览器打开查看效果:
<script src="https://sdk.jinrishici.com/v2/browser/jinrishici.js" charset="utf-8"></script>
<div id="poem_sentence"></div>
<div id="poem_info"></div>
<script type="text/javascript">
jinrishici.load(function(result) {
var sentence = document.querySelector("#poem_sentence")
var info = document.querySelector("#poem_info")
sentence.innerHTML = result.data.content
info.innerHTML = '【' + result.data.origin.dynasty + '】' + result.data.origin.author + '《' + result.data.origin.title + '》'
});
</script>
2.3. 博客/论坛简单安装示例
本示例适用于 Wordpress / Typecho / Emlog / Hexo / Hugo 等博客和 Discuz / PHPwind / Xiuno 等论坛。
您想添加一句诗词到您的网站,您需要找到您选择使用的模板的相应位置。加入快速安装代码即可。
如果您找不到,可以使用文本搜索附近的 HTML 代码关键字。
比如,您想添加到页脚,一般您需要修改 footer.php
,加入安装代码即可。
需要注意的是,不要把安装代码粘贴到 <?php 和 ?> 中间。
<footer id="footer" role="contentinfo">
<span id="jinrishici-sentence">正在加载今日诗词....</span>
<script src="https://sdk.jinrishici.com/v2/browser/jinrishici.js" charset="utf-8"></script>
<br>
© <?php echo date('Y'); ?> <a href="<?php $this->options->siteUrl(); ?>"><?php $this->options->title(); ?></a>.
<?php _e('由 <a href="http://www.typecho.org">Typecho</a> 强力驱动'); ?>.
</footer><!-- end #footer -->
可能有一些同学受其他 hitokoto 一言 API 的影响,认为可以直接在服务器用 PHP 的 curl 等方法直接请求接口,这在本接口是 完全错误 的。 |
3. 小程序 SDK
如果您使用微信小程序调用我们的接口,我们也为您准备了SDK。这款SDK帮您实现了 [token] 的所有步骤
第一步
,
点击下载小程序SDK文件
第二步
,放置在您的小程序目录,一般是 /utils 下
第三步
,在微信后台添加我们的API地址到白名单:
https://v2.jinrishici.com
第四步
,在您需要调用的 Page 的 JS 文件最上面,引用我们的SDK
const jinrishici = require('../js/jinrishici.js')
请注意文件夹深度,确保文件地址正确。 |
第五步
,在 JS 文件的 onLoad 处 或者其他地方,调用我们的加载函数,您需要传一个回调函数。
jinrishici.load(result => {
// 下面是处理逻辑示例
console.log(result)
this.setData({"jinrishici": result.data.content})
})
result
的格式见 接口返回结果格式
4. NPM 快速安装
如果你使用 Vue 、 React 等框架,或使用 Webpack 工作流,可以通过 npm 快速安装我们的 SDK
npm -i jinrishici --save
该 NPM 包仅支持浏览器环境,不支持 Node 环境,不支持服务器渲染,本接口需要获取客户端数据,所以也不能服务端渲染。 |
安装好后,可以在页面的启动函数中引入 SDK ,并调用 load
函数,传入一个处理结果的函数。
const jinrishici = require('jinrishici');
jinrishici.load(result => {
console.log(result);
});
返回结果 result
的格式见 接口返回结果格式
你也可以再传一个错误处理函数处理加载错误时的情况
const jinrishici = require('jinrishici');
jinrishici.load(result => {
console.log(result);
}, errData => {
console.log(err);
});
通常,你应该在页面加载完之后调用 load
方法,比如 Vue 的 mounted 钩子
methods: {
loadSentence: function() {
jinrishici.load(result => {
this.msg = result.data.content
}, err => {
console.log("test");
})
}
},
mounted: function(){this.loadSentence()}
5. 安卓 SDK
通过安装安卓 SDK 您可以快速集成今日诗词 API 到您的安卓 APP 上。
Maven 安装
<dependency>
<groupId>com.jinrishici</groupId>
<artifactId>android-sdk</artifactId>
<version>1.5</version>
<type>pom</type>
</dependency>
Gradle 安装
implementation 'com.jinrishici:android-sdk:1.5'
在调用获取今日诗词的接口之前任何地方调用初始化方法(控件形式调用可跳过):
//以下两种初始化方式任选一种即可
JinrishiciFactory.init(getContext());
JinrishiciClient.getInstance().init(getContext());
这一步是为了初始化 SharedPreference 的存储,让今日诗词的 token 能够存储到客户端设备上,从而避免推荐重复
调用时,您有三种方法调用:
第一种
:异步方法:
JinrishiciClient client = JinrishiciClient.getInstance();
client.getOneSentenceBackground(new JinrishiciCallback() {
@Override
public void done(PoetySentence poetySentence) {
//TODO do something
//在这里进行你的逻辑处理
}
@Override
public void error(JinrishiciRuntimeException e) {
Log.w(TAG, "error: code = " + e.getCode() + " message = " + e.getMessage());
//TODO do something else
}
});
第二种
:同步方法,当请求出现错误时会抛出 JinrishiciRuntimeException ,请自行捕获进行处理。同步异步方法二选一即可。
PoetySentence poetySentence = JinrishiciClient.getInstance().getOneSentence();
第三种
:自定义控件。
同样,sdk也提供自定义控件,你只需要将控件添加进布局中,无需处理相关逻辑,控件会自动请求数据并展示到控件上 如果使用自定义控件的方式,那么不用手动调用初始化的方法,控件会自动调用
<com.jinrishici.sdk.android.view.JinrishiciTextView
android:id="@+id/jinrisiciTextView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:textColor="@color/colorAccent"
android:textSize="18sp" />
<!--你可以像使用TextView那样对JinrishiciTextView进行设置-->
<!--如示例代码中的textColor和textSize属性-->
属性名 | 支持数据类型 | 备注 |
jrsc_refresh_on_click | boolean | 点击TextView时是否刷新 |
jrsc_show_error | boolean | 当请求出现错误时,是否直接将错误信息显示到TextView上 |
jrsc_show_loading_text | boolean | 是否在加载数据时显示加载文本 |
jrsc_text_loading | string | 加载数据时显示的文本 |
jrsc_text_error | string | 加载失败时显示的文本 |
DEMO APP,SDK 源代码,SDK 最新文档,见: Github
安卓 SDK 作者为 mystery0 ,特此感谢
6. 高级 JSON 接口
本接口是 今日诗词 API 的核心接口。返回格式为 JSON 。
今日诗词接口免费版 不支持服务端调用 ,不支持浏览器调用(浏览器只能使用 SDK),仅支持客户端调用,详见 服务器端可以调用吗?
如果您是 IOS、桌面端的开发者,您需要通过手动调用本接口来获取诗词推荐。
如果您确实需要在浏览器中手动调用本接口,请直接查看 [browser]
基本原理是,对于每一个客户端,都先获取一个新的 Token,Token和该客户绑定,类似“登录”,然后储存在硬盘上,之后该客户端的每次请求都附带这个 Token,这样,我们就可以知道这个客户端的调用历史。 Token 是永久有效的,只要用户不手动清除,则可以一直保留。
调用本接口,您需要:
-
对于每一个用户第一次访问,先使用 获取 Token ,然后存到
Storage
里面。(Storage
表示一些长效的储存机制,如 localStorage ,您 不应该存储到运行内存 中) -
之后每一次接口调用,把
Token
从Storage
里面拿出来。 -
使用 附带 Token 的接口 , 发送附带
Token
的请求。
调用接口写好后,请使用 接口测试
虽然您不附带 Token 也可以正常访问我们的接口,但是对于不带 Token 的访问,我们每次都会自动创建一个新 Token。单个 IP 签发多个 Token 会导致诗词推荐质量下降。 但要注意,不同用户之间请不要使用同一个 Token |
6.1. 获取 Token
Token
用于鉴别和区分每个用户,获取后 永久有效
获取 Token 的地址为,GET 方法
https://v2.jinrishici.com/token
返回的 Token 在 data
中:
{
"status": "success",
"data": "RgU1rBKtLym/MhhYIXs42WNoqLyZeXY3EkAcDNrcfKkzj8ILIsAP1Hx0NGhdOO1I"
}
6.2. 附带 Token 的接口
GET 方法,地址为:
https://v2.jinrishici.com/sentence
您需要在 HTTP 的 Headers
头中指定 Token
。
X-User-Token:RgU1rBKtLym/MhhYIXs42WNoqLyZeXY3EkAcDNrcfKkzj8ILIsAP1Hx0NGhdOO1I
返回结果在此查看 接口返回结果格式
6.3. 接口测试
为了保证接口的成功安装,您需要进行接口测试。
您可以直接用 附带 Token 的接口 做简单的测试,重点是,对于同一个用户, token
字段每次调用应该保持一致 ,如果不一致则 安装错误 。请重新阅读文档或 联系我们 , QQ群
另外,您也可以调用我们的高级测试接口:
GET方法,接口地址为:
https://v2.jinrishici.com/info
额外的 Headers
(可选)
X-User-Token:5894fcba-0f9b-435e-b460-bb02d19b8974
正常返回:
{
"status": "success",
"data": {
"token": "5894fcba-0f9b-435e-b460-bb02d19b8974",
"ip": "215.17.40.175",
"region": "广东|深圳",
"weatherData": {
"temperature": 26,
"windDirection": "东风",
"windPower": 1,
"humidity": 91,
"updateTime": "23:10",
"weather": "雨",
"visibility": "33.43km",
"rainfall": 0,
"pm25": 23
},
"tags": [
"桂花",
"华南",
"雨",
"秋",
"晚上"
],
"beijingTime": "2018-09-17T23:47:48.194228"
}
}
如果满足以下条件,则说明您的调用是正确的
-
对于同一用户,多次调用的 Token 是同一个
-
IP 是用户的 IP,region 识别正常
7. 捷径/浏览器插件接口
如果您用浏览器直接打开我们的接口地址,则自动使用我们的浏览器直接访问接口(原标准 JSON 接口),我们会自动向您发送一个 Cookies,作用和 Token 等效。
此接口 仅适用于浏览器直接访问 ,不适用于网站调用,应用场景包括:浏览器插件、IOS 捷径访问。如果您贪方便在其他地方直接调用本接口,可能会触发我们的系统判断,导致诗词推荐质量下降。
实际调用本接口时,请务必进行 接口测试 确保 Token 每次一致。
8. 接口返回结果格式
NPM 快速安装 , 小程序 SDK, 网站快速安装 高级版,高级 JSON 接口 接口返回的正常的数据格式为:
正确返回:
{
"status": "success",
"data": {
"id": "5b8b9572e116fb3714e6faba",
"content": "君问归期未有期,巴山夜雨涨秋池。",
"popularity": 1170000,
"origin": {
"title": "夜雨寄北",
"dynasty": "唐代",
"author": "李商隐",
"content": [
"君问归期未有期,巴山夜雨涨秋池。",
"何当共剪西窗烛,却话巴山夜雨时。"
],
"translate": [
"您问归期,归期实难说准,巴山连夜暴雨,涨满秋池。",
"何时归去,共剪西窗烛花,当面诉说,巴山夜雨况味。"
]
},
"matchTags": [
"秋",
"晚上"
],
"recommendedReason": "",
"cacheAt": "2018-09-17T21:18:44.693645"
},
"token": "6453911a-9ad7-457e-9b9d-c21011b85a0c",
"ipAddress": "162.248.93.154"
}
其中
data.content
是核心,即推荐的诗句
data.matchTags
是与你相关的标签,也是推荐给你的部分理由。
data.recommendedReason
是推荐原因,暂未支持。
data.cacheAt
是指我们会对每个 Token
进行预生成推荐数据并缓存。正常情况下我们会10分钟更新一次缓存数据。
data.popularity
是我们对这句诗的流行度评价
data.origin
源诗信息
data.origin.translate
是整诗翻译,部分诗词有,部分没有
token
是当前用户的 token
,原则上,同一个用户,一段时间内 Token 应该不变。
ipAddress
是当前用户的 ip
,如果 IP 有异常,您需要查明您是否在服务端调用
错误返回:
{
"status": "error",
"errCode": 2001,
"errMessage": "No matching handler"
}
errcode
是错误码,目前只有以下几种错误码,您也简单判断 HTTP 头中的状态码,对于错误返回,我们总不会返回 200
1001
:内部服务器错误,HTTP状态码 500
1002
:API路径不对,HTTP状态码 404
2002
:Token不是服务器签发,HTTP状态码 400
2003
:IP超过每日新用户限制,HTTP状态码 400,这很有可能是您没有正确保存 Cookies 或者 Token
9. 图片形式调用
本接口不推荐在自己的网站或 APP 中调用,只有您确实无法添加 JS 或 SDK 时才应该考虑调用。图片调用形式仅限在网站中调用。禁止在其他地方调用。
对于禁用了第三方 Cookies的浏览器(Chrome默认不禁用),本接口可能无法正常跟踪用户导致触发保护机制,降低推荐的效果。请悉知。
图片调用地址为:
https://v2.jinrishici.com/one.svg
Markdown 格式
![今日诗词](https://v2.jinrishici.com/one.svg)
HTML 格式
<img alt="今日诗词" src="https://v2.jinrishici.com/one.svg">
HTML 调用时在所在 DIV 居中并且不会 overflow :
<img alt="今日诗词" src="https://v2.jinrishici.com/one.svg" style="max-width:100%; display: block; margin: 0 auto;">
如果您需要自定义图片的文字的大小、间距、颜色,可以在图片地址后面加参数:
参数名
|
说明
|
默认值
|
合法范围
|
font-size
|
字体大小(px)
|
20
|
[8,50]
|
spacing
|
间距(px)
|
1.5
|
[0,30]
|
color
|
颜色
|
black
|
颜色英文单词
|
例如:
https://v2.jinrishici.com/one.svg?font-size=20&spacing=2&color=blue
需要注意的是,颜色目前只接收英文单词, 查看所有颜色英文单词
掘金等一些网站或论坛,会在后端保存图片并替换地址,请注意识别。 |
10. 使用协议
使用本API接口代表您 已经同意
以下的使用协议:
一、 使用本接口,您的网站、小程序、客户端、桌面端等终端(下简称终端)和您的行为必须满足以下条件:
-
终端内容和您的行为符合中国大陆法律
-
不恶意访问、攻击本接口
-
不使用自动化工具有目的地抓取保存本接口的数据
-
不伪造、仿冒、反向代理本接口
本网站已经在工信部备案,不想被查水表,请各位看官手下留情。 不要在违法网站上面调用本站接口啦。 |
二、 满足以下条件,您可以 免费使用
本接口
-
不以本接口及其提供的内容盈利
,盈利行为包括但不仅限于:出售本接口信息、在以本接口为主体内容的页面中放置广告 等。但如果在有自己内容的页面调用本接口不受该限制。
本接口不开放商用 |
三、 本接口保留以下权利
-
对于异常访问的用户,接口在一定时间内 降低推荐质量 的权利,异常行为包括:
-
使用 高级 JSON 接口 不按规定发 Token
-
短时间内大量访问
-
-
对于以下行为,接口 拒绝服务 的权利:
-
违法网站调用
-
短时间内巨量访问,目前规则为: 5秒内单IP只能访问25次,超过的部分返回 403
-
-
自行更改协议的权利。
四、免责声明
-
本接口提供的诗词数据来源于网络,如有侵权或错漏,请 联系我们
-
本接口推荐结果是根据时间、地点、天气等数据使用机器自动推荐,不代表本接口及其所有者赞成键入内容及推荐结果的内容或立场。
-
本接口为开放调用,不代表本接口及其所有者赞成调用本接口的终端上的内容或立场。
-
我们尽最大可能保证接口的稳定性,但对于本接口,特别是免费版本,我们不做任何稳定性、可靠性保证,由于本接口无法访问而带来的损失,本接口以及所有者不对此负责。
五、隐私权声明
-
本接口会临时获取用户公开的
IP
数据用以推荐,会向用户电脑置入Cookies
或Token
信息记录历史推荐数据,如果您的终端用户认为此行为侵犯了他们的隐私,您应对此负责。
11. 常见问题
11.2. 服务器端可以调用吗?
原则上,为了获取到正确的 IP
定位信息,我们的接口都应该在终端(客户端)直接调用,在实际用户处向我们发送请求。
如果您确实需要服务端调用,可以选择我们的旧版接口 旧API接口 。
11.3. 微信公众号用哪个接口?
只能使用旧版接口 旧API接口
11.5. 接口稳定吗?
我们尽最大可能维持接口的稳定性,长效性。
技术上,我们使用 Spring-Boot, Spring-WebFlux 开发,运行在 Netty 上,使用了 Mongo 数据库和 Redis 缓存,具有一定健壮性。
运维上,接口目前部署在腾讯云广州机房,具有一定的可靠性。
但对于恶意攻击和不可抗力因素导致的接口访问异常,我们只能尽快修复。
对于 高级 JSON 接口 调用的用户,您可以在接口失效的时候放置默认数据。对于 图片形式调用 调用的用户,您可以加置 alt
标签或者图片的描述性标签,用于无法访问时的备用显示。
使用后请尽量加 QQ群,方便我们向您通知一些情况。
11.6. 我们是如何推荐的?
-
根据调用的用户所在地,收集真实世界的信息,包括天气、时间、日期、事件等等
-
把真实世界信息转化为标签和其他特征,按特征拉取初步推荐池 推荐关联的标签有哪些?
-
去掉已经推荐过给该用户的诗词
-
判断诗词的好坏,并且根据一列算法对推荐池的诗词进行打分排序
-
根据真实世界的不同情况,选择不同的策略进行分段抽取,并缓存
-
从缓存池逐条返回
11.7. 推荐关联的标签有哪些?
注:该表仅供参考,和实际接口有出入。
标签
|
触发条件
|
气象触发标签
|
|
晴
|
天气晴
|
雨
|
天气雨
|
小雨
|
天气小雨/ 降水量
|
大雨
|
天气大雨/ 降水量
|
阴
|
天气阴
|
云
|
天气多云
|
风
|
风力 >=2级
|
无风
|
风力 <= 1级
|
东风
|
东风,风力 >=2级
|
南风
|
南风,风力 >=2级
|
西风
|
西风,风力 >=2级
|
北风
|
北风,风力 >=2级
|
微风
|
风力 [2,3] 级
|
大风
|
风力 >= 4级
|
雪
|
天气雪
|
雷电
|
雷电天气
|
干旱
|
|
沙尘
|
|
雾
|
能见度
|
寒冷
|
气温 <= 10 度
|
炎热
|
气温 >= 30 度
|
时间触发标签
|
|
日出
|
当地日出时间后1小时
|
日落
|
当地日落前后1小时
|
正午
|
北京时间11-13点(人们通常认为12点为正午)
|
上午
|
[8-11]点
|
下午
|
[13-17]点
|
晚上
|
日落后1小时 - 晚上12点
|
凌晨
|
[0-5]点
|
日期触发标签
|
|
春
|
农历2-4月
|
夏
|
农历5-7月
|
秋
|
农历8-10月
|
冬
|
农历10-1月
|
除夕
|
除夕
|
春节
|
春节
|
新年
|
元旦,春节
|
元宵
|
元宵
|
寒食
|
寒食
|
清明
|
清明
|
端午
|
端午
|
七夕
|
七夕
|
爱情
|
七夕, 元宵, 情人节,白色情人节
|
中秋
|
中秋
|
重阳
|
重阳
|
劳动
|
劳动节
|
爱国
|
国庆节,七七,九一八
|
妇女
|
妇女节
|
母亲
|
母亲节
|
父亲
|
父亲节
|
儿童
|
儿童节
|
老师
|
教师节
|
地理标签
|
|
华东
|
山东、江苏、安徽、浙江、福建、上海
|
华南
|
广东、广西、海南
|
华中
|
湖北、湖南、河南、江西
|
华北
|
北京、天津、河北、山西、内蒙古
|
西北
|
宁夏、新疆、青海、陕西、甘肃
|
西南
|
四川、云南、贵州、西藏、重庆
|
东北
|
辽宁、吉林、黑龙江
|
江南
|
上海、浙江、江苏
|
边塞
|
内蒙古,甘肃,宁夏,青海,青海
|
西域
|
新疆
|
徽州
|
安徽黄山
|
长安
|
陕西西安
|
武陵
|
湖南常德
|
浔阳
|
江西九江
|
姑苏
|
江苏苏州
|
苏州
|
江苏苏州
|
扬州
|
江苏扬州,江苏泰州,江苏南通,江苏盐城,江苏镇江,江苏南京,安徽天长,江苏淮安
|
燕京
|
北京
|
庐州
|
安徽合肥
|
琅琊
|
山东临沂
|
石头城
|
江苏南京
|
景德镇
|
江西景德镇
|
京口
|
江苏镇江
|
临安
|
浙江杭州
|
广陵
|
江苏扬州
|
武陵
|
湖南常德
|
钱塘
|
浙江杭州
|
金陵
|
江苏南京
|
幽州
|
北京
|
洛阳
|
洛阳
|
凉州
|
甘肃武威
|
齐州
|
山东济南
|
蜀地
|
四川
|
汝南
|
河南驻马店
|
大梁
|
河南开封
|
泰山
|
山东泰安
|
华山
|
陕西渭南
|
衡山
|
湖南衡阳
|
恒山
|
山西大同
|
嵩山
|
河南登封
|
黄山
|
安徽黄山
|
庐山
|
江西九江
|
雁荡山
|
浙江温州
|
河流
|
|
长江
|
四川攀枝花,四川宜宾,四川泸州,重庆,湖北宜昌,湖北荆州,湖北岳阳,湖北武汉,湖北鄂州,湖北黄石,江西九江,安徽安庆,安徽铜陵,安徽芜湖,安徽马鞍山,江苏南京,江苏镇江,江苏南通,上海
|
黄河
|
甘肃兰州,甘肃白银、宁夏石嘴山,内蒙古乌海,内蒙古巴彦淖尔, 内蒙古包头,陕西韩城,山西河津,山西永济、河南开封,河南三门峡,河南洛阳、山东滨州,山东济南
|
黄鹤楼
|
湖北武昌
|
滕王阁
|
江西南昌
|
岳阳楼
|
湖南岳阳
|
玉门
|
甘肃敦煌
|
阳关
|
甘肃敦煌
|
瓜州
|
江苏扬州
|
锦城
|
四川成都
|
成都
|
四川成都
|
洞庭
|
湖南岳阳
|
西湖
|
浙江杭州
|
赤壁
|
湖北咸宁
|
荒漠
|
荒漠地貌
|
草原
|
草原地貌
|
雪山
|
雪山地形
|
地震
|
|
混合标签
|
|
梅雨
|
华东地区,6月中-7月中,下雨
|
海棠
|
山东,陕西,湖北,江西,安徽,江苏,浙江,广东,广西;4-5月
|
桃花
|
华南、西南:2-4月
华中华东:3-4月
华北:4-5月
|
牡丹
|
全国;5月
|
丁香
|
西南,西北,华北,东北;4-5月
|
杏花
|
华中,华东,华北,东北,西南,西北 3 - 4月
|
梅花
|
全国 1-3月
|
杜鹃
|
华南,华中,华东;4-6月
|
荷花
|
全国;6-9月
|
桂花
|
华南,华中,华东 9-10 月
|
梨花
|
|
菊花
|
|
竹
|
|
柳
|
华北 4月
|
惩罚标签
|
|
白天(惩罚项)
|
日落-日出
|
夜晚(惩罚项)
|
日出-日落
|
15. 更新历史
2019.01.31 安卓 SDK 上线,版本为 1.1
2019.01.19 更新今日诗词版本为 2.2,重写推荐引擎,大幅提高推荐的应景效果。NPM-SDK 1.0 上线。
2018.12.28 更新浏览器 SDK 版本为 1.2,增强兼容性,特别针对 Safari 优化
2018.10.31 更新今日诗词版本为 2.1 ,大幅降低推荐的重复性,可以显示更多没有看过的诗词
2018.10.25 更新浏览器 SDK 版本为 1.1,增强兼容性,支持 class 标签自动赋值
2018.09.23 今日诗词的第一个版本 2.0 BETA 上线,浏览器 SDK 1.0,小程序 SDK 1.0 上线
因为我们的 旧API接口 为1.X版本,所以 今日诗词API 版本号从 2.X 开始 |