這篇文章將為大家詳細講解有關使用CKEditor與dotnetcore怎么實現一個圖片上傳功能,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
CKEditor的使用
1.引入js庫
<script src="https://cdn.ckeditor.com/4.6.1/standard-all/ckeditor.js"></script>
2.定義一個textarea標簽
<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', //配置圖片上傳后臺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;h2;h3;h4;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.后臺接收圖片
/// <summary> /// 圖片上傳 /// </summary> /// <param name="env"></param> /// <returns></returns> public async Task<IActionResult> UploadImageUrl([FromServices]IHostingEnvironment env) { // CKEditor提交的很重要的一個參數 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";//獲取到圖片保存的路徑,這邊根據自己的實現 var savePath = Path.Combine(env.WebRootPath, bowerPath); using (FileStream fs = new FileStream(savePath, FileMode.Create)) { await fs.WriteAsync(buff, 0, buff.Length); //服務器返回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.注意
服務器返回需要加上這個,否則會遇到前端頁面不執行返回的JavaScript腳本的問題
Response.ContentType = "text/html;charset=UTF-8";
關于使用CKEditor與dotnetcore怎么實現一個圖片上傳功能就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。