科班出身不懂跨域,再次成功被前端鄙视!

2024-03-25 23:32

本文主要是介绍科班出身不懂跨域,再次成功被前端鄙视!,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

针对跨域这个词,相信不少测试同学应该还是比较陌生,特别是非科班出家的测试从业者

笔者为何今天分享该知识点,是因为上周自己的团队内部就因为小程序分享页的功能涉及到跨域的问题导致请求直接404;并且该问题在测试环验证时未覆盖全面,造成了对线上用户的影响

造成事故的原因不单单是在验证前期,涉及到的端以及载体范围未验证到位,以及在提测阶段针对跨域这个事件做了一步域名迁移动作

测试同学对这个不是很了解。但是也没有进一步的与开发同学去确认相关影响面与测试重点。

开发对测试讲到跨域这个词,测试又是懵的一皮,成功又被鄙视了!

这里就针对跨域这个名词做一次小小的分享,本次分享的内容部分整理于网络,如有侵权请联系笔者删除。

熟悉了解可以读1-2节点,深入了解可读3-5章节

1.跨域是什么意思?

首先一个url是由:协议、域名、端口 三部分组成。(一般端口默认80)

如:https://blog.moonlet.cn:80

当一个请求url的协议、域名、端口三者之间的任意一个与当前页面url不同即为跨域

当前页面ur

被请求页面url

是否跨域

原因

https://blog.moonlet.cn

https://blog.moonlet.cn/archives/550

同源(协议、域名、端口号相同)

http://blog.moonlet.cn

https://blog.moonlet.cn/archives/550

跨域 

协议不同(http/https)

https://blog.moonlet.cn

https://www.baidu.com

跨域

主域名不同

https://blog.moonlet.cn

https://www.moonlet.cn

跨域

子域名不同(www/blog)

https://blog.moonlet.cn:80

https://blog.moonlet.cn:8080

跨域

端口号不同(80/8080)

2.跨域产生原因?

出于浏览器的同源策略限制。

同源策略(Same Orgin Policy)是一种约定,它是浏览器核心也最基本的安全功能,它会阻止一个域的js脚本和另外一个域的内容进行交互,如果缺少了同源策略,浏览器很容易受到XSS、CSFR等攻击

所谓同源(即在同一个域)就是两个页面具有相同的协议(protocol)、主机(host)和端口号(port)

  • 非同源会出现的限制

  • 无法读取非同源网页的cookie、localstorage等

  • 无法接触非同源网页的DOM和js对象

  • 无法向非同源地址发送Ajax请求

3.nginx反向代理解决跨域(前端常用)

#正向代理:

a-->b访问不了,可以找个中间的服务器c, 先访问c再从c到b,类似曲线救国。

明确访问的目的地,但是用户不知道中间的代理服务器。(忽略中间服务器)

#反向代理:a--> c <--b

a明确访问c代理服务器,但是不知道c的内容从哪里来,c反向从别的地方拿来数据。(忽略的是目标地址)

浏览器可以访问a,而服务器之间不存在跨域问题,浏览器先访问a的服务器c,让c服务器作为代理去访问b服务器,拿到之后再返回数据给a。

例如:nginx是静态服务器,跨域请求放在api下面好管理http://www.baidu.com:80/api/user

可以在nginx下面的config下面的nginx.conf里面配置

从80端口进来的就拦截一下,代理到81端口

server{
location /api {
//拦截一下
proxy_pass  http://www.baidu.com:81;
}
}

4.添加响应头解决跨域

浏览器先询问b,b允许a访问

access-control-allow-origin

access-control-max-age

PHP端修改header:
header('Access-Control-Allow-Origin:*');//允许所有来源访问
header('Access-Control-Allow-Method:POST,GET');//允许访问的方式

5.通过jsonp解决跨域(老方法)

实现原理:通常为了减轻web服务器的负载,我们把js、css、图片等静态资源分离到另一台独立域名的服务器上

在html页面中再通过相应的标签从不同域名下加载静态资源,而被浏览器允许。html中有的标签天然支持跨域,比如但是只支持get请求。

近期精彩好文传送门:从业2年,我被一个女前端鄙视了!软件测试 | 服务端接口测试新分享

后期都是针对测试岗位子在实际工作中碰到的问题,进行总结分享,请还未关注小编的同志,点击上方个人号名片,进行关注,谢谢大家的支持,点歌赞与在看,分享一波支持一下!

更多精彩文章点击阅读原文

这篇关于科班出身不懂跨域,再次成功被前端鄙视!的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/846614

相关文章

vue基于ElementUI动态设置表格高度的3种方法

《vue基于ElementUI动态设置表格高度的3种方法》ElementUI+vue动态设置表格高度的几种方法,抛砖引玉,还有其它方法动态设置表格高度,大家可以开动脑筋... 方法一、css + js的形式这个方法需要在表格外层设置一个div,原理是将表格的高度设置成外层div的高度,所以外层的div需要

mysql外键创建不成功/失效如何处理

《mysql外键创建不成功/失效如何处理》文章介绍了在MySQL5.5.40版本中,创建带有外键约束的`stu`和`grade`表时遇到的问题,发现`grade`表的`id`字段没有随着`studen... 当前mysql版本:SELECT VERSION();结果为:5.5.40。在复习mysql外键约

Vue项目中Element UI组件未注册的问题原因及解决方法

《Vue项目中ElementUI组件未注册的问题原因及解决方法》在Vue项目中使用ElementUI组件库时,开发者可能会遇到一些常见问题,例如组件未正确注册导致的警告或错误,本文将详细探讨这些问题... 目录引言一、问题背景1.1 错误信息分析1.2 问题原因二、解决方法2.1 全局引入 Element

详解如何在React中执行条件渲染

《详解如何在React中执行条件渲染》在现代Web开发中,React作为一种流行的JavaScript库,为开发者提供了一种高效构建用户界面的方式,条件渲染是React中的一个关键概念,本文将深入探讨... 目录引言什么是条件渲染?基础示例使用逻辑与运算符(&&)使用条件语句列表中的条件渲染总结引言在现代

详解Vue如何使用xlsx库导出Excel文件

《详解Vue如何使用xlsx库导出Excel文件》第三方库xlsx提供了强大的功能来处理Excel文件,它可以简化导出Excel文件这个过程,本文将为大家详细介绍一下它的具体使用,需要的小伙伴可以了解... 目录1. 安装依赖2. 创建vue组件3. 解释代码在Vue.js项目中导出Excel文件,使用第三

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

vue解决子组件样式覆盖问题scoped deep

《vue解决子组件样式覆盖问题scopeddeep》文章主要介绍了在Vue项目中处理全局样式和局部样式的方法,包括使用scoped属性和深度选择器(/deep/)来覆盖子组件的样式,作者建议所有组件... 目录前言scoped分析deep分析使用总结所有组件必须加scoped父组件覆盖子组件使用deep前言

VUE动态绑定class类的三种常用方式及适用场景详解

《VUE动态绑定class类的三种常用方式及适用场景详解》文章介绍了在实际开发中动态绑定class的三种常见情况及其解决方案,包括根据不同的返回值渲染不同的class样式、给模块添加基础样式以及根据设... 目录前言1.动态选择class样式(对象添加:情景一)2.动态添加一个class样式(字符串添加:情

React实现原生APP切换效果

《React实现原生APP切换效果》最近需要使用Hybrid的方式开发一个APP,交互和原生APP相似并且需要IM通信,本文给大家介绍了使用React实现原生APP切换效果,文中通过代码示例讲解的非常... 目录背景需求概览技术栈实现步骤根据 react-router-dom 文档配置好路由添加过渡动画使用

使用Vue.js报错:ReferenceError: “Vue is not defined“ 的原因与解决方案

《使用Vue.js报错:ReferenceError:“Vueisnotdefined“的原因与解决方案》在前端开发中,ReferenceError:Vueisnotdefined是一个常见... 目录一、错误描述二、错误成因分析三、解决方案1. 检查 vue.js 的引入方式2. 验证 npm 安装3.