【WEB】深入理解 CORS(跨域资源共享):原理、配置与常见问题

目录

  • 引言
  • 一、同源策略(Same-Origin Policy)概述
      • 1.1 同源策略的定义
      • 1.2 同源策略的作用
  • 二、CORS 的引入与工作原理
    • 2.1 CORS(跨域资源共享)的基本概念
    • 2.2 简单请求与预检请求
      • 2.2.1 简单请求(Simple Requests)
      • 2.2.2 预检请求(Preflight Request)
    • 2.3 预检请求流程
  • 三、CORS 相关 HTTP 头部
    • 3.1 `Access-Control-Allow-Origin`
    • 3.2 `Access-Control-Allow-Methods`
    • 3.3 `Access-Control-Allow-Headers`
    • 3.4 `Access-Control-Allow-Credentials`
    • 3.5 `Access-Control-Expose-Headers`
    • 3.6 `Access-Control-Max-Age`
  • 四、跨域请求的类型
    • 4.1 简单请求
    • 4.2 预检请求
  • 五、处理跨域问题的常见方式
    • 5.1 前端(JavaScript)处理 CORS
      • 5.1.1 使用 `fetch` 发起跨域请求
      • 5.1.2 使用 `XMLHttpRequest` 发起跨域请求
    • 5.2 Node.js 中处理 CORS
      • 5.2.1 使用 `cors` 中间件
      • 5.2.2 使用自定义 CORS 头部
    • 5.3 Python 中处理 CORS
      • 5.3.1 安装 `Flask-CORS`
      • 5.3.2 配置 CORS
    • 5.4 Go 语言中处理 CORS
      • 5.4.1 使用 `gorilla/handlers`
  • 六、CORS 处理流程图
  • 七、CORS 常见问题
    • 7.1 `Access-Control-Allow-Origin` 设置问题
    • 7.2. 预检请求失败
    • 7.3 带凭证的请求问题
    • 7.4 跨域请求的缓存问题
    • 7.5 使用代理解决跨域
  • 总结

引言

在现代 Web 开发中,跨域请求已经成为不可避免的一部分。浏览器的同源策略(Same-Origin Policy)虽然提供了基本的安全保障,但也限制了不同域之间的数据交互。为了弥补这一限制,CORS(Cross-Origin Resource Sharing,跨域资源共享)应运而生。CORS 是浏览器的一项安全机制,允许从一个域名(如前端页面的域)发起跨域请求,从而访问其他域名(如后端 API)的资源。通过这一机制,Web 应用可以灵活地访问跨域的资源,同时确保用户数据的安全。

本文将详细介绍 CORS 的工作原理、涉及的 HTTP 头部、跨域请求的不同类型以及如何在前后端开发中正确配置 CORS,帮助开发者更好地理解和解决常见的跨域问题。

一、同源策略(Same-Origin Policy)概述

1.1 同源策略的定义

浏览器的同源策略(Same-Origin Policy)是一种重要的安全机制,用于阻止不同源(域)之间的恶意操作。根据同源策略,网页中的脚本只能访问与其所在网页相同源的资源。源的定义包括三个主要部分:

  • 协议(Scheme):如 http://https://
  • 主机(Host):如 www.example.comapi.example.com
  • 端口(Port):如 808080

如果请求的协议、主机名或端口号不一致,浏览器将视为跨域请求,默认会阻止这样的访问。例如:

  • http://example.comhttps://example.com 属于不同来源(协议不同);
  • http://example.comhttp://api.example.com 属于不同来源(主机名不同);
  • http://example.com:80http://example.com:8080 属于不同来源(端口不同)。

1.2 同源策略的作用

同源策略的核心目的是保护用户的数据隐私和安全,避免恶意网站通过脚本发起未经授权的请求,从而窃取或篡改用户的数据。例如:

  • 一个恶意网站可能试图通过 JavaScript 脚本访问银行网站,获取用户的敏感信息如账户余额或信用卡号码。
  • 如果没有同源策略的保护,网站之间的数据交换将可能面临被恶意操控的风险。

二、CORS 的引入与工作原理

由于同源策略对跨域资源共享的限制,前端开发中常常需要访问不同域的资源,比如从 www.example.comapi.example.com 请求数据。为了能够安全、灵活地进行跨域通信,CORS(跨域资源共享)机制应运而生。

2.1 CORS(跨域资源共享)的基本概念

