侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

CKEditor与dotnetcore实现图片上传功能

技术  /  管理员 发布于 7年前   473

本文实例为大家分享了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;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提交的很重要的一个参数    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";

配置完成即可使用图片上传功能

 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


  • 上一条:
    WPF气泡提示框的简单制作
    下一条:
    基于localStorge开发登录模块的记住密码与自动登录实例
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 2024.07.09日OpenAI将终止对中国等国家和地区API服务(0个评论)
    • 2024/6/9最新免费公益节点SSR/V2ray/Shadowrocket/Clash节点分享|科学上网|免费梯子(0个评论)
    • 国外服务器实现api.openai.com反代nginx配置(0个评论)
    • 2024/4/28最新免费公益节点SSR/V2ray/Shadowrocket/Clash节点分享|科学上网|免费梯子(0个评论)
    • 近期文章
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • Laravel 11.15版本发布 - Eloquent Builder中添加的泛型(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-07
    • 2017-08
    • 2017-09
    • 2018-01
    • 2018-07
    • 2018-08
    • 2018-09
    • 2018-12
    • 2019-01
    • 2019-02
    • 2019-03
    • 2019-04
    • 2019-05
    • 2019-06
    • 2019-07
    • 2019-08
    • 2019-09
    • 2019-10
    • 2019-11
    • 2019-12
    • 2020-01
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2020-07
    • 2020-08
    • 2020-09
    • 2020-10
    • 2020-11
    • 2021-04
    • 2021-05
    • 2021-06
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-12
    • 2022-01
    • 2022-02
    • 2022-03
    • 2022-04
    • 2022-05
    • 2022-06
    • 2022-07
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-08
    • 2023-09
    • 2023-10
    • 2023-12
    • 2024-02
    • 2024-04
    • 2024-05
    • 2024-06
    • 2025-02
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客