Products
GG网络技术分享 2025-03-18 16:14 2
大家好,这里是关于[好用的PHP图床程序Chevereto安装教程介绍],[Docker系列 在markdown中使用chevereto]问题的解答,希望对您有所帮助。如果你还想了解更多这方面的信息,请关注本站其他相关内容,共同学习吧!
教程大全Chevereto,Chevereto图床安装教程,Chevereto版本,PHP图床,免费图床,图床程序
好用的PHP图床程序Chevereto安装教程介绍
这是一款PHP的图床程序,有免费版和付费版。免费付费区别其实不大,仅仅是技术支持和版本更新的区别。
本人在黑色星期五也就是本文发表当天购买了一个个人授权的付费版。19.5美元
下面给大家介绍下这款程序以及安装的步骤。
官网:https://chevereto.com/
demo:https://demo.chevereto.com/
首页预览图如下
安装要求:
Apache或Nginx Web服务器(推荐服务器)
PHP 5.6(推荐7.3)和标准库。
MySQL 8 / MariaDB 10
本人安装环境:nginx+PHP7.2+mysql5.6,使用的宝塔面板。
官方说是还需要安装PHP的一个扩展程序GD图像处理库,这个是涉及到图片的自动加水印等功能使用,本人没有安装这个支持库。
官方给出的安装文件是一个PHP文件,install.php
我们现需要在网站nginx配置文件中加入以下配置。
# Chevereto nginx generated rules for http://img.cheshirex.com/
## Disable access to sensitive files
location ~* /(app|content|lib)/.*\\.(po|php|lock|sql)$ {
deny all;
}
## CORS headers
location ~* /.*\\.(ttf|ttc|otf|eot|woff|woff2|font.css|css|js) {
add_header Access-Control-Allow-Origin \"*\";
}
## Upload path for image content only and set 404 replacement
location ^~ /images/ {
location ~* (jpe?g|png|gif) {
log_not_found off;
error_page 404 /content/images/system/default/404.gif;
}
return 403;
}
## Pretty URLs
location / {
index index.php;
try_files $uri $uri/ /index.php?$query_string;
}
# END Chevereto nginx rules加入的位置如下图
在最后一个}前面粘贴进入即可。
将install.php安装文件上传到网站根目录,然后访问就进入了安装过程
第一步是让你输入序列号,可以不输入安装免费版。
下面就是填入数据库等信息然后市创建管理员账户
然后是输入系统邮件地址等等,按照说明一步步安装下来即可。
安装到最后会自动设置,然后下载程序包,程序包下载可能会出现什么http错误之类的,如果出现错误就刷新网页从头开始重新安装。我的重复了2次才成功。
安装后默认的全局后台位置是你的域名/dashboard/bulk
没一个账户也都可以进行一些自动已设置,根据自己喜好设置即可。
在上一回Docker系列 搭建个人图床chevereto中,我们用Docker镜像安装了chevereto。虽然chevereto的功能是强大,但有时功能强大就代表其设置比较复杂。我记得刚刚开始玩的时候,都不知道那些设置是什么意思,都采用的默认值,哈哈!不过采用默认值有一些潜在的不便,特别是国内用户。下面,我会简单地和大家说一下我自己用的chevereto图床是怎么设置。
大家可以看一下我的图床:https://chevereto.hwb0307.com。颜值是不是非常高呢!和其它方法搭建的chevereto是完全一样的喔!
当然,最重要的是怎么让chevereto集成在你的typora里面,实现图片的随粘随传!这才是markdown的正确使用方式!
仪表盘,即dashboard一般就是指后台。这和wordpress的wp-admin是类似的。
在我的图床里,访问地址就是:https://chevereto.hwb0307.com/dashboard。chevereto的dashboard你们在上回也基本见过了,我的图床长这样:
dashboard是有多个页面的,包括统计、图片、相册、用户、设置、批量导入。在统计中,可以看到我图床的版本是1.4.1。我用的版本和你们的一样,也是旧版喔!MYSQL数据库版本则是5.5.5-10.7.3-MariaDB-1:10.7.3+maria~focal。这里可能大家发现了,MYSQL和MariaDB好像是同一个东西。一般在开源社区,大家都使用MariaDB,因为MYSQL已经被甲骨文公司收购了嘛!
大家还记得之前的php.ini的内容吗?
upload_max_filesize = 100M
post_max_size = 100M
memory_limit = 3072M
其实和这里的设置是一一对应的:
最大的文件上传:100 MB
最大的执行大小:100 MB
内存限制:3.1 GB
如果你不设置它,默认情况下是一个很小的值(好像是2M),这会带来不便,因为你的图片很有可能超过2M嘛!虽然在markdown使用中比较罕见。作为个人使用,当然要将上限调得高高的!
当然,默认值还是比较低的,到时要在后台改动。详情就往下看吧!
正在连接的IP172.26.0.1是一个局域网地址。它应该是chevereto这个Stack的网关的地址。你也可以在Portainer上确认一下是不是噢!
整体的布局就是长这样:
你双击这个图片,就可以观察这个图片的详细信息,它们是关于、嵌入代码、详细信息。比如:
所以说,chevereto的功能还是很强的!至少可以对同一张图片生成很多不同用途的链接,对吧!
我的相册只有一个,就是typora。我在typora上粘贴的图片都会放在这个相册里。
我个人认为,这个相册对于新接触的chevereto的markdown用户来说十分重要。我强烈建议你应该创建一个相册,将typora上传上来的图片集中管理。如果你不设置相册,在使用API的时候,它会以访客的身份上传图片。我还没找到怎么将访客的图片转移到特定用户的特定相册。或许这是付费功能;或许通过对MYSQL的操作可以做到,但我觉得这对普通用户来说都不太友好。如果你以后有意拓展chevereto的用途,应该在一开始就建立一个特定的相册来管理API接口的图片。放心,本文也会教你怎么操作的!
这里教大家看一下相册的album id。后面有用:
我贴一些图,大家可以根据我的设置来搞。或者你可以自定义喽。如果我设置不对,大家也指正一下!
可设置的项目非常多:
你可以按我的设置来初始化。如果你有什么不满意,自己微调即可。
这里值得一说的,搜索、探索、随机、喜欢、粉丝禁用后,这样访客就看不到你的图片。如果你想别人看到你的图片,就可以启用。还有就是网站的隐私模式,只有选了访客开放,非注册用户才可以看到你酷酷的图床主页的图片切换!
因为是个人使用,所以禁用开放注册。
这里国内的用户要特别注意,将自动更新检查设置为禁用。不然,它可能会影响你登陆后台!这个问题曾经困扰我1年多。我开始以为是自己宝塔哪里设置的不对呢!后来发现是这个自动更新检查开启时,它会向github请求;而国内正常情况下github会封禁,无法访问。
这里红框的要多加注意。一般个人用,肯定是禁止访客上传数据的嘛!我不知道这个会不会影响API上传。如果影响,你们就启用吧!
这里值得一说的是,你可以在主页设置多个图片,让图床的主页好看些(没什么卵用系列)。比如我就设置了多张图片:
这里还有一个语言选项,我是默认的,没有动过。不知道这个有没有什么影响?
终于来到最重要的一个设置了。这个密钥你记住。它是类似于阿里云token一样的东西。有了它,可以不需要密码即可访问图床呢!这也是我们在typora里集成chevereto的最重要的参数。
没说到的都默认就行。
在进一步设置typora和PicGo之前呢,让我们回到Shell修改一些Chevereto的文件。
# 工作目录
work=~/docker/chevereto/app/html
将网站根目录html下的./app/routes/route.api.php复制到同目录下的/overrides文件夹。该步骤使得复制后的文件在不替换的情况下更新,既保存源文件,又使修改后的代码能在源代码保留的情况下运行。
# 复制文件
sudo cp $work/app/routes/route.api.php $work/app/routes/overrides
# 将文件改为www-data所有
sudo chown -R 33:33 $work/app/routes/overrides
然后修改这个复制后的文件:
sudo vim $work/app/routes/overrides/route.api.php
±对应新增删除代码:
$version = $handler->request[0];
$action = $handler->request[1];
+ $user = $_REQUEST['user'];// 新增
+ $album = $_REQUEST['album'];//新增
...
// CHV\\Image::uploadToWebsite($source, 'username', [params]) to inject API uploads to a given username
- $uploaded_id = CHV\\Image::uploadToWebsite($source);
+ $uploaded_id = CHV\\Image::uploadToWebsite($source, $user, array('album_id'=>$album));
这里有一些截图,大家看一下:
该步骤将接受来自客户端的用户名和相册 ID 参数,避免上传至访客相册。
最后,重启一下chevereto以使配置生效:
cd ~/docker/chevereto && docker-compose restart
这一步有人教就不难。应该没什么问题吧?有问题评论区留言吧!
大致的原理是这样的Typora--PicGo--Chevereto。
PicGo的Github仓库地址是:https://github.com/Molunerfinn/PicGo。有16.6k收藏!
我在这里演示怎么在本地端(windows 10)安装PicGo-core和web-uploader。Mac的童鞋自己去找教程。PicGo其实和其它Windows软件类似,我觉得它用法比较多样、简单,这里我就不详细展开了。有兴趣进一步了解Google百度。
我们专注于PicGo中与typora和chevereto的相关设置!如果有什么疑难,评论区留言即可。
npm -v # 6.13.4
node -v # v12.15.0
# 查看默认的npm镜像。不然下载会卡顿
npm get registry # https://registry.npmjs.org/
# 更改默认镜像。我这里用的是阿里的镜像。
npm config set registry https://registry.npm.taobao.org
# npm下载并安装picgo-core
npm install -g picgo
# 检查安装成功与否
picgo -h
# picgo中安装web-uploader插件(依赖npm,要事先设定好镜像)
picgo install web-uploader
# 观察picgo的位置
which picgo # /cygdrive/c/Users/Administrator/AppData/Roaming/npm/picgo
# 添加picgo至环境变量。如果是通过npm直接安装的picgo,则不需要自己添加环境路径。另外,要找到picgo的config.json文件
picgo upload -c C:\\Users\\Administrator\\.picgo\\config.json # 这是我的typora的设置
如果你用Everything之类的快速文件检索软件,搜索.picgo\\config.json可以迅速定位喔!
PicGo的config.json文件内容如下:
{
"picBed": {
"uploader": "web-uploader",
"current": "web-uploader",
"transformer": "path",
"web-uploader": {
"customBody": "{\\"key\\":\\"09900000000000000000000000b\\", \\"user\\":\\"test_user\\", \\"album\\":\\"1\\"}",
"customHeader": null,
"jsonPath": "image.url",
"paramName": "source",
"url": "https://chevereto.hwb0307.com/api/1/upload"
}
},
"picgoPlugins": {
"picgo-plugin-web-uploader@1.1.1": true,
"picgo-plugin-web-uploader": true
}
}一般这种Json文件可以用notepad++或者windows自带的记事本软件打开。
打开偏好设置:
依次进入到设置图像的地方。在上传服务里选择Custom Command,命令是填写picgo upload -c C:\\Users\\Administrator\\.picgo\\config.json。当然,如果你的picgo不在windows系统的环境路径中,你应该写绝对路径。如果你是按我的方法来安装的,应该是在环境路径中的。
你可以点一下验证图片上传选项。正常的结果如下:
如果你不行,应该是有什么设置没对。自己检查一下,或者评论区留言了!
如果你现在才搭建成功chevereto,但你的markdown文件里就有一些旧图片怎么办?
如果你的旧图片(无论是本地还是其它图床的图片)可以用的话,直接在typora中右键你的图片,点上传图片即可。
可能还有其它更好的方法,欢迎评论区留言啦!
一般我建议在换新图床的时候,应该保持一段时间你的旧图床的正常运行。等你过了一段时间(比如1年),觉得已经过渡了,再正式地弃用旧图床,使用新图床。当然,如果你一开始就有一个好选择,就不用烦恼这种事了!
本文终于将chevereto常规设置、在Typora中集成chevereto讲完了。老实话,设置还蛮复杂的。不过,你基本也只需要设置一次而已嘛!
这个文章也是为自己而写,如果以后有什么不记得了,就回来看看。
另外,我不知道不更新软件会不会留下什么漏洞。不过我的chevereto是用的NPM反代,应该还是蛮安全的吧!如果有大佬的话,也欢迎就图床安全问题给点建议噢!
虽然我可以成功地设置,不过我还是觉得这些方法不够简洁。如果Typora有内置网络图床的服务,说不定对很多用户有都很有吸引力呢!毕竟不是所有人都像我一样喜欢折腾的!大多数人一定是喜欢最简单的!
我觉得,可能不少人初次设置无法成功的。如果有什么问题,欢迎评论区留言。祝你好运
另外再次强调,一定要用duplicati做好chevereto的备份!
其实应该有看不少文章,但是年代久远,很多链接失效了,找不到原文。
Demand feedback