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

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

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

【 html+css 绚丽Loading 】000046 三才归元阵

前言:哈喽,大家好,今天给大家分享html+css 绚丽Loading!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 📚一、效果📚二、信息💡1.简介:💡2.外观描述:💡3.使用方式:💡4.战斗方式:💡5.提升:💡6.传说: 📚三、源代码,上代码,可以直接复制使用🎥效果🗂️目录✍️

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

计算机毕业设计 大学志愿填报系统 Java+SpringBoot+Vue 前后端分离 文档报告 代码讲解 安装调试

🍊作者:计算机编程-吉哥 🍊简介:专业从事JavaWeb程序开发,微信小程序开发,定制化项目、 源码、代码讲解、文档撰写、ppt制作。做自己喜欢的事,生活就是快乐的。 🍊心愿:点赞 👍 收藏 ⭐评论 📝 🍅 文末获取源码联系 👇🏻 精彩专栏推荐订阅 👇🏻 不然下次找不到哟~Java毕业设计项目~热门选题推荐《1000套》 目录 1.技术选型 2.开发工具 3.功能

Vue3项目开发——新闻发布管理系统(六)

文章目录 八、首页设计开发1、页面设计2、登录访问拦截实现3、用户基本信息显示①封装用户基本信息获取接口②用户基本信息存储③用户基本信息调用④用户基本信息动态渲染 4、退出功能实现①注册点击事件②添加退出功能③数据清理 5、代码下载 八、首页设计开发 登录成功后,系统就进入了首页。接下来,也就进行首页的开发了。 1、页面设计 系统页面主要分为三部分,左侧为系统的菜单栏,右侧

【VUE】跨域问题的概念,以及解决方法。

目录 1.跨域概念 2.解决方法 2.1 配置网络请求代理 2.2 使用@CrossOrigin 注解 2.3 通过配置文件实现跨域 2.4 添加 CorsWebFilter 来解决跨域问题 1.跨域概念 跨域问题是由于浏览器实施了同源策略,该策略要求请求的域名、协议和端口必须与提供资源的服务相同。如果不相同,则需要服务器显式地允许这种跨域请求。一般在springbo

HTML提交表单给python

python 代码 from flask import Flask, request, render_template, redirect, url_forapp = Flask(__name__)@app.route('/')def form():# 渲染表单页面return render_template('./index.html')@app.route('/submit_form',

Java 后端接口入参 - 联合前端VUE 使用AES完成入参出参加密解密

加密效果: 解密后的数据就是正常数据: 后端:使用的是spring-cloud框架,在gateway模块进行操作 <dependency><groupId>com.google.guava</groupId><artifactId>guava</artifactId><version>30.0-jre</version></dependency> 编写一个AES加密

vue2 组件通信

props + emits props:用于接收父组件传递给子组件的数据。可以定义期望从父组件接收的数据结构和类型。‘子组件不可更改该数据’emits:用于定义组件可以向父组件发出的事件。这允许父组件监听子组件的事件并作出响应。(比如数据更新) props检查属性 属性名类型描述默认值typeFunction指定 prop 应该是什么类型,如 String, Number, Boolean,