【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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...