自建一言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>

自建一言API》一文由 Magneto 发布在SYMBK.CN一站上,采用《CC BY-NC-ND 4.0》,转载必须注明作者和本文链接。
如果想要纯净阅读您可以选择本文的AMP模式

评论

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

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


    查看图片
    QQ截图20210403182748.png




    查看图片
    QQ截图20210403182715.png




    查看图片
    QQ截图20210403182756.png

    • Magneto 博主
      Windows Edge
      6月前
      2021-4-03 19:28:40

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

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

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

        • Magneto 博主
          Windows Edge
          6月前
          2021-4-03 20:30:52

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

          • 沧笙踏歌
            Windows Firefox
            已编辑
            6月前
            2021-4-03 20:50:23

            是这样吗

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

            对,就是这样

          • 沧笙踏歌
            Windows Firefox
            6月前
            2021-4-03 21:13:21

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

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

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

发送评论 编辑评论

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