<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

        CKEditor與dotnetcore實(shí)現(xiàn)圖片上傳功能

        來源:懂視網(wǎng) 責(zé)編:小OO 時(shí)間:2020-11-27 22:35:25
        文檔

        CKEditor與dotnetcore實(shí)現(xiàn)圖片上傳功能

        本文實(shí)例為大家分享了CKEditor與dotnetcore實(shí)現(xiàn)圖片上傳的具體代碼,供大家參考,具體內(nèi)容如下:CKEditor的使用。1.引入js庫;<;script src="https://cdn.ckeditor.com/4.6.1/standard-all/ckeditor.js">;<;/script>。2.定義一個(gè)textarea標(biāo)簽。<;textarea id="editor">;<;/textarea>。3.用CkEditor替換textarea即可使用基本功能。CKEDITOR.replace('editor')。4.配置CkEditor。添加圖片上傳,代碼插入工具。
        推薦度:
        導(dǎo)讀本文實(shí)例為大家分享了CKEditor與dotnetcore實(shí)現(xiàn)圖片上傳的具體代碼,供大家參考,具體內(nèi)容如下:CKEditor的使用。1.引入js庫;<;script src="https://cdn.ckeditor.com/4.6.1/standard-all/ckeditor.js">;<;/script>。2.定義一個(gè)textarea標(biāo)簽。<;textarea id="editor">;<;/textarea>。3.用CkEditor替換textarea即可使用基本功能。CKEDITOR.replace('editor')。4.配置CkEditor。添加圖片上傳,代碼插入工具。

        本文實(shí)例為大家分享了CKEditor與dotnetcore實(shí)現(xiàn)圖片上傳的具體代碼,供大家參考,具體內(nèi)容如下

        CKEditor的使用

        1.引入js庫

        <script src="https://cdn.ckeditor.com/4.6.1/standard-all/ckeditor.js"></script> 
        

        2.定義一個(gè)textarea標(biāo)簽

        <textarea id="editor">
         </textarea> 

        3.用CkEditor替換textarea即可使用基本功能

        CKEDITOR.replace('editor'); 

        4.配置CkEditor

        添加圖片上傳,代碼插入工具

        CKEDITOR.replace('editor-box', {
         //GitHub地址:https://github.com/ckeditor 
         toolbar: [
         { name: 'document', items: ['Source'] },
         { name: 'basicstyles', items: ['Bold', 'Italic'] },
         { name: 'paragraph', items: ['NumberedList', 'BulletedList', '-', 'Outdent', 'Indent', '-', 'Blockquote'] },
         { name: 'links', items: ['Link', 'Unlink'] },
         { name: 'insert', items: ['Image','CodeSnippet'] },
         { name: 'styles', items: ['Format', 'Styles'] }
         ],
         filebrowserImageUploadUrl: '/Blogs/UploadImageUrl', //配置圖片上傳后臺(tái)Url 
         customConfig: '', 
         extraPlugins: 'codesnippet,image2,uploadimage', 
         removePlugins: 'image', 
         //mathJaxLib: 'https://cdn.mathjax.org/mathjax/2.6-latest/MathJax.js?config=TeX-AMS_HTML', 
         codeSnippet_theme: 'ir_black',
         height: 450, 
         contentsCss: ['https://cdn.ckeditor.com/4.6.1/standard-all/contents.css'], 
         format_tags: 'p;h1;h2;h3;pre', 
         removeDialogTabs: 'image:advanced;link:advanced;link:target', 
         stylesSet: [
         /* Inline Styles */
         { name: 'Marker', element: 'span', attributes: { 'class': 'marker' } },
         { name: 'Cited Work', element: 'cite' },
         { name: 'Inline Quotation', element: 'q' },
         /* Object Styles */
         {
         name: 'Special Container',
         element: 'div',
         styles: {
         padding: '5px 10px',
         background: '#eee',
         border: '1px solid #ccc'
         }
         },
         {
         name: 'Compact table',
         element: 'table',
         attributes: {
         cellpadding: '5',
         cellspacing: '0',
         border: '1',
         bordercolor: '#ccc'
         },
         styles: {
         'border-collapse': 'collapse'
         }
         },
         { name: 'Borderless Table', element: 'table', styles: { 'border-style': 'hidden', 'background-color': '#E6E6FA' } },
         { name: 'Square Bulleted List', element: 'ul', styles: { 'list-style-type': 'square' } },
         /* Widget Styles */
         { name: 'Illustration', type: 'widget', widget: 'image', attributes: { 'class': 'image-illustration' } },
         { name: 'Featured snippet', type: 'widget', widget: 'codeSnippet', attributes: { 'class': 'code-featured' } },
         { name: 'Featured formula', type: 'widget', widget: 'mathjax', attributes: { 'class': 'math-featured' } }
         ]
         });
        

        5.后臺(tái)接收?qǐng)D片

        /// <summary>
         /// 圖片上傳
         /// </summary>
         /// <param name="env"></param>
         /// <returns></returns>
         public async Task<IActionResult> UploadImageUrl([FromServices]IHostingEnvironment env)
         {
         // CKEditor提交的很重要的一個(gè)參數(shù) 
         string callback = Request.Query["CKEditorFuncNum"];
         var form = Request.Form;
         var img = form.Files[0]; //獲取圖片
         string fileName = img.FileName;
         var openReadStream = img.OpenReadStream();
         byte[] buff = new byte[openReadStream.Length];
         await openReadStream.ReadAsync(buff, 0, buff.Length);
         string filenameGuid = Guid.NewGuid().ToString();
         var bowerPath = PathUtils.GetSavePath(filenameGuid, true) + ".jpg";//獲取到圖片保存的路徑,這邊根據(jù)自己的實(shí)現(xiàn)
         var savePath = Path.Combine(env.WebRootPath, bowerPath);
         using (FileStream fs = new FileStream(savePath, FileMode.Create))
         {
         await fs.WriteAsync(buff, 0, buff.Length);
         //服務(wù)器返回JavaScript腳本
         string result = $"<script type=\"text/javascript\">window.parent.CKEDITOR.tools.callFunction(\"{callback}\", \"{"/"+bowerPath}\", \"\");</script>";
         Response.ContentType = "text/html;charset=UTF-8";
         return Content(result);
         }
         }
         
        
        

        6.注意

        服務(wù)器返回需要加上這個(gè),否則會(huì)遇到前端頁面不執(zhí)行返回的JavaScript腳本的問題

        Response.ContentType = "text/html;charset=UTF-8";
        

        配置完成即可使用圖片上傳功能

        聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        CKEditor與dotnetcore實(shí)現(xiàn)圖片上傳功能

        本文實(shí)例為大家分享了CKEditor與dotnetcore實(shí)現(xiàn)圖片上傳的具體代碼,供大家參考,具體內(nèi)容如下:CKEditor的使用。1.引入js庫;<;script src="https://cdn.ckeditor.com/4.6.1/standard-all/ckeditor.js">;<;/script>。2.定義一個(gè)textarea標(biāo)簽。<;textarea id="editor">;<;/textarea>。3.用CkEditor替換textarea即可使用基本功能。CKEDITOR.replace('editor')。4.配置CkEditor。添加圖片上傳,代碼插入工具。
        推薦度:
        • 熱門焦點(diǎn)

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 亚洲av成人一区二区三区在线观看| 美女网站在线观看视频免费的| 鲁大师在线影院免费观看| 国产精品亚洲αv天堂无码 | 亚洲伊人久久大香线蕉| 亚洲电影免费在线观看| 亚洲成人在线电影| 30岁的女人韩剧免费观看| 91久久亚洲国产成人精品性色| 久久99国产乱子伦精品免费| 夜夜亚洲天天久久| 97视频热人人精品免费| 亚洲精品无码久久久久牙蜜区| 麻豆国产入口在线观看免费| 久久精品国产亚洲av品善| 亚洲日韩国产成网在线观看| 中文日本免费高清| 色婷婷六月亚洲婷婷丁香| 青青久在线视频免费观看| 国产午夜亚洲精品不卡| 亚洲精品无码永久在线观看你懂的 | 久久久国产亚洲精品| 国产无遮挡裸体免费视频| 一级全免费视频播放| 亚洲人成影院在线| 妞干网在线免费观看| 一区二区视频免费观看| 亚洲一区综合在线播放| 精品久久久久久久免费加勒比| 免费一级毛片在线播放视频免费观看永久| 久久久久亚洲精品无码网址 | 亚洲人成片在线观看| 国产一级淫片a免费播放口之| 中文在线观看免费网站| 久久综合亚洲色HEZYO社区| 日本免费网站在线观看| 无码中文字幕av免费放dvd| 亚洲日本一线产区和二线| 久久久精品国产亚洲成人满18免费网站| 久久99热精品免费观看牛牛| 亚洲第一街区偷拍街拍|