i漂泊

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 4198|回复: 0

[已解决] 浏览器拦截跨域请求处理方法,同时解决QQ登录无法自动登录

[复制链接]
TA的礼物信息
  • 收到:0
  • 送出:2
发表于 2018-2-2 16:24:31 | 显示全部楼层 |阅读模式
如题目所示,当浏览器进行跨域请求时,会出现跨域问题。

该问题在 Firefox 中会报错:
  1. 已拦截跨源请求:同源策略禁止读取位于 http://XXXX/x 的远程资源。(原因:CORS 头缺少 'Access-Control-Allow-Origin')。
复制代码
而在 Chrome 中会显示如下错误:
  1. XMLHttpRequest cannot load http://XXXX/x. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://XXX' is therefore not allowed access.
复制代码

而这个问题是由于浏览器 同源策略 导致的。
让我们先了解同源策略的概念:(来自百度)
 同源策略(Same origin policy)是一种约定,它是浏览器最核心也最基本的安全功能,如果缺少了同源策略,则浏览器的正常功能可能都会受到影响。可以说Web是构建在同源策略基础之上的,浏览器只是针对同源策略的一种实现。
所谓的同源是指:域名、协议、端口相同。
ok,很明显,出现这个问题是由于域名、协议或端口不相同导致的。
从网上找了很多资料,大部分的方法都指向下面这种解决方式:
  1. response.writeHead(200, {'Access-Control-Allow-Origin':'*'});
复制代码
这种方式也实际帮我解决了问题,但是有一个问题就是,如果项目真实上线了,我们必须对该问题进行限制,因此如果只是简单的进行该设置,会让我们的程序暴露在危险中的,以下的改进方式: 将*替换成指定的域名。  
 如果还是无法解决,网上还有另一种解决方式:
在被请求服务器根目录下创建:  crossdomain.xml   文件。内容格式如下:
  1. <?xml version="1.0"?>
  2. <cross-domain-policy>
  3.   <allow-access-from domain="*" />
  4. </cross-domain-policy>
复制代码
该方法笔者没有进行验证,仅供参考。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|小黑屋|手机版|IPiaoBo Inc. ( 渝ICP备17002826号 )

GMT+8, 2024-5-2 09:38 , Processed in 0.070272 second(s), 43 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表