开发一个属于自己的一言 (Hitokoto) api网站

时间:2020-6-17    作者:晨曦    分类: 源码之家


基本思路展开目录

什么心路历程也懒得写了,虽然说一言 api 烂大街,但是用别人的接口始终不放心,所以说还是维护一个自己的接口比较好。
我的思路就是:采集别人,壮大自己!
是的,没有看错,自己采集得采集到猴年马月,直接采集别人来的痛快。

采集部分展开目录

首先,我们需要采集别人的,并保存到本地,所以说我这里写了一个通用采集的模板,代码如下:


  • <?php
  • $api[] = 'http://api.moleft.cn/yiyan/api.php';
  • $api[] = 'https://api.moleft.cn/yiyan/api.php';
  • $contents = file_get_contents($api[mt_rand(0,count($api)-1)]);
  • if(!empty($contents) && !preg_match('/'.$contents.'/',file_get_contents('./api.txt'))){
  • file_put_contents('./api.txt',$contents."\n",FILE_APPEND);
  • echo 'Success -> '.$contents;
  • }else{
  • echo 'Failed -> 获取数据失败';
  • }
  • ?>

如果想要增加 api 的话,可以照着这个模板写,也就是:


  • $api[] = '要采集的api';

这样的话,我们就可以采集别人的,同时我加了重复的判断,所以说不用担心采集到的会有重复,同时多 api 随机采集也可以最大程度避免采集同一 api 导致防火墙拦截

接口部分展开目录

接口部分没什么特殊的,就是很 “模板” 的一个一言接口模板


  • <?php
  • //获取句子文件的绝对路径
  • $path = dirname(__FILE__);
  • $file = file($path."/api.txt");
  • //随机读取一行
  • $arr = mt_rand( 0, count( $file ) - 1 );
  • $content = trim($file[$arr]);
  • //编码判断,用于输出相应的响应头部编码
  • if (isset($_GET['charset']) && !empty($_GET['charset'])) {
  • $charset = $_GET['charset'];
  • if (strcasecmp($charset,"gbk") == 0 ) {
  • $content = mb_convert_encoding($content,'gbk', 'utf-8');
  • }
  • } else {
  • $charset = 'utf-8';
  • }
  • //格式化判断,输出js或纯文本
  • if ($_GET['encode'] === 'js') {
  • echo "function api(){document.write('" . $content ."');}";
  • }else if($_GET['encode'] === 'json'){
  • $content = array('text'=>$content);
  • echo json_encode($content, JSON_UNESCAPED_UNICODE);
  • }else {
  • echo $content;
  • }
  • ?>

大功告成展开目录

这样的话我们就维护了一个属于自己的一言 api,如果发现哪个接口死了,还可以安装那个格式继续添加,采集下来的 api 都保存到本地,我建议采集部分和接口部分保存到两个文件中,然后给那个采集部分挂个计划任务,这样就可以 24 小时不停的采集了。
哈哈哈哈,采集别人,壮大自己,估计采集个一年半载你就是全网最靓的仔!