分享一下自己正在写的库ohos_reqwest,无需OpenSSL依赖,支持忽略SSL证书校验的http(s)请求库...

仓库地址:https://gitee.com/Kingtous/ohos_reqwest

README:reqwest/README.md · Kingtous/ohos_reqwest - Gitee.com

目前还在走ohpm审核流程,可以down下来打包尝鲜,支持到API 9,API 11可以用abortController取消请求。

Reqwest是Rust下用的特别多的一个http库,并且支持rustls(纯Rust实现的OpenSSL,摆脱OpenSSL问题):seanmonstar/reqwest: An easy and powerful Rust HTTP Client (github.com)

最近遇到需要忽略自签证书校验(SSL)问题,尝试过使用axios(使用的ohos.net.http,无法绕过)、httpclient、axiosforhttpclient(context和ca都传了,但一直出现SSL is null,折腾了几天,看了下代码估计是内部调用socket问题),都没能解决问题,提issue后作者可能也在忙其他事情。后来想着还是自己解决一下。

目前已经在自己内部项目中使用,欢迎大家使用/共建,有问题可以提pr/issue。

 

  • 5
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在信号处理领域,DOA(Direction of Arrival)估计是一项关键技术,主要用于确定多个信号源到达接收阵列的方向。本文将详细探讨三种ESPRIT(Estimation of Signal Parameters via Rotational Invariance Techniques)算法在DOA估计中的实现,以及它们在MATLAB环境中的具体应用。 ESPRIT算法是由Paul Kailath等人于1986年提出的,其核心思想是利用阵列数据的旋转不变性来估计信号源的角度。这种算法相比传统的 MUSIC(Multiple Signal Classification)算法具有较低的计算复杂度,且无需进行特征值分解,因此在实际应用中颇具优势。 1. 普通ESPRIT算法 普通ESPRIT算法分为两个主要步骤:构造等效旋转不变系统和估计角度。通过空间平移(如延时)构建两个子阵列,使得它们之间的关系具有旋转不变性。然后,通过对子阵列数据进行最小二乘拟合,可以得到信号源的角频率估计,进一步转换为DOA估计。 2. 常规ESPRIT算法实现 在描述中提到的`common_esprit_method1.m`和`common_esprit_method2.m`是两种不同的普通ESPRIT算法实现。它们可能在实现细节上略有差异,比如选择子阵列的方式、参数估计的策略等。MATLAB代码通常会包含预处理步骤(如数据归一化)、子阵列构造、旋转不变性矩阵的建立、最小二乘估计等部分。通过运行这两个文件,可以比较它们在估计精度和计算效率上的异同。 3. TLS_ESPRIT算法 TLS(Total Least Squares)ESPRIT是对普通ESPRIT的优化,它考虑了数据噪声的影响,提高了估计的稳健性。在TLS_ESPRIT算法中,不假设数据噪声是高斯白噪声,而是采用总最小二乘准则来拟合数据。这使得算法在噪声环境下表现更优。`TLS_esprit.m`文件应该包含了TLS_ESPRIT算法的完整实现,包括TLS估计的步骤和旋转不变性矩阵的改进处理。 在实际应用中,选择合适的ESPRIT变体取决于系统条件,例如噪声水平、信号质量以及计算资源。通过MATLAB实现,研究者和工程师可以方便地比较不同算法的效果,并根据需要进行调整和优化。同时,这些代码也为教学和学习DOA估计提供了一个直观的平台,有助于深入理解ESPRIT算法的工作原理。
当使用 reqwest 软件下载接口时,你可以结合 Rust 的 web 框架(比如 Actix-web)来创建一个 HTTP 服务器,然后设置一个路由来处理下载请求。以下是一个示例: 首先,在 `Cargo.toml` 文件中添加所需的依赖: ```toml [dependencies] actix-web = "3.3" reqwest = "0.11" tokio = { version = "1", features = ["full"] } ``` 然后,你可以创建一个 Rust 文件,比如 `main.rs`,并编以下代码: ```rust use actix_web::{get, web, App, HttpResponse, HttpServer}; use std::fs::File; use std::io::Write; #[get("/download")] async fn download_file() -> HttpResponse { // 创建一个文件来保存下载的内容 let mut file = match File::create("downloaded_file.txt") { Ok(file) => file, Err(_) => return HttpResponse::InternalServerError().finish(), }; // 发起 HTTP 请求并获取响应 let response = match reqwest::get("http://example.com").await { Ok(response) => response, Err(_) => return HttpResponse::InternalServerError().finish(), }; // 检查响应状态码 if response.status().is_success() { // 将响应体入文件 let mut content = match response.bytes().await { Ok(content) => content, Err(_) => return HttpResponse::InternalServerError().finish(), }; if let Err(_) = io::copy(&mut content, &mut file) { return HttpResponse::InternalServerError().finish(); } println!("文件下载完成!"); HttpResponse::Ok().finish() } else { HttpResponse::InternalServerError().finish() } } #[actix_web::main] async fn main() -> std::io::Result<()> { HttpServer::new(|| { App::new().service(download_file) }) .bind("127.0.0.1:8080")? .run() .await } ``` 以上代码使用了 Actix-web 框架创建了一个简单的 HTTP 服务器,并使用 reqwest 来发送 HTTP 请求和获取响应。当访问 `/download` 路由时,它会从服务器下载文件并保存到名为 `downloaded_file.txt` 的文件中。 请注意,这只是一个简单的示例,实际应用中可能需要更多的错误处理和逻辑。确保在实际使用时根据需求进行适当的修改和调整。 希望这可以帮助到你!如果你有任何其他问题,请随时问我。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值