最近须要一个在线编辑器,以前听人说过百度的UEditor不错,去官网下了一个。不过服务端只有ASP.NET版的,若是是为了能尽快使用,只要把ASP.NET版的服务端做为应用部署在IIS上就能够当即使用了。不过个人需求并不急,因此把ASP.NET移植到了ASP.NET Core上。整个过程很简单,只是从新引用了一些包,修改了几处代码,另外就是把Controller中比较长的一个switch语句块重构为了字典,根据url中的action参数从字典中找出并调用相应的Action处理,这样的好处就是若是要扩展action支持的操做无需修改源代码,只要扩展字典就能够,对扩展开放,对修改关闭。最后把服务端功能打成了nuget包UEditorNetCore,方便使用。这篇博客主要就介绍下如何使用UEditorNetCore快速实现UEditor服务端,也能够直接使用源代码中的示例,但愿对有这方面需求的园友有所帮助。javascript
当接收到action后,UEditorService会从UEditorActionCollection中找到这个action对应的方法并调用,同时传入HttpContext参数。这些方法调用基层的服务XxxxHandler完成功能,并把返回内容经过HttpContext.Response.WriteAsync()方法写入。若是要扩展对action的支持,能够扩展UEditorActionCollection,具体方法后面有介绍。html
Install-Package UEditorNetCore
public void ConfigureServices(IServiceCollection services) { //第一个参数为配置文件路径,默认为项目目录下config.json //第二个参数为是否缓存配置文件,默认false services.AddUEditorService() services.AddMvc(); }
[Route("api/[controller]")] //配置路由 public class UEditorController : Controller { private UEditorService ue; public UEditorController(UEditorService ue) { this.ue = ue; } public void Do() { ue.DoAction(HttpContext); } }
serverUrl须要参照第3步Controller中配置的路由,按照上面步骤3中的配置,须要如下配置:前端
serverUrl:"/api/UEditor"
这样配置后当前端要获取服务端UEditor配置时就会访问/api/UEditor?action=config。java
上传类的操做须要配置相应的PathFormat和Prefix。示例部署在web根目录,所以Prefix都设置为"/"。使用时要根据具体状况配置。 例如示例中图片上传的配置以下:git
"imageUrlPrefix": "/", /* 图片访问路径前缀 */ "imagePathFormat": "upload/image/{yyyy}{mm}{dd}/{time}{rand:6}",
关于PathFormat的详细配置可参照官方文档。github
<script type="text/javascript" charset="utf-8" src="~/lib/ueditor/ueditor.config.js"></script> <script type="text/javascript" charset="utf-8" src="~/lib/ueditor/ueditor.all.min.js"> </script> <script type="text/javascript" charset="utf-8" src="~/lib/ueditor/lang/zh-cn/zh-cn.js"></script>
UEditor前端和后端交互主要经过在url中给出不一样的action参数实现的,例如/api/UEditor?action=config会从服务端获取UEditor配置信息。UEditorNetCore目前支持的有8种action:web
config 获取服务端配置信息
uploadimage 上传图片
uploadscrawl 上传涂鸦
uploadvideo 上传视频
uploadfile 上传文件
listimage 多图片上传
listfile 多文件上传
catchimage 抓取图片json
若是以上action没法知足需求,能够方便的增长、覆盖、移除action。后端
public void ConfigureServices(IServiceCollection services) { services.AddUEditorService() .Add("test", context => { context.Response.WriteAsync("from test action"); }) .Add("test2", context => { context.Response.WriteAsync("from test2 action"); }); services.AddMvc(); }
以上代码增长了名字为test和test2两个action,做为示例仅仅返回了字符串。当访问/api/UEditor?action=test时会返回"from test action"。在扩展action时可使用Config获取服务端配置,也可使用已有的Handlers,具体能够参考源代码。api
上面的Add方法除了添加新action外还能够覆盖现有action。当现有的action可能不符合你的要求,能够Add一个同名的action覆盖现有的。
若是要移除某个action,可使用Remove方法。
public void ConfigureServices(IServiceCollection services) { services.AddUEditorService() .Remove("uploadvideo"); services.AddMvc(); }
以上代码中的Remove("uploadvideo")方法移除了名为uploadvideo的action。
UEditorNetCore代码和示例:https://github.com/durow/UEditorNetCore
UEditor代码:https://github.com/fex-team/ueditor
UEditor官网:http://ueditor.baidu.com/website/index.html