自建一言API

前言

很多网站都喜欢在页面中加个一言,不过一般都是调用的第三方api。其实,使用万能的php能通过短短的几行代码就实现该功能。

准备工作

首先准备一个代码编辑器,然后新建一个 php 文件,命名为 api.php,再新建一个文件,命名为 data.dat(两个文件均需采用 UTF-8 编码,否则会乱码)

打开 data.dat,在里面贴入要随机显示出来的文本,一行一条。如果你暂时想不出什么比较好的句子的话,于是我这儿准备了几十句网易云热评,可以直接点我下载引用。

上代码

将下列代码复制并粘贴到 api.php 中保存,你的专属“一言” API 就搭建完成了!超简单是不是……

<?php
// 存储数据的文件
$filename = 'data.dat';        
// 指定页面编码
header('Content-type: text/html; charset=utf-8');
if(!file_exists($filename)) {
    die($filename . ' 数据文件不存在');
}
$data = array();
// 打开文档
$fh = fopen($filename, 'r');
// 逐行读取并存入数组中
while (!feof($fh)) {
    $data[] = fgets($fh);
}
// 关闭文档
fclose($fh);
// 随机获取一行索引
$result = $data[array_rand($data)];
echo $result;

上面的代码是用 fopen + fgets 函数实现的,有些朋友似乎不是特别喜欢,觉得“效率低”。别急,这儿还有个 file_get_contents 函数实现的版本:

<?php
// 存储数据的文件
$filename = 'data.dat';
// 指定页面编码
header('Content-type: text/html; charset=utf-8');
if(!file_exists($filename)) {
    die($filename . ' 数据文件不存在');
}
// 读取整个数据文件
$data = file_get_contents($filename);
// 按换行符分割成数组
$data = explode(PHP_EOL, $data);
// 随机获取一行索引
$result = $data[array_rand($data)];
// 去除多余的换行符(保险起见)
$result = str_replace(array("\r","\n","\r\n"), '', $result);
echo $result;

如何在静态页面中引用

上面的代码都是直接在页面中就输出了随机的句子。如果想像一言那样在静态的网页中引用这个 api,该如何实现呢?

很简单,将最后那一行的 echo $result; 换成

echo 'document.write("'.htmlspecialchars($result).'");';

然后在需要的位置用引入 js 的方式进行调用即可。

示例代码:

<script src="http://你的网址/api.php"></script>
此文由 Magneto 发布,本文采用《CC BY-NC-ND 4.0》协议,转载必须注明作者和本文链接。

评论

  1. 沧笙踏歌
    Windows Firefox
    4 年前
    2021-4-03 18:30:53

    请问为什么会找不到文件内容


    查看图片
    QQ截图20210403182748.png




    查看图片
    QQ截图20210403182715.png




    查看图片
    QQ截图20210403182756.png

    • Magneto
      博主
      沧笙踏歌
      Windows Edge
      4 年前
      2021-4-03 19:28:40

      你应该要建立一个txt文件,可以参考起源实验室 OneSpeak

      • 沧笙踏歌
        Magneto
        Windows Firefox
        4 年前
        2021-4-03 20:29:31

        有txt文件,就是最下面那个

        • Magneto
          博主
          沧笙踏歌
          Windows Edge
          4 年前
          2021-4-03 20:30:52

          txt文件引用的地址不正确,要引用完,从站点根目录开始。

          • 沧笙踏歌
            Magneto
            Windows Firefox
            4 年前
            2021-4-03 20:50:23

            是这样吗

            // 存储数据的文件
            $filename = 'https://xxx.xxx.xxx/wp-content/themes/xxx/data.txt';
          • Magneto
            博主
            沧笙踏歌
            Windows Edge
            4 年前
            2021-4-03 20:51:05

            对,就是这样

          • 沧笙踏歌
            Magneto
            Windows Firefox
            4 年前
            2021-4-03 21:13:21

            还是报错。。。等会我还原备份看看,今天换了个主题出现的问题

    • 沧笙踏歌
      沧笙踏歌
      Windows Firefox
      4 年前
      2021-4-10 16:23:16

      懂了是我开了延迟加载js的缘故

发送评论 编辑评论

|´・ω・)ノ
ヾ(≧∇≦*)ゝ
(☆ω☆)
(╯‵□′)╯︵┴─┴
 ̄﹃ ̄
(/ω\)
∠( ᐛ 」∠)_
(๑•̀ㅁ•́ฅ)
→_→
୧(๑•̀⌄•́๑)૭
٩(ˊᗜˋ*)و
(ノ°ο°)ノ
(´இ皿இ`)
⌇●﹏●⌇
(ฅ´ω`ฅ)
(╯°A°)╯︵○○○
φ( ̄∇ ̄o)
ヾ(´・ ・`。)ノ"
( ง ᵒ̌皿ᵒ̌)ง⁼³₌₃
(ó﹏ò。)
Σ(っ °Д °;)っ
( ,,´・ω・)ノ"(´っω・`。)
╮(╯▽╰)╭
o(*////▽////*)q
>﹏<
( ๑´•ω•) "(ㆆᴗㆆ)
😂
😀
😅
😊
🙂
🙃
😌
😍
😘
😜
😝
😏
😒
🙄
😳
😡
😔
😫
😱
😭
💩
👻
🙌
🖕
👍
👫
👬
👭
🌚
🌝
🙈
💊
😶
🙏
🍦
🍉
😣
Source: github.com/k4yt3x/flowerhd
小恐龙
酷安
颜文字
Emoji
花!
上一篇
下一篇