百度ueditor编辑器跨域问题的另一个解决方法

知识技术 2022-04-18 15:49 1288
转载请务必注明: 来源:《建站管家》https://www.df81.com/news/284.html

项目开发中用了百度ueditor编辑器,在用到ueditor的表情时,遇到了跨域问题,因为我们项目中所有的js、css、图片等静态资源都是放在cdn里,跟项目工程不在同个服务器,所以导致了跨域问题。

举个例子示意下:

项目域名:http://home.index.html,对应index.css、 index.js
表情相关资源域名:http://cdn.emotion.html,对应emotion.css、emotion.js
http://cdn.emotion.html是以iframe的形式嵌在http://home.index.html下,在读取emotion.html下的资源的时候就报跨域的错误了


去网上查了下iframe跨域解决方案,千篇一律说:

在index.html里加  document.domain = "home.com";//根域在emotion.html里加  document.domain = "home.com";//根域


但是用这种方式解决跨域问题是有条件限制的,你只能赋成当前的域名或者基础域名,亲测确实不行,还会报错,所以就放弃了这个方案

我的解决方案是找到ueditor的配置文件ueditor.config.js里的iframeUrlMap,重新配置表情对应iframe的src:

iframeUrlMap:{
  'emotion:'http://home.emotion.html'}


然后把ueditor->dialogs->emotion下的emotion.html到项目工程下,更改里面js、css等资源的请求路径,重新部署后,ifarme里的src就会由原先的“http://cdn.emotion.html”变成“http://home.emotion.html”,这样就不涉及跨域问题了。

同理,对于ueditor的超链接iframe导致的跨域问题,也可以通过这个方法解决:

iframeUrlMap:{
  'emotion:'http://home.emotion.html',
  'link':'http://home.link.html'}

再将ueditor下的link.html移植到工程下,一起发布到服务器,就不会产生跨域问题。


点赞 (0)

收藏 (0)

本站部分信息来源网络,如有侵权,请联系QQ:1062129401删除。

上一篇: 《建站管家》二次开发文档

下一篇: php设置允许跨域请求的代码

请先登录后,再发表评论 ~ ~
发表评论
发表评论
发表帖子
广告位招租( ¥5 / 天 )
点击咨询
相关帖子

如果要判断文件是否存在,用函数 is_file(),如果要判断目录是否存在,用函数 is_dir()
用宝塔安装TP程序后,网站前台可以访问,后台无法访问,不是程序问题,而是web服务器环境配置问题(PHP配置),出现这种问题,一般是windows主机安装宝塔造成的,linux安装宝塔不会出现此错误
广告位招租( ¥3 / 天 )
点击咨询
广告位招租( ¥2 / 天 )
点击咨询
广告位招租( ¥1 / 天 )
点击咨询
最新帖子

小朋友,你爸爸是谁啊?这很单纯的,就像我们碰到别人会问:你吃过饭了吗?类似;许多人初次相识,经常会问:你是做什么的啊?你做什么,好像决定你收入的高低,你,资产的范围
1、升级框架到ThinkPHP8.0.3【要求PHP8.1+环境,推荐PHP8.1】 2、启用/禁用调试模式等小细节改进
后台点击生成站点地图 一直转圈圈没有反应,
在线客服