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>

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

相关推荐
小兵张健8 小时前
价值1000的 AI 工作流:Codex 通用前端协作模式
前端·aigc·ai编程
sunny_8 小时前
面试踩大坑!同一段 Node.js 代码,CJS 和 ESM 的执行顺序居然是反的?!99% 的人都答错了
前端·面试·node.js
拉不动的猪8 小时前
移动端调试工具VConsole初始化时的加载阻塞问题
前端·javascript·微信小程序
ayqy贾杰10 小时前
Agent First Engineering
前端·vue.js·面试
IT_陈寒10 小时前
SpringBoot实战:5个让你的API性能翻倍的隐藏技巧
前端·人工智能·后端
iceiceiceice10 小时前
iOS PDF阅读器段评实现:如何从 PDFSelection 精准还原一个自然段
前端·人工智能·ios
大金乄11 小时前
封装一个vue2的elementUI 表格组件(包含表格编辑以及多级表头)
前端·javascript
葡萄城技术团队11 小时前
【性能优化篇】面对万行数据也不卡顿?揭秘协同服务器的“片段机制 (Fragments)”
前端
程序员阿峰12 小时前
2026前端必备:TensorFlow.js,浏览器里的AI引擎,不写Python也能玩转智能
前端
Jans12 小时前
Shipfe — Rust 写的前端静态部署工具:一条命令上线 + 零停机 + 可回滚 + 自动清理
前端