昨天在 YouTube 上看到又一个搭建自己短网址的视频教程,用的是开源的 polr,但是按照步骤一步步搭建下来,最后一步都会出现
PLAINTEXT
Whoops, looks like something went wrong |
百度、谷歌查了一圈也没找到有效的解决方法。(顺带说一下,查出来很多的文章都是出自同一个作者,国内有的人就是瞎转载,自己根本没有尝试过,一个人错了,转载的人也跟着一起错,完全在浪费搜索者的时间,这个现象在百度、CSDN 现尤为严重,谷歌相对好一点)
折腾了一晚上,换了两台服务器,查看官方文档,尝试了几种方法也没解决问题,心里非常不舒服。
考虑到 polr 也很久没有更新了,自己的能力也不足以解决遇到的 bug,而工作原因,确实对点击链接的统计有需求,我开始寻找别的解决方案。
然后找到了这个 ——YOURLS
官方文档:https://yourls.org
YOURLS stands for Your Own URL Shortener. It is a small set of PHP scripts that will allow you to run your own URL shortening service (a la TinyURL or Bitly).
Running your own URL shortener is fun, geeky and useful: you own your data and don’t depend on third-party services. It’s also a great way to add branding to your short URLs, instead of using the same public URL shortener everyone uses.
大概意思就是说 YOURLS,这个基于 PHP 开发的短链接服务,适用于私有,且不依赖第三方公共短链接生成。你只需要有一定的耐心和一个短域名,就可以感受到短链接生成的乐趣。
跟着官方文档和 Pluto Tz 提供的文章,结合自己的生产环境,我终于成功搭建好了自己的短链接服务。
展示链接
下面是一步一步的安装记录。
系统 Centos7
宝塔面板(LNMP)
首先,打开宝塔面板,我们来添加一个已经解析好的网站。
安装数据库,php。
然后给域名申请一个 SSL 证书:
开启强制 https:
设置伪静态:
PLAINTEXT
location / { try_files $uri $uri/ /yourls-loader.php$is_args$args; } |
到 github 上下载最新版本:
https://github.com/YOURLS/YOURLS/releases
目前最新的是 1.7.9
选择下载(国内速度比较慢,不过好在文件不大,只有 2.7M)
当然如果我们的服务器不在大陆的话,还可以用服务器来下载,速度会快很多。
方法如下:
打开网站根目录:
下载好了之后,直接点解压:
打开 YOURLS-1.7.9
文件夹,全选里面的内容,粘贴到网站根目录:
接下来打开目录 /user/
, 把里面的 config-sample.php
改成 config.php
。
然后我们来编辑里面的内容:
打开之后是这样的:
PLAINTEXT
'password', // 'username2' => 'password2', // You can have one or more 'login'=>'password' lines ); /** Debug mode to output some internal information ** Default is false for live site. Enable when coding or before submitting a new issue */ define( 'YOURLS_DEBUG', false ); /* ** URL Shortening settings */ /** URL shortening method: 36 or 62 */ define( 'YOURLS_URL_CONVERT', 36 ); /* * 36: generates all lowercase keywords (ie: 13jkm) * 62: generates mixed case keywords (ie: 13jKm or 13JKm) * Stick to one setting. It's best not to change after you've started creating links. */ /** * Reserved keywords (so that generated URLs won't match them) * Define here negative, unwanted or potentially misleading keywords. */ $yourls_reserved_URL = array( 'porn', 'faggot', 'sex', 'nigger', 'fuck', 'cunt', 'dick', ); /* ** Personal settings would go after here. */ |
下面一条一条来说明:
PLAINTEXT
define( 'YOURLS_DB_USER', 'your db user name' ); # 数据库用户名 define( 'YOURLS_DB_PASS', 'your db password' ); # 数据库密码 define( 'YOURLS_DB_NAME', 'yourls' ); # 数据库名称 define( 'YOURLS_DB_HOST', 'localhost' ); # 不用改 define( 'YOURLS_DB_PREFIX', 'yourls_' ); # 不用改 define( 'YOURLS_SITE', 'http://your-own-domain-here.com' ); # 你自己的域名 越短越好,比如我的loll.cc(再短的申请不到了。。。)短地址基于这个生成。 define( 'YOURLS_HOURS_OFFSET', 0 ); # 时区偏移 改成 8 define( 'YOURLS_LANG', '' ); # 语言设置,默认是英文,后面我们改成中文版本,填'zh_CN' define( 'YOURLS_UNIQUE_URLS', true ); # 不用改,短地址是否唯一 define( 'YOURLS_PRIVATE', true ); # 不用改,是否私有,如果私有的,则进行api调用生成短地址时需要传递用户名和密码 define( 'YOURLS_COOKIEKEY', 'modify this text with something random' ); # 点击http://yourls.org/cookie 复制里面的密钥,这个不用记住的。 'username' => 'password', # 用户名=>密码 可填多个 登录成功后这里的明文密码会被加密,这里默认是没有的,我们为了安全加上一个,比如用户名是'admin',密码是'123456' define( 'YOURLS_DEBUG', false ); # 不用改,是否开启调试 define( 'YOURLS_URL_CONVERT', 36 ); # 自己设置使用36进制 还是62进制 这个最好一开始设好不要修改,避免地址冲突,建议62进制 $yourls_reserved_URL = array( 'porn', 'faggot', 'sex', 'nigger', 'fuck', 'cunt', 'dick', ); # 排除这些敏感词汇,这些地址是不会生成的 |
首先是数据库的相关信息,由于我们创建网站的时候已经创建好了数据库,所以,可以在这边找到数据库的情况:
‘YOURLS_COOKIEKEY’的信息:
填完之后,保存。
下面我们来安装语言包(如果没改成’zh_CN’的话,自己想要用英文,这一步可以跳过)
语音包地址:
https://github.com/ZvonimirSun/YOURLS-zh_CN
作者已经停止更新了貌似,不过还可以用,有能力的同学也可以帮忙翻译。
语音包下载方法同上面讲过的,两种方法,自行选择。
我这里还是用服务器下载:
同样,解压,然后把 /user/languages/YOURLS-zh_CN-1.7.3
的文件剪切出来:
到这里应该基本上已经完成了,访问一下
浏览器 输入 https:// 域名 /admin。
报错了!!
观察网站,可能是域名路径的问题,我之前在
define( 'YOURLS_SITE', 'http://your-own-domain-here.com' );
没有加 https://
, 修改一下再看看:
ok!
直接点击安装!
由于我们之前已经配置好的数据库等文件,所以这里直接显示完成了。
点击进入管理员页面,
输入账号密码就可以访问啦!
这边我提供一个测试账号给大家测试一下,账号 admin
, 密码 loll.cc
, 后续会关掉,仅仅供测试用噢。
添加一个网址:
压缩网址。
之后可以通过在短网址之后加上一个 +
号来查看数据情况。
可以愉快地玩起来了!
这里是来自 PlutoTz 博客的补充内容。
你可能遇到一些问题:
1、如果安装报错,或者不跳转,那有可能是你的 php 或者 mysql 版本过低
2、短链接后面从 1 开始,很不爽,可以推荐用时间戳来生成
只需要修改 includes/functions.php 272 行左右
将 $id = yourls_get_next_decimal();
改为 $id = time();
这样的话,后面链接会变长,而且不知道是 bug 还是什么原因,我想改回来改不回来,有需要的同学可以尝试一下。
YOURLS 还有很多插件,大家有兴趣可以再研究研究。
你可以使用官方自带的插件库:
https://github.com/YOURLS/awesome-yourls#plugins
完结撒花。
感谢 PlutoTz 写的非常详细的文档、感谢 YOURLS 提供了这么棒的项目,当然还有后面的众多的开发人员。
开源,让世界更美好。