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>

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

相关推荐
胡gh4 小时前
页面卡成PPT?重排重绘惹的祸!依旧性能优化
前端·javascript·面试
言兴4 小时前
# 深度解析 ECharts:从零到一构建企业级数据可视化看板
前端·javascript·面试
山有木兮木有枝_5 小时前
TailWind CSS
前端·css·postcss
烛阴5 小时前
TypeScript 的“读心术”:让类型在代码中“流动”起来
前端·javascript·typescript
杨荧5 小时前
基于Python的农作物病虫害防治网站 Python+Django+Vue.js
大数据·前端·vue.js·爬虫·python
Moment6 小时前
毕业一年了,分享一下我的四个开源项目!😊😊😊
前端·后端·开源
程序视点7 小时前
Escrcpy 3.0投屏控制软件使用教程:无线/有线连接+虚拟显示功能详解
前端·后端
silent_missile7 小时前
element-plus穿梭框transfer的调整
前端·javascript·vue.js
专注VB编程开发20年7 小时前
OpenXml、NPOI、EPPlus、Spire.Office组件对EXCEL ole对象附件的支持
前端·.net·excel·spire.office·npoi·openxml·spire.excel
古蓬莱掌管玉米的神7 小时前
coze娱乐ai换脸
前端