【NKeditor】富文本編輯器上傳圖片

来源:https://www.cnblogs.com/zxf100/archive/2023/09/05/17680240.html
-Advertisement-
Play Games

目的: 使用NKeditor富文本編輯器上傳圖片,同時上傳到七牛雲存儲上。後端語言使用ThinkPHP。 效果 實現方法: 1、下載NKeditor插件庫 下載地址:NKeditor: NKedtior是一款優秀的輕量級Web編輯器,基於 Kindedior 二次開發 裡面的文檔demo寫的比較詳細 ...


目的:

使用NKeditor富文本編輯器上傳圖片,同時上傳到七牛雲存儲上。後端語言使用ThinkPHP。

效果

實現方法:

1、下載NKeditor插件庫

下載地址:NKeditor: NKedtior是一款優秀的輕量級Web編輯器,基於 Kindedior 二次開發

裡面的文檔demo寫的比較詳細,可以直接使用,不過裡面上傳七牛雲的代碼不能用,所以我是自己寫的。 

2、部署

 把下載的NKeditor插件庫放到/public/文件夾下。

 
<link href="/NKeditor/libs/bootstrap/bootstrap.min.css" rel="stylesheet">
 
<div role="tabpanel" class="tab-pane fade" id="default">
    <form name="example" method="post">
        <textarea name="content2" style="width:900px;height:500px;visibility:hidden;"></textarea>
    </form>
</div>
 
 
<script charset="utf-8" src="/NKeditor/NKeditor-all.js"></script>
<!-- 如果你不需要使用批量圖片上傳,塗鴉功能和文件管理功能,就不需要引入 jquery -->
<script charset="utf-8" src="/NKeditor/libs/jquery.min.js"></script>
<!-- JDialog是一款優秀的漂亮,輕量級的js彈出框插件 不是必須引入的,如果不引入則使用預設的 window.alert() 來彈出提示信息 -->
<script charset="utf-8" src="/NKeditor/libs/JDialog/JDialog.min.js"></script>
<script src="/NKeditor/libs/bootstrap/bootstrap.min.js"></script>
 
<script>
KindEditor.ready(function(K) {
    
    K.create('textarea[name="mytextarea"]', {
        uploadJson : '/teacher/qiniu/uploadImg',
        // fileManagerJson : K.basePath+'php/qiniu/file_manager_json.php',
        dialogOffset : 0, //對話框距離頁面頂部的位置,預設為0居中,
        allowFileManager : false,
        allowImageUpload : true,
        allowMediaUpload : false,
        items : ['source','undo','redo','preview','print','code','quote','plainpaste','justifyleft','justifycenter','justifyright','justifyfull','insertorderedlist','insertunorderedlist','indent','outdent','subscript','superscript','clearhtml','quickformat','selectall','formatblock','fontname','fontsize','forecolor','hilitecolor','bold','italic','underline','strikethrough','lineheight','removeformat','image','table','tablecell','hr','baidumap','pagebreak','link','unlink','fullscreen'
        ],
        afterCreate : function() {
            var self = this;
            K.ctrl(document, 13, function() {
                self.sync();
                K('form[name=example]')[0].submit();
            });
            K.ctrl(self.edit.doc, 13, function() {
                self.sync();
                K('form[name=example]')[0].submit();
            });
        },
        showHelpGrid: false, // 是否顯示輸入輔助線
        themeType : "black", //主題
        //錯誤處理 handler
        errorMsgHandler : function(message, type) {
            try {
                JDialog.msg({type:type, content:message, timer:2000});
            } catch (Error) {
                alert(message);
            }
        }
    });
})
</script>

後端代碼:返回值是json,返回格式與下麵代碼一致。

<?php
namespace app\teacher\controller;
use think\Controller;
use Qiniu\Auth as Auth;
use Qiniu\Storage\BucketManager;
use Qiniu\Storage\UploadManager;
 
/**
 * 七牛雲操作
 */
class Qiniu extends Base
{
 
    public function uploadImg()
    {
        error_reporting(0);
 
        vendor('qiniu.autoload');
        $accessKey = config('ACCESSKEY');
        $secretKey = config('SECRETKEY');
        $bucket = config('BUCKET');
        $domain = config('DOMAIN');
 
        $fileType = trim($_GET['fileType']);
 
        if (empty($fileType)) {
            $fileType = "image";
        }
 
        // 要上傳圖片的本地路徑
        $filePath = $_FILES['imgFile']['tmp_name'];
 
        $ext = substr($_FILES['imgFile']['name'],strrpos($_FILES['imgFile']['name'],'.')+1);  //文件尾碼
         // 尾碼大寫轉換成小寫
         $ext = strtolower($ext);
 
        $format = array('png','jpg','gif','jpeg','bmp','tif','svg','webp');  //允許上傳的格式
        if (!in_array($ext,$format)) {
            $result = array(
                'code'=>'001',
                'message'=>'格式錯誤'
            );
        }
 
        // 上傳到七牛後保存的文件名
        $key = 'shouyi_img/'.substr(md5($filePath) , 0, 5) .'/'. date('YmdHis') . rand(0, 9999) . '.' . $ext;
 
        // 構建鑒權對象
        $auth = new Auth($accessKey, $secretKey);
 
        $token = $auth->uploadToken($bucket);
 
        // 初始化 UploadManager 對象併進行文件的上傳
        $uploadMgr = new UploadManager();
 
        // 調用 UploadManager 的 putFile 方法進行文件的上傳
        list($ret, $err) = $uploadMgr->putFile($token, $key, $filePath);
 
        // var_dump($ret);
        if ($err !== null) {
 
            $result = array(
                'code'=>'001',
                'message'=>'上傳失敗'
            );
 
        } else {
            $result = array(
                'code'=>'000',
                'message'=>'上傳成功'.$_FILES['imgFile']['name'],
                'data'=>array('url' => $domain . $ret['key']),
            );
        }
 
        die(json_encode($result,JSON_UNESCAPED_UNICODE));
    }
}

文件上傳到七牛雲可參看之前寫的文章:【七牛雲】使用PHP把文件上傳到七牛雲_php 七牛雲上傳_下頁、再停留的博客-CSDN博客

4、自定義工具欄

在items根據需要添加相應的功能

    source : 'HTML代碼',
    preview : '預覽',
    undo : '後退(Ctrl+Z)',
    redo : '前進(Ctrl+Y)',
    cut : '剪切(Ctrl+X)',
    copy : '複製(Ctrl+C)',
    paste : '粘貼(Ctrl+V)',
    plainpaste : '粘貼為無格式文本',
    wordpaste : '從Word粘貼',
    selectall : '全選(Ctrl+A)',
    justifyleft : '左對齊',
    justifycenter : '居中',
    justifyright : '右對齊',
    justifyfull : '兩端對齊',
    insertorderedlist : '編號',
    insertunorderedlist : '項目符號',
    indent : '增加縮進',
    outdent : '減少縮進',
    subscript : '下標',
    superscript : '上標',
    formatblock : '段落',
    fontname : '字體',
    fontsize : '文字大小',
    forecolor : '文字顏色',
    hilitecolor : '文字背景',
    bold : '粗體(Ctrl+B)',
    italic : '斜體(Ctrl+I)',
    underline : '下劃線(Ctrl+U)',
    strikethrough : '刪除線',
    removeformat : '刪除格式',
    image : '圖片',
    multiimage : '批量圖片上傳',
    graft : '塗鴉',
    flash : 'Flash',
    media : '視音頻',
    table : '表格',
    tablecell : '單元格',
    hr : '插入橫線',
    emoticons : '插入表情',
    link : '超級鏈接',
    unlink : '取消超級鏈接',
    fullscreen : '全屏顯示',
    about : '關於',
    print : '列印(Ctrl+P)',
    filemanager : '文件空間',
    code : '插入程式代碼',
    quote : '插入引用',
    map : 'Google地圖',
    baidumap : '百度地圖',
    lineheight : '行距',
    clearhtml : '清理HTML代碼',
    pagebreak : '插入分頁符',
    quickformat : '一鍵排版',
    insertfile : '插入文件',
    template : '插入模板'

 

——現在的努力,只為小時候吹過的牛逼! ——
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文主要討論了操作系統中文件系統的實現和分配方式。首先介紹了虛擬文件系統(VFS)作為中間層,統一了不同文件系統的介面。然後介紹了文件的物理結構,包括文件塊和邏輯塊之間的映射關係。接著詳細討論了連續分配方式的特點和優缺點,包括順序訪問和隨機訪問的效率,以及磁碟空間碎片和文件長度擴展不方便的問題。最後... ...
  • ![](https://img2023.cnblogs.com/blog/3076680/202309/3076680-20230904205926819-1818911722.png) # 1. 時區 ## 1.1. 大航海時代伊始就在和時差打交道,而電腦時代的到來加劇了這一問題 ## 1.2. ...
  • 1. 樂觀鎖和悲觀鎖的理解及使用 樂觀鎖和悲觀鎖是在併發編程中使用的兩種併發控制機制,用於解決多線程或多進程環境下的數據一致性問題。 1. 悲觀鎖(Pessimistic Locking): 悲觀鎖的思想是假設併發訪問會導致衝突,因此在訪問共用資源之前,悲觀鎖會將資源鎖定,確保其他線程無法修改資源。 ...
  • 1、伺服器mysql資料庫本地連接開發3306有安全風險,開發和運營過程中往往需要本地操作資料庫,遠程上去操作資料庫非常的不方便 2、在本地建隧道連接遠程資料庫,關閉伺服器連接,資料庫連接自動中斷,安全又方便 3、下麵是具體的操作流程,需要的小伙伴可以參考使用 圖1:選擇目標主機-》右鍵點擊屬性-》 ...
  • 在vue3中,可以使用vue3的API `defineExpose()`函數結合`ref`或者`$parent`,實現父子組件數據的傳遞。 # 子組件向父組件傳遞數據`defineExpose()`和`ref` - 子組件:通過`defineExpose()` 函數,向外暴露響應式數據或者方法 `` ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 CSS 滾動驅動動畫 scroll() animation-timeline 通過 scroll() 指定可滾動元素與滾動軸來為容器動畫提供一個匿名的 scroll progress timeline. 通過元素在頂部和底部(或左邊和右邊 ...
  • Node.js 使用 `officecrypto-tool` 讀取加密的 Excel (xls, xlsx) 和 Word( docx)文檔, 還支持 xlsx 和 docx 文件的加密(具體使用看文檔)。暫時不支持doc文件的解密 傳送門:[officecrypto-tool](https://w ...
  • 目的:使用Layui的數據表格,拖動行進行排序。 使用插件:layui-soul-table 和 Layui 1.layui-soul-table文檔:https://soultable.yelog.org/#/zh-CN/component/start/install 2.layui文檔:Layu ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...