You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

141 lines
6.0 KiB

2 years ago
  1. UEditor ASP.NET 后台使用说明
  2. =====
  3. ## 背景
  4. UEditor 在 1.4 版本之后进行了一次[前后端统一配置](../_doc/3.1 后端请求规范.md)的整理,.Net 的后台也进行了一次重写,跟之前的版本差别较大,升级的用户注意阅读本文档。
  5. 本文档介绍 UEditor ASP.NET 后台的部署、配置、源码说明。
  6. ## 1. 部署说明
  7. ### 1.1. 安装并注册 .NET Framework 4.0
  8. 代码的运行时环境是 .NET Framework 4.0,首先要确认 IIS 已经安装了 .NET 4.0 的运行时框架。方法是打开「IIS 管理器」,选择根目录下的「应用程序池」,在右侧查看是否有一个应用程序池的版本是 v4.0,如果存在,则 IIS 已经安装了所需的运行时环境,此时读者可以跳过本节。
  9. ![检查 .NET 4.0 安装情况](../_doc/images/net-publish-1.png)
  10. 如果没有找到对应的应用程序池,需要手动安装。
  11. Windows 7 和 Windows Server 2008 R2 默认安装了 .Net Framework 4.0,如果是 Server 03 和老掉牙的 Windows XP,则需要手动安装 [.NET Framework 4.0](http://www.microsoft.com/zh-cn/download/details.aspx?id=17718)。
  12. 安装完 .NET Framework 4.0 后,还需要向 IIS 注册应用程序池,注册的方法是,使用**管理员权限**打开命令提示符(CMD),输入以下命令:
  13. ```shell
  14. C:\Windows\Microsoft.NET\Framework\v4.0.30319\aspnet_regiis -i
  15. ```
  16. 安装完毕后,在 IIS 管理器刷新就能看到 4.0 的应用程序池。
  17. ### 1.2. 设置 .NET 应用程序
  18. 代码要求以应用程序的形式来运行(可以方便加入库依赖和组织代码)。需要把 `net` 目录转换为应用程序。
  19. 1. 在 IIS 中,展开到 `ueditor/net` 目录,在目录上右击,点击「转换为应用程序」。
  20. ![转换为应用程序](../_doc/images/net-publish-2.png)
  21. 2. 弹出的对话框中,点击「选择...」来指定使用的应用程序池。选择版本为 4.0 的应用程序池,然后点确定。
  22. ![选择应用程序池](../_doc/images/net-publish-3.png)
  23. 3. 设置连接凭据。点击「链接为...」按钮,在弹出的对话框中指定一个对目录具有读写权限的用户(如 administrator),然后点确定。
  24. ![设置连接凭据](../_doc/images/net-publish-4.png)
  25. 设置完毕后,可以点击「测试设置...」来测试权限是否正常。
  26. ![设置连接凭据](../_doc/images/net-publish-5.png)
  27. ### 1.3. 运行测试
  28. 在浏览器中运行 `net/controller.ashx`,如果返回 "`{"state":"action 参数为空或者 action 不被支持。"}`",则表示应用程序运行成功。
  29. 如果你确认上述步骤已经执行,但是依然有问题,请给我们[提 Issue](https://github.com/fex-team/ueditor/issues/new?labels=NET%E5%90%8E%E5%8F%B0),我们会尽快答复解决。
  30. ## 2. 配置说明
  31. 前后端配置统一之后,配置文件由后台读取,返回给前端。但是部分配置是给后台使用的。
  32. ### 2.1. 上传配置说明
  33. 关于上传的部分,后台需要关心以下模板的配置项。
  34. ```json
  35. {
  36. "{tpl}FieldName": "upfile",
  37. "{tpl}PathFormat": "upload/{tpl}/{yyyy}{mm}{dd}/{time}{rand:6}",
  38. "{tpl}UrlPrefix": "/ueditor/net/",
  39. "{tpl}AllowFiles": [".png", ".jpg", ".jpeg", ".gif", ".bmp"],
  40. "{tpl}MaxSize": 2048000
  41. }
  42. ```
  43. "{tpl}FieldName" 表示提交的表单的文件域名称。
  44. "{tpl}PathFormat" 表示上传文件保存的路径和名称。注意,这里的路径是相对应用程序的,如果需要修改的话,请自行修改源码。
  45. "{tpl}UrlPrefix" 表示上传文件访问的 URL 前缀。注意,这里应该给出应用程序的 URL 路径,否则上传的文件不能正确定位。
  46. > 举个例子,如果你的 UEditor 的位置在 `http://www.mydomain.com/myapp/ueditor`,对应的本地路径是 `C:\iis_pub\www\myapp\ueditor`,那么 .NET 应用程序的位置在 `http://www.mydomain.com/myapp/ueditor/net`,对应的本地路径是 `C:\iis_pub\www\myapp\ueditor\net`。图片上传配置项应该如下:
  47. >
  48. > {
  49. > "imagePathFormat": "upload/image/{yyyy}{mm}{dd}/{time}{rand:6}",
  50. > "imageUrlPrefix": "/myapp/ueditor/net/",
  51. > }
  52. >
  53. > 上传的文件会保存在 `C:\iis_pub\www\myapp\ueditor\net\upload\image\{日期}\{文件名}`
  54. "{tpl}AllowFiles" 限制文件上传的类型,注意要有 "."。
  55. "{tpl}MaxSize" 限制文件上传的大小。注意这里的限制是代码上的判断,应用程序本身还有一个请求报文大小限制。该限制在 web.config 文件中修改,注意要有以下的节:
  56. ```xml
  57. <configuration>
  58. <system.web>
  59. <httpRuntime requestValidationMode="2.0" maxRequestLength="102400" />
  60. </system.web>
  61. </configuration>
  62. ```
  63. maxRequestLength 就是请求报文大小限制,该大小应该要比设置的所有上传大小都大,否则应用程序执行之前,请求会被被拒绝。
  64. ## 3. 源码说明
  65. 可以看到 net 目录内的源码结构是这样的:
  66. ```
  67. net
  68. App_Code
  69. Config.cs
  70. Handler.cs
  71. PathFormatter.cs
  72. *Handler.cs
  73. Bin
  74. Newtonsoft.Json.dll
  75. config.json
  76. controller.ashx
  77. net.sln
  78. README.md
  79. Web.config
  80. ```
  81. App_Code 上的文件是应用程序的源码。
  82. - Config.cs 负责读取配置文件
  83. - Handler.cs 是请求处理器的基类,提供了一些基本对象的访问以及输出控制。如果需要增加处理器,应该从该基类继承
  84. - PathFormatter.cs 解析 PathFormat,把信息填充为运行时信息。
  85. - *Handler.cs 是各种处理器,处理各种 UEditor 需要的请求。
  86. Bin 里面的是应用程序的依赖库,当前依赖 Newtonsoft 的 Json 库。Bin 目录和 App_Code 目录受应用程序保护,不用担心被用户访问到。
  87. config.json 是 UEditor 后端的配置文件,上一节已经介绍了比较重要的配置项。
  88. controller.ashx 是 UEditor 请求的入口,它把不同的 action 分发到不同的 Handler 来处理。
  89. net.sln 是项目的解决方案文件,安装 Visual Studio 2013 或以上的机器可以打开进行项目的改造。
  90. README.md 是本说明文件。
  91. Web.config 是应用程序的配置文件。