博客集成Hitokoto·一言经典语句功能

crazybird 2021-01-21 631阅读 0评论

温馨提示:这篇文章已超过615天没有更新,请注意相关的内容是否还可用!

Hitokoto·一言是一个挺有意思的项目,官方的自我介绍如下:

一言网(Hitokoto.cn)创立于2016年,隶属于萌创Team,目前网站主要提供一句话服务。

动漫也好、小说也好、网络也好,不论在哪里,我们总会看到有那么一两个句子能穿透你的心。我们把这些句子汇聚起来,形成一言网络,以传递更多的感动。如果可以,我们希望我们没有停止服务的那一天。

简单来说,一言指的就是一句话,可以是动漫中的台词,也可以是网络上的各种小段子。
或是感动,或是开心,有或是单纯的回忆。来到这里,留下你所喜欢的那一句句话,与大家分享,这就是一言存在的目的。

自己用了好一段时间了,看到有不少朋友在问文章底部那个一句话是怎么实现的,所以这里来分享下。

一、部署接口

<?php
//获取句子文件的绝对路径
//如果你介意别人可能会拖走这个文本,可以把文件名自定义一下,或者通过Nginx禁止拉取也行。
$path = dirname(__FILE__);
$file = file($path."/hitokoto.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';
}
header("Content-Type: text/html; charset=$charset");
 
//格式化判断,输出js或纯文本
if ($_GET['format'] === 'js') {
    echo "function hitokoto(){document.write('" . $content ."');}";
} else {
    echo $content;
}

以上代码保存为index.php,然后上传到网站根目录下的hitokoto文件夹,并在hitokoto文件夹新建文本hitokoto.txt,内容为你想显示的一言简语

现在,浏览器访问 http://你的域名/hitokoto/ 就可以看到输出内容了。


二、博客集成

第一步我们已经完成了这个接口的自建部署,现在可以把这个功能搬到博客上了。

部署方法和其他博客基本一致,非常简单,将下面两行代码添加到博客你想显示一言的位置即可:

<script type="text/javascript" src="https://你的域名/hitokoto/?format=js&charset=utf-8"></script>
<div id="hitokoto"><script>hitokoto()</script></div>

不过,这样输出的样式可能会比较丑,如果你懂CSS的话可以自己再美化美化。

当然,不会css的朋友可以先试下我这边写好的css代码(可以加到style.css):

#hitokoto{    
border-left: 5px solid #2f889a;    
border-right: 5px solid #2f889a;    
background-color: #ebebeb;    
padding: 10px;text-align: center;    
color: #095AD4;    
margin: 5px 0 5px 0;    
}

部署完成之后,前台刷新应该就可以看到效果了,每次刷新都会随机展示一言经典句子。如果你有新的句子,也只要编辑hitokoto.txt文件加入即可。

免责声明:本文来自张戈博客,不代表云维护的观点和立场,如有侵权请联系本平台处理。

发表评论

快捷回复: 表情:
验证码
评论列表 (暂无评论,631人围观)

还没有评论,来说两句吧...

取消
微信二维码
微信二维码
支付宝二维码