为什么接口测试工具不跨域

浏览器实施了同源策略,限制了在不同域之间的资源共享。这是出于安全考虑,以防止恶意网站获取用户的敏感信息。同源策略要求发送请求的源(协议、域名和端口)必须与接收响应的源相同。如果源不同,则浏览器会拒绝该请求,抛出跨域错误。

然而,Postman 不是一个运行在浏览器上的应用程序,它只是模拟了一个 HTTP 客户端发送请求和接收响应,不受浏览器的同源策略限制

跨域本质上是浏览器的问题。你用js发起一个http请求,底层是由浏览器(或者说是js运行时)去执行这个请求的。http请求发出去了,服务器收到也正常响应了,两者看似你情我愿,但是中间的浏览器一看,这响应报文的请求头不对呀,赶紧给他拦截了。

你用postman或其他工具或者用nodejs请求,因为不存在浏览器这个中间层所以也没人把服务器的响应拦截住说你跨域了

总结:

第一:HTTP是无状态协议。每一次请求是独立的。

第二:跨域问题只存在于正经的浏览器,是出于安全考虑。

第三:HTTP请求谁都可以发,不只是浏览器。

相关推荐
小涛不学习2 小时前
HTTP 和 HTTPS 详解(原理 + 区别 + 面试重点)
http·面试·https
一直都在5723 小时前
HTTPS 加密传输原理
网络协议·http·https
爱丽_3 小时前
TCP vs UDP 怎么选(偏实战:别背概念,用场景做决策)
网络协议·tcp/ip·udp
虾..3 小时前
Linux HTTP服务器
linux·服务器·http
五月天的小迷弟3 小时前
edge添加插件的时候出现Download interrupted错误
edge浏览器
taxunjishu4 小时前
TCP/IP转EtherNet/IP 协议转换 罗克韦尔PLC与视觉设备交互
网络·网络协议·tcp/ip
cheems95276 小时前
[网络原理] HTTPS 加密演进与中间人攻击
网络·网络协议·http·https
qq_570398576 小时前
websocket
网络·websocket·网络协议
葡萄城技术团队7 小时前
Hurley:用 Rust 打造的高性能 HTTP 客户端 + 压测工具
开发语言·http·rust
爱丽_7 小时前
HTTPS 与 TLS 握手
网络协议·http·https