欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2017年09月27日 10:08:50   作者:不懂代碼的攻城師  
這篇文章主要為大家詳細(xì)介紹了CKEditor與dotnetcore實(shí)現(xiàn)圖片上傳功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(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', //配置圖片上傳后臺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.后臺接收圖片

/// <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è),否則會遇到前端頁面不執(zhí)行返回的JavaScript腳本的問題

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

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

 以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • ASP.NET仿新浪微博下拉加載更多數(shù)據(jù)瀑布流效果

    ASP.NET仿新浪微博下拉加載更多數(shù)據(jù)瀑布流效果

    本篇文章介紹了如何實(shí)現(xiàn)下拉加載更多數(shù)據(jù)瀑布流的效果,這種效果最近很流行,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2015-07-07
  • 解決Visual Studio 2012 Update 4 RC啟動調(diào)試失敗的方案

    解決Visual Studio 2012 Update 4 RC啟動調(diào)試失敗的方案

    這篇文章主要為大家詳細(xì)介紹了Visual Studio 2012 Update 4 RC啟動調(diào)試失敗的解決方案,感興趣的小伙伴們可以參考一下
    2016-05-05
  • Asp.net MVC中Razor常見的問題與解決方法總結(jié)

    Asp.net MVC中Razor常見的問題與解決方法總結(jié)

    這篇文章主要給大家介紹了關(guān)于Asp.net MVC中Razor常見的問題與解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-08-08
  • ASP.NET Core中的Http緩存使用

    ASP.NET Core中的Http緩存使用

    這篇文章主要介紹了ASP.NET Core中的Http緩存使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • .NET Core自定義配置文件

    .NET Core自定義配置文件

    這篇文章介紹了.NET Core自定義配置文件的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-07-07
  • asp.net 判斷數(shù)組是否存在某個(gè)值的方法

    asp.net 判斷數(shù)組是否存在某個(gè)值的方法

    asp.net 判斷數(shù)組是否存在某個(gè)值的兩種方法, 需要的朋友可以參考下。
    2010-07-07
  • Asp.Net 音頻文件上傳和播放代碼

    Asp.Net 音頻文件上傳和播放代碼

    在網(wǎng)上找到一個(gè)名叫AspNetPager的第三方控件,將AspNetPager.dll文件引用到項(xiàng)目的Bin中。在網(wǎng)頁中可直接調(diào)用。
    2010-05-05
  • 獲取DataList控件的主鍵和索引實(shí)用圖解

    獲取DataList控件的主鍵和索引實(shí)用圖解

    一是在DataList控件添加一個(gè)DataKeyField,以便獲取到它的主鍵值,另外還添加了兩個(gè)銨鈕及一個(gè)Label標(biāo)答,用來顯示選擇結(jié)果,真正將來你也許用不上標(biāo)簽,因?yàn)楂@取到結(jié)果之后,就可以進(jìn)行你想的要事情了
    2013-01-01
  • .Net Core3.0 配置Configuration的實(shí)現(xiàn)

    .Net Core3.0 配置Configuration的實(shí)現(xiàn)

    這篇文章主要介紹了.Net Core3.0 配置Configuration的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-10-10
  • 一個(gè)簡單的自定義程序日志小樣例

    一個(gè)簡單的自定義程序日志小樣例

    前面一篇文章大概說了下自己對日志的一點(diǎn)理解,可能不太直觀,這里再附上一個(gè)簡單的使用例子,以作為對之前的補(bǔ)充,例子比較簡單,所以直接看注釋即可。
    2009-07-07

最新評論