markdown编辑器实现图片上传图床

有熟悉的朋友可能知道我最近一直在做编辑器的小项目,麻雀虽小,五脏俱全吧。最近做到插入图片的部分了,简单分享一下方案。

前期选型主要有三种方案:

  • 纯前端获取本地绝对路径,直接赋值(可以在编辑器中正常显示,但是文件无法被控制,且无法上传到各网站)
  • 使用云服务厂商提供的OSS服务(方便快捷,而且不用操心,但是花钱。个人小项目慎用,尤其是公开的项目,会有人恶意刷流量)
  • 使用个人服务器搭建图床(搭建费点儿劲,需要自己维护,但是近乎免费。花钱买了个99一年的服务器~)

所以,没啥可选的,直接第三种方案。

图床程序选择了开源的EasyImage2.0,原因很简单,宝塔面板上有一键安装,并且玩儿起来比较简单。

安装图床

如果有服务器使用宝塔面板的可以去软件商店直接搜,点击一键安装,齐活!

如果不用宝塔面板可以参考一下官网文档《icret.github.io/EasyImages2...

安装依赖

EasyImage2.0项目依赖PHP以及Nginx,另外需要安装一下PHP内部的一些依赖(一般都是默认安装好的),Fileinfo、iconv、zip、mbstring、openssl。

安装程序

Windows Server的话可以直接下载程序。

Linux可以用git下载程序,或者在Github上下载完成以后上传。

配置代理

另外就是需要配置下Nginx代理,将某个端口代理到EasyImage2.0的程序文件夹下。

nginx 复制代码
location / {
    root /home/www/easyImage
    index index.html;
    try_files $uri $uri/ /index.html;
}

上传图片

安装完成正常运行图床程序以后,就可以着手上传程序的开发了。

html 复制代码
<button onclick="uploadImage">上传图片</button>
<input type="file" id="uploadImageId" style="display: none" oninput="changeUploadImage" />


<script>
function uploadImage() {
    document.getElementById("uploadImageId").click();
}

function changeUploadImage() { 
    let file = document.getElementById("uploadImageId").files[0];
    if (file) {
        let formData = new FormData();
        formData.append("name": file.name);
        formData.append("file", file);
        formData.append("sign", new Date().getTime() / 1000 | 0);
        $.ajax({
            url: "http://图床地址/app/upload.php",
            type: "POST",
            data: formData,
            processData: false,
            contentType: false,
            success: function (data) {
                console.log(data.url);
            }
        })
    }
}
</script>

注意:这里可能存在跨域问题,记得部署代理。

相关推荐
再学一点就睡22 分钟前
前端必会:Promise 全解析,从原理到实战
前端·javascript·面试
前端工作日常1 小时前
我理解的eslint配置
前端·eslint
前端工作日常1 小时前
项目价值判断的核心标准
前端·程序员
90后的晨仔2 小时前
理解 Vue 的列表渲染:从传统 DOM 到响应式世界的演进
前端·vue.js
OEC小胖胖2 小时前
性能优化(一):时间分片(Time Slicing):让你的应用在高负载下“永不卡顿”的秘密
前端·javascript·性能优化·web
烛阴2 小时前
ABS - Rhomb
前端·webgl
植物系青年2 小时前
10+核心功能点!低代码平台实现不完全指南 🧭(下)
前端·低代码
植物系青年2 小时前
10+核心功能点!低代码平台实现不完全指南 🧭(上)
前端·低代码
桑晒.3 小时前
CSRF漏洞原理及利用
前端·web安全·网络安全·csrf
宋辰月3 小时前
Vue2-VueRouter
开发语言·前端·javascript