CORS(Cross-Origin Resource Sharing) 是一种机制,允许受限的资源在一个域(域A)上被另一个域(域B)请求。CORS 通过在 HTTP 请求中添加额外的头部信息来实现跨域通信,从而解决了浏览器的同源策略限制。

同源策略(Same-Origin Policy)
浏览器的同源策略(Same-Origin Policy)是一种用于防止不同来源的网页互相干扰的机制。它要求,网页中的脚本只能访问与它相同源的资源。换句话说,不同域名、协议或端口的资源访问会被浏览器默认阻止。

同源的定义:

  • 相同的协议(http:// 与 https://)
  • 相同的主机名(www.example.com 与 example.com)
  • 相同的端口号(80与8080)

如果协议、主机名或端口号不相同,则被视为跨域请求。

CORS 的核心思想是,服务器通过在 HTTP 响应头中设置特定字段,来允许或拒绝跨域请求。CORS 并不改变浏览器的同源策略,而是通过配置来放宽限制。

2.2 简单请求与预检请求

根据请求类型,CORS 分为两种情况:简单请求预检请求

2.2.1 简单请求(Simple Requests)

简单请求是指那些符合以下条件的跨域请求:

  • 请求方法是 GETPOSTHEAD
  • 请求头部只包含以下字段之一:AcceptContent-Type(只限 application/x-www-form-urlencodedmultipart/form-datatext/plain),Authorization 等常见字段。

对于这种请求,浏览器会直接发送请求到服务器,并且不发送预检请求。

2.2.2 预检请求(Preflight Request)

如果跨域请求方法是 PUTDELETEPATCH,或者请求中包含自定义的 HTTP 头部(如 X-Custom-Header),浏览器首先会发送一个 OPTIONS 请求来询问服务器是否允许跨域请求。该请求被称为“预检请求”。服务器需要在响应中包含允许跨域访问的标识,浏览器才会继续发送实际的请求。

2.3 预检请求流程

在进行跨域请求时,浏览器通常会先发送一个预检请求(OPTIONS 请求)以确定服务器是否允许跨域访问。预检请求的流程如下:

  1. 浏览器发送 OPTIONS 请求:浏览器向服务器发送一个 OPTIONS 请求,询问服务器是否支持跨域请求。
  2. 服务器响应 CORS 头部信息:服务器根据请求的内容,在响应头中添加 CORS 相关的字段,告知浏览器是否允许跨域请求。
  3. 判断是否允许跨域请求:浏览器根据服务器返回的 CORS 头部信息,判断是否允许继续发送实际的跨域请求。
  4. 发送实际请求或报错
    • 如果服务器允许,浏览器会继续发送实际请求。
    • 如果服务器不允许,浏览器会拒绝请求并抛出 CORS 错误。
CSDN @ 2136
浏览器发送 OPTIONS 请求
服务器响应 CORS 头部信息
是否允许跨域请求?
浏览器发送实际请求
浏览器拒绝请求, 提示 CORS 错误
服务器响应实际请求
浏览器处理并显示响应
CSDN @ 2136

说明

  1. 浏览器发送 OPTIONS 请求:浏览器首先发送一个 OPTIONS 请求到服务器,以询问是否允许跨域请求。
  2. 服务器响应 CORS 头部信息:服务器在响应中包含 Access-Control-Allow-Origin 等 CORS 相关头部,告知浏览器是否允许跨域。
  3. 判断是否允许跨域请求
    • 如果服务器允许跨域,浏览器会发送实际请求。
    • 如果服务器不允许,浏览器会拒绝请求,并报出 CORS 错误。
  4. 发送实际请求或拒绝
    • 如果允许,浏览器继续发出实际请求。
    • 如果不允许,浏览器会显示 CORS 错误。
  5. 服务器响应实际请求:如果跨域请求被允许,服务器会正常响应实际请求。
  6. 浏览器处理并显示响应:浏览器接收并处理服务器返回的数据,最后展示给用户。

通过上述流程,浏览器能够确保服务器允许跨域请求,从而安全地进行数据交换。

三、CORS 相关 HTTP 头部

CORS 主要依赖服务器端的 HTTP 头部来进行配置。以下是常见的 CORS 相关头部字段及其作用:

  • Access-Control-Allow-Origin:指定哪些源(域)可以访问资源。可以是单个源,或者是 *(允许所有源)。
  • Access-Control-Allow-Methods:指定允许的 HTTP 方法(如 GET, POST, PUT, DELETE 等)。
  • Access-Control-Allow-Headers:指定允许的请求头字段。
  • Access-Control-Allow-Credentials:指示是否允许发送凭据(如 cookies)到跨域资源。
  • Access-Control-Expose-Headers:允许客户端访问特定的响应头。
  • Access-Control-Max-Age:指示预检请求的有效期,即多少秒内无需再次发送预检请求。

3.1 Access-Control-Allow-Origin

  • 作用:指定哪些源(域)可以访问该资源。可以是单个域名,也可以是 *,表示允许所有来源。
    • 单个域名:Access-Control-Allow-Origin: https://www.example.com
    • 允许所有来源:Access-Control-Allow-Origin: *
    • 如果允许的来源是动态的,服务器可以根据请求的 Origin 动态返回允许的域名。

3.2 Access-Control-Allow-Methods

  • 作用:指定允许的 HTTP 请求方法。
  • 常见值GET, POST, PUT, DELETE, PATCH

3.3 Access-Control-Allow-Headers

  • 作用:指定哪些请求头字段可以包含在实际请求中。例如,某些自定义请求头,如 X-Custom-Header,需要通过这个字段允许。
  • 示例Access-Control-Allow-Headers: Content-Type, X-Custom-Header

3.4 Access-Control-Allow-Credentials

  • 作用:指示是否允许发送凭据(如 cookies)。如果设置为 true,表示跨域请求中可以发送 cookies。
  • truefalse
  • 注意:当设置为 true 时,Access-Control-Allow-Origin 不能为 *,必须指定具体的域名。

3.5 Access-Control-Expose-Headers

  • 作用:允许浏览器访问指定的响应头。默认情况下,浏览器只会暴露某些标准的响应头,使用该字段可以暴露其他自定义的头部。
  • 示例Access-Control-Expose-Headers: X-Response-Time

3.6 Access-Control-Max-Age

  • 作用:指定预检请求的有效期(单位为秒)。在此期间,浏览器不会再次发送预检请求。
  • 示例Access-Control-Max-Age: 3600 表示预检请求的结果有效期为 1 小时。

四、跨域请求的类型

4.1 简单请求

  • GETPOSTHEAD 方法
  • 头部字段限制:只允许常见的头部字段,如 AcceptContent-TypeAuthorization 等。

4.2 预检请求

  • 如果请求方法是 PUTDELETEPATCH,或者包含自定义头部字段,浏览器会先发送一个 OPTIONS 请求(预检请求)询问服务器是否允许跨域操作。

五、处理跨域问题的常见方式

以下分别展示在前端、Node.js、Python 和 Go 中处理跨域请求的代码示例,并对其进行详细说明。

5.1 前端(JavaScript)处理 CORS

在前端代码中,通常通过设置 fetchXMLHttpRequestmodecredentials 等选项来控制跨域行为。

5.1.1 使用 fetch 发起跨域请求

fetch('https://example.com/data', {method: 'GET',headers: {'Content-Type': 'application/json',},// 是否允许携带 cookiescredentials: 'include', // 'same-origin', 'include', 'omit'
})
.then(response => {return response.json();
})
.then(data => {console.log(data);
})
.catch(error => {console.error('Error:', error);
});
  • credentials: 'include':允许携带 cookies。如果目标服务器配置了 CORS 头部 Access-Control-Allow-Credentials: true,浏览器才会发送带有 cookies 的跨域请求。

5.1.2 使用 XMLHttpRequest 发起跨域请求

var xhr = new XMLHttpRequest();
xhr.open('GET', 'https://example.com/data', true);
xhr.withCredentials = true; // 设置是否带上凭证
xhr.setRequestHeader('Content-Type', 'application/json');
xhr.onreadystatechange = function() {if (xhr.readyState == 4 && xhr.status == 200) {console.log(JSON.parse(xhr.responseText));}
};
xhr.send();

5.2 Node.js 中处理 CORS

在 Node.js 中,处理 CORS 最常见的方式是使用 cors 中间件,它能简化 CORS 相关的配置。

5.2.1 使用 cors 中间件

首先,需要安装 cors

npm install cors

然后在代码中引入并使用它:

const express = require('express');
const cors = require('cors');
const app = express();// 使用 cors 中间件
app.use(cors({origin: 'https://your-frontend-domain.com', // 允许的来源methods: ['GET', 'POST', 'PUT', 'DELETE'],allowedHeaders: ['Content-Type', 'Authorization'],credentials: true // 允许携带凭证
}));app.get('/data', (req, res) => {res.json({ message: 'Hello World' });
});app.listen(3000, () => {console.log('Server running on port 3000');
});

5.2.2 使用自定义 CORS 头部

如果不使用 cors 中间件,可以手动添加 CORS 头部:

const express = require('express');
const app = express();app.use((req, res, next) => {res.header('Access-Control-Allow-Origin', 'https://your-frontend-domain.com'); // 允许的源res.header('Access-Control-Allow-Methods', 'GET, POST, PUT, DELETE');res.header('Access-Control-Allow-Headers', 'Content-Type, Authorization');res.header('Access-Control-Allow-Credentials', 'true');next();
});app.get('/data', (req, res) => {res.json({ message: 'Hello World' });
});app.listen(3000, () => {console.log('Server running on port 3000');
});

5.3 Python 中处理 CORS

在 Python 中,可以使用 Flask-CORS 扩展来处理 CORS。

5.3.1 安装 Flask-CORS

pip install flask-cors

5.3.2 配置 CORS

from flask import Flask
from flask_cors import CORSapp = Flask(__name__)
CORS(app, origins="https://your-frontend-domain.com", supports_credentials=True)@app.route("/data")
def data():return {"message": "Hello World"}if __name__ == "__main__":app.run(port=5000)

5.4 Go 语言中处理 CORS

在 Go 中,可以通过 gorilla/handlersnet/http 来处理 CORS。

5.4.1 使用 gorilla/handlers

首先安装 gorilla/handlers

go get github.com/gorilla/handlers

然后配置 CORS:

package mainimport ("fmt""github.com/gorilla/mux""github.com/gorilla/handlers""net/http"
)func main() {r := mux.NewRouter()r.HandleFunc("/data", func(w http.ResponseWriter, r *http.Request) {w.Write([]byte(`{"message": "Hello World"}`))}).Methods("GET")// 配置 CORSheadersOk := handlers.AllowedHeaders([]string{"X-Requested-With", "Content-Type", "Authorization"})originsOk := handlers.AllowedOrigins([]string{"https://your-frontend-domain.com"})methodsOk := handlers.AllowedMethods([]string{"GET", "POST", "PUT", "DELETE"})// 启动服务器http.ListenAndServe(":3000", handlers.CORS(originsOk, headersOk, methodsOk)(r))
}

六、CORS 处理流程图

成功
失败
CSDN @ 2136
前端请求资源
浏览器发送请求
浏览器检测是否跨域
是否跨域?
发送预检请求 OPTIONS
直接发送请求
服务器检查预检请求并返回 CORS 响应头
浏览器继续发送实际请求
浏览器阻止实际请求并报告错误
服务器处理请求并返回数据
浏览器接受响应
渲染页面
浏览器反馈 CORS 错误
CSDN @ 2136

解释

  • 前端请求资源:前端应用(例如一个网页)发出请求,可能会向不同的域、协议或端口请求资源,导致跨域。

  • 浏览器发送请求:浏览器会发起 HTTP 请求,向服务器请求所需资源。

  • 浏览器检测是否跨域:浏览器根据请求的目标 URL 判断请求是否跨域。如果目标 URL 与当前网页 URL 的域、协议或端口不同,则认为是跨域请求。

  • 是否跨域:这是判断跨域请求与否的关键节点。如果请求和当前页面的源不同,则会触发 CORS 机制。

    • 是跨域:浏览器会发送一个预检请求(Preflight Request)。这是一个 HTTP 请求,用于询问目标服务器是否允许跨域访问,通常是一个 OPTIONS 请求。

    • 否跨域:如果请求没有跨域,浏览器会直接发送请求,不经过预检过程。

  • 发送预检请求(OPTIONS):如果是跨域请求,浏览器会先发送一个 OPTIONS 请求,询问服务器是否允许跨域操作。

  • 服务器检查预检请求并返回 CORS 响应头:服务器收到预检请求后,会根据 CORS 配置返回相应的 CORS 头部信息,如 Access-Control-Allow-Origin 和其他相关字段。如果服务器允许该请求,浏览器继续发送实际的请求。

  • 服务器处理请求并返回数据:如果预检请求成功,浏览器会发出实际的跨域请求。服务器处理请求并返回数据。

  • 浏览器接受响应:浏览器接收到响应后,会检查 CORS 头部,确认是否允许访问资源。如果允许,则进行页面渲染;如果不允许,则阻止该请求。

  • 渲染页面:如果响应没有问题,浏览器会将数据渲染到页面上,展示给用户。

  • 浏览器反馈 CORS 错误:如果预检请求失败,或者响应头中缺少必要的 CORS 信息,浏览器会终止请求并提示 CORS 错误。

七、CORS 常见问题

7.1 Access-Control-Allow-Origin 设置问题

No ‘Access-Control-Allow-Origin’ header is present on the requested resource:表示响应中缺少 Access-Control-Allow-Origin 头部。
描述
- Access-Control-Allow-Origin 是 CORS 头部中的关键字段,用来指定允许跨域访问的来源(即允许哪些域名访问资源)。如果响应中没有该字段或该字段的值不匹配请求的来源,浏览器会阻止跨域请求。报错为:
No ‘Access-Control-Allow-Origin’ header is present on the requested resource

解决方案

  • 服务器可以通过返回该头部来明确哪些域名被允许跨域访问。可以指定单一域名(如 https://example.com),或者使用通配符 * 允许所有域名访问,但通配符不能与带凭证的请求(如 cookies 或 Authorization 头部)一起使用,也不能与 credentials: 'include' 一起使用。
  • 如果多个域名都需要访问,服务器可以动态判断请求来源,并根据来源返回不同的 Access-Control-Allow-Origin 值。

示例

Access-Control-Allow-Origin: https://example.com
  • 如果允许所有域访问:
Access-Control-Allow-Origin: *

注意

  • 通配符 * 不能与带凭证的请求(例如 cookiesAuthorization)一起使用。如果请求需要凭证,服务器必须指定明确的来源(域名)。即 Access-Control-Allow-Origin 必须设置为明确的域名,而不能使用 *

7.2. 预检请求失败

描述

  • 对于某些复杂的请求(如 PUTDELETE,或包含自定义头部的请求),浏览器会首先发送一个 OPTIONS 预检请求,以确认服务器是否接受跨域请求。如果服务器没有正确响应或缺少必需的 CORS 头部,实际请求会被浏览器阻止。报错为:
    CORS policy: Response to preflight request doesn’t pass access control check

解决方案

  • 服务器需要正确处理 OPTIONS 请求,并返回适当的 CORS 响应头。常见的响应头包括:
  • Access-Control-Allow-Origin
  • Access-Control-Allow-Methods(指定允许的 HTTP 方法,如 GET, POST, PUT, DELETE 等)
  • Access-Control-Allow-Headers(列出允许的自定义头部)

示例

Access-Control-Allow-Origin: *
Access-Control-Allow-Methods: GET, POST, PUT
Access-Control-Allow-Headers: Content-Type, Authorization

7.3 带凭证的请求问题

描述

  • 当浏览器在请求中包含凭证(如 cookiesAuthorization 头部)时,CORS 请求需要显式的配置来允许凭证一起发送。如果服务器没有设置 Access-Control-Allow-Credentials,浏览器会拒绝携带凭证的请求。可能出现以下错误:
    Credential is not supported if the CORS header ‘Access-Control-Allow-Origin’ is ‘*’

解决方案

  • 当浏览器携带凭证(如 cookies 或 Authorization)发起跨域请求时,服务器需要在响应中设置 Access-Control-Allow-Credentials: true,并且 Access-Control-Allow-Origin 不能使用通配符(*),必须指定明确的域名。

示例

Access-Control-Allow-Origin: https://example.com
Access-Control-Allow-Credentials: true
  • 如果服务器允许携带 cookies 和其他凭证,但未正确配置 Access-Control-Allow-Credentials,浏览器将拒绝请求。

常见错误

  • No 'Access-Control-Allow-Origin' header is present on the requested resource:这通常意味着服务器没有正确设置 Access-Control-Allow-Origin 头部。

7.4 跨域请求的缓存问题

描述

  • 浏览器可能会缓存跨域请求的响应。如果 CORS 响应头设置不当,缓存可能导致不必要的跨域问题。

解决方案

  • 服务器可以通过设置 Cache-Control 头部,控制缓存策略。例如,可以禁用缓存:
Cache-Control: no-store

示例

Cache-Control: no-cache
Access-Control-Allow-Origin: https://example.com
  • 如果需要缓存响应,可以使用 no-cache,但仍需要确保正确设置 CORS 头部。

7.5 使用代理解决跨域

描述

  • 如果由于 CORS 设置问题而无法直接访问资源,可以通过设置一个代理服务器来转发请求,从而绕过跨域限制。代理服务器会代表客户端发起请求,并返回响应数据。

解决方案

  • 前端可以将请求发送到与页面同域的代理服务器,由代理服务器向目标服务器发起请求,再将响应返回给前端。

优点

  • 这种方式可以避免浏览器的 CORS 限制,但增加了额外的服务器端负担。

总结

CORS 是一种重要的浏览器安全机制,解决了不同源之间资源共享的问题。无论是在前端使用 fetch 或 XMLHttpRequest 发起请求,还是在后端使用中间件或手动设置响应头部,正确的 CORS 配置对于确保跨域请求的顺利进行至关重要。通过合理配置 CORS 相关头部,开发者可以有效避免常见的跨域问题,如头部设置不正确、预检请求失败、带凭证的请求问题等。

掌握 CORS 的核心原理与配置方法,不仅能帮助开发者顺利实现跨域资源共享,还能提高 Web 应用的安全性和用户体验。如果你在开发过程中遇到任何 CORS 配置上的挑战,随时可以寻求更多的帮助和解决方案。


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/14916.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

深入浅出《钉钉AI》产品体验报告

1. 引言 随着人工智能技术的迅猛发展,企业协同办公领域迎来了新的变革。钉钉作为阿里巴巴集团旗下的企业级通讯与协同办公平台,推出了钉钉AI助理,旨在提高工作效率,优化用户体验。本报告将对钉钉AI助理进行全面的产品体验分析&am…

揭开基础动销方案的神秘面纱

在如今竞争激烈的市场大环境下,产品实现有效动销可谓是企业生存发展的关键所在。而基础动销方案,正是推动产品销售的重要利器。 基础动销方案到底是什么呢?它指的是企业为促进产品销售,运用一系列营销手段和策略,提升产…

YOLO v5 Series - Image Comparison

图像相似度 Image Similarity 图片差异度 Image Dissimilaritypuzzle-diff pacman -S autoconf automake base-devel libtool pacman -S mingw-w64-x86_64-libgdautogen /opt/admin/libpuzzle>./configure configure: loading site script /etc/config.site che…

sqli—labs靶场 5-8关 (每日4关练习)持续更新!!!

Less-5 上来先进行查看是否有注入点,判断闭合方式,查询数据列数,用union联合注入查看回显位,发现到这一步的时候,和前四道题不太一样了,竟然没有回显位??? 我们看一下源…

InnoDB引擎

6.1 逻辑存储结构 InnoDB的逻辑存储结构如下图所示: 6.2 架构 6.2.1 概述 MySQL5.5 版本开始,默认使用InnoDB存储引擎,它擅长事务处理,具有崩溃恢复特性,在日常开发中使用非常广泛。下面是InnoDB架构图,左侧为内存结…

C#与C++交互开发系列(二十二):跨进程通信之使用基于HTTP协议的REST风格的API

1. 前言 REST API(Representational State Transfer Application Programming Interface)是一种基于HTTP协议的通信方式,广泛用于网络服务和分布式应用程序之间的通信。通过REST API,可以让C#和C应用程序进行跨进程、甚至跨平台的…

想让三维模型与实时视频融合?这款软件值得一试

视频融合,是指将视频数据投影到地理特征表面,并通过相应姿态参数控制投影效果的一种三维展示方式,实现了三维模型与实时视频的融合。 四维轻云是一款轻量化的地理空间数据管理云平台,支持地理空间数据的在线管理、编辑以及分享。…

汉化版WinHex和CFF Explorer下载及程序脱壳后修复,重建引入表,修改程序PE文件(附下载链接)

前言 现有一个加壳程序,要求对程序脱壳,需要修复脱壳后的程序 使用PEiD查壳,显示为NsPack 1.4 -> Liuxingping [Overlay] * 先定位程序的OEP,使用od打开程序,看到有压入栈的操作 进行查找,查找命令序列…

STM32F407简单驱动步进电机(标准库)

配置 单片机型号:STM32F104ZGT6 步进电机:YK28HB40-01A 驱动器:YKD2204M-Plus 接线方式: pu:接对应的产生PWM的引脚,这里接PF9,对应TIM14_CH1通道! pu-:接单片机的G…

linux-DNS解析

dns解析 dns:域名系统,将域名和ip地址互相映射的一个分布式的数据库,方便用户访问互联网。 ip地址:是所有设备和网站在互联网上的唯一地址,通信一定是ip和ip之间的通信。 dns解析:根据域名在互联网当中找…

光伏电站容量计算方法科普

光伏电站的容量计算是设计和评估光伏系统性能的关键步骤。通过了解光伏电站的容量,我们可以预估其发电量,优化系统设计,并确保系统能满足电力需求。本文将详细介绍几种常见的光伏电站容量计算方法,并特别介绍小程序“光伏一点通”…

采集opc da 转 profinet IO项目案例

目录 1 案例说明 1 2 VFBOX网关工作原理 1 3 应用条件 2 4 查看OPC DA服务器的相关参数 2 5 配置网关采集opc da数据 4 6 用profinet IO协议转发数据 6 7 在服务器上运行仰科OPC DA采集软件 9 8 案例总结 11 1 案例说明 在OPC DA服务器上运行OPC DA client软件查看OPC DA服务…

循环矩阵和BCCB矩阵与向量乘积的快速计算——矩阵向量乘积与频域乘积之间的转换

目录 循环矩阵循环矩阵的定义特征值与特征向量循环矩阵的对角化 循环矩阵与向量的乘积 BCCB矩阵BCCB矩阵的定义BCCB矩阵的对角化BCCB 矩阵与向量的乘积BCCB 矩阵与向量乘积的实现 总结 循环矩阵(Circulant Matrix)和块循环对称矩阵(Block Cir…

(动画版)排序算法 -希尔排序

文章目录 1. 希尔排序(Shellsort)1.1 简介1.2 希尔排序的步骤1.3 希尔排序的C实现1.4 时间复杂度1.5 空间复杂度1.6 希尔排序动画 1. 希尔排序(Shellsort) 1.1 简介 希尔排序(Shells Sort),又…

蓝桥杯每日真题 - 第7天

题目:(爬山) 题目描述(X届 C&C B组X题) 解题思路: 前缀和构造:为了高效地计算子数组的和,我们可以先构造前缀和数组 a,其中 a[i] 表示从第 1 个元素到第 i 个元素的…

socketcan-goloang

模拟接收 模拟发送 package mainimport ("context""fmt""go.einride.tech/can""go.einride.tech/can/pkg/candevice""go.einride.tech/can/pkg/socketcan" )func main() {// linux系统设置// sudo ip link add dev can0 ty…

Java期末复习暨学校第五次上机课作业

Java期末复习暨学校第五次上机课作业:掌握类的定义、掌握类的封装、熟悉类的成员方法的调用。 第一题: 先定义两个整形变量x和y,然后showMessage方法打印防御塔的位置。 然后通过new关键字实例化了一个TowerDefense对象t1,并把x赋值为3&…

【目标检测】【Ultralytics-YOLO系列】Windows11下YOLOV5人脸目标检测

【目标检测】【Ultralytics-YOLO系列】Windows11下YOLOV5人脸目标检测 文章目录 【目标检测】【Ultralytics-YOLO系列】Windows11下YOLOV5人脸目标检测前言YOLOV5模型运行环境搭建YOLOV5模型运行数据集准备YOLOV5运行模型训练模型验证模型推理 总结 前言 Ultralytics YOLO 是一…

【启明智显分享】5G CPE与5G路由器到底有什么区别?

5G路由器和5G CPE在功能和应用场景上存在很明显的差异,小编做了详细比较,希望能帮助到你进一步了解他们的区别及应用。 一、定义与功能 5G路由器 5G路由器是一个将5G网络连接转换为Wi-Fi信号的设备,使多个Wi-Fi设备可以通过5G网络进行连接…

【go从零单排】File Paths文件路径

🌈Don’t worry , just coding! 内耗与overthinking只会削弱你的精力,虚度你的光阴,每天迈出一小步,回头时发现已经走了很远。 📗概念 在 Go 中,处理文件路径通常使用 path/filepath 包。这个包提供了一系…