Toggle navigation
首页
问答
文章
积分商城
专家
专区
更多专区...
文档中心
返回主站
搜索
提问
会员
中心
登录
注册
https
mbedtls
Webclient
10
使用https下载文件,下载失败
发布于 2024-11-14 20:29:08 浏览:264
订阅该版
下载的文件约有800KB,但是单片机内存没有那么大, 程序用的是示例程序 webclient_file.c MBEDTLS的内存最大增到过最大限制长度16384,但是还是原因mbedtls的大小,小于下载文件大小导致失败 ```c //#define MBEDTLS_SSL_MAX_CONTENT_LEN 16384 ``` ```c #define MBEDTLS_AES_ROM_TABLES #define MBEDTLS_ECP_WINDOW_SIZE 2 #define MBEDTLS_SSL_MAX_CONTENT_LEN 3584*2 ``` 每次读文件的大小都限制了2048字节 ```c #define WEBCLIENT_HEADER_BUFSZ 2048 #define WEBCLIENT_RESPONSE_BUFSZ 2048 ``` 下载失败日志如下: 下载失败日志如下: ``` [D/mbedtls.clnt] Set debug level (1) [D/mbedtls.clnt] mbedtls client struct init success... [D/web] host address: unilink-uat.crland.com.cn , port: 443 [D/mbedtls.clnt] mbedtls client context init success... [D/mbedtls.clnt] Connected unilink-uat.crland.com.cn:443 success... [D/mbedtls.clnt] Certificate verified success... [D/web] request header: [D/web] GET /uat-api/file/I5MaXMTfXiI2M-JhmfNFz4_LPSeuvsvh?accessKey=I5MaXMV7JBd2Nr2wmoy_ysqmVJn1u9_t HTTP/1.1 [D/web] Host: unilink-uat.crland.com.cn [D/web] User-Agent: RT-Thread HTTP Agent [D/web] response header: [D/web] HTTP/1.1 200 OK [D/web] Date: Thu, 14 Nov 2024 12:00:51 GMT [D/web] Content-Type: application/octet-stream [D/web] Content-Length: 738482 [D/web] Connection: keep-alive [D/web] traceparent: 00-932a8c34cba8dcb89c2e97c565f81768-70bc13c3e3b97d2d-01 [D/web] Vary: Origin [D/web] Vary: Access-Control-Request-Method [D/web] Vary: Access-Control-Request-Headers [D/web] traceparent: 00-932a8c34cba8dcb89c2e97c565f81768-0f4e5e5146cc9664-01 [D/web] Vary: Origin [D/web] Vary: Access-Control-Request-Method [D/web] Vary: Access-Control-Request-Headers [D/web] Accept-Ranges: bytes [D/web] Content-MD5: 288bbbefb2e7adba49bee0408df74757 [D/web] Digest: sha-256=459e9106a46221589d5ceb6eac43920f08ccefb3c9d080c74d7cb189261a8c97 [D/web] Content-Disposition: attachment; filename*=UTF-8''EACSS_HD_HR_4.0.0.4.bin [D/web] get position handle response(200). [D/web.file] len:2048 >[D/web.file] len:4096 >[D/web.file] len:6144 >[D/web.file] len:8192 >[D/web.file] len:10240 >[D/web.file] len:12288 >[D/web.file] len:14336 >[D/web.file] len:16384 >[D/mbedtls.clnt] ../packages/mbedtls-latest/mbedtls/library/ssl_msg.c:1897: requesting more data than fits [D/mbedtls.clnt] ../packages/mbedtls-latest/mbedtls/library/ssl_msg.c:4719: mbedtls_ssl_fetch_input() returned -28928 (-0x7100) [D/mbedtls.clnt] ../packages/mbedtls-latest/mbedtls/library/ssl_msg.c:3974: ssl_get_next_record() returned -28928 (-0x7100) [D/mbedtls.clnt] ../packages/mbedtls-latest/mbedtls/library/ssl_msg.c:5464: mbedtls_ssl_read_record() returned -28928 (-0x7100) [E/mbedtls.clnt] mbedtls_client_read data error, return -0x7100 [D/web] receive data error(-28928). [D/web.file] len:16942 >[D/mbedtls.clnt] ../packages/mbedtls-latest/mbedtls/library/ssl_msg.c:1897: requesting more data than fits [D/mbedtls.clnt] ../packages/mbedtls-latest/mbedtls/library/ssl_msg.c:4719: mbedtls_ssl_fetch_input() returned -28928 (-0x7100) [D/mbedtls.clnt] ../packages/mbedtls-latest/mbedtls/library/ssl_msg.c:3974: ssl_get_next_record() returned -28928 (-0x7100) [D/mbedtls.clnt] ../packages/mbedtls-latest/mbedtls/library/ssl_msg.c:5464: mbedtls_ssl_read_record() returned -28928 (-0x7100) [E/mbedtls.clnt] mbedtls_client_read data error, return -0x7100 [D/web] receive data error(-28928). [D/web.file] read err [D/web.file] save 16942 bytes. [D/mbedtls.clnt] ../packages/mbedtls-latest/mbedtls/library/ssl_msg.c:2866: mbedtls_ssl_flush_output() returned -26752 (-0x6880) [D/mbedtls.clnt] ../packages/mbedtls-latest/mbedtls/library/ssl_msg.c:5000: mbedtls_ssl_write_record() returned -26752 (-0x6880) [D/mbedtls.clnt] ../packages/mbedtls-latest/mbedtls/library/ssl_msg.c:5871: mbedtls_ssl_send_alert_message() returned -26752 (-0x6880) ``` 下面是mbedtls源码,nb_want的值是一直增加的是随着webclient_read一直增加的,这样子内存一直不够。 ```c int mbedtls_ssl_fetch_input( mbedtls_ssl_context *ssl, size_t nb_want ) { int ret = MBEDTLS_ERR_ERROR_CORRUPTION_DETECTED; size_t len; #if defined(MBEDTLS_SSL_VARIABLE_BUFFER_LENGTH) size_t in_buf_len = ssl->in_buf_len; #else size_t in_buf_len = MBEDTLS_SSL_IN_BUFFER_LEN; #endif MBEDTLS_SSL_DEBUG_MSG( 2, ( "=> fetch input" ) ); if( ssl->f_recv == NULL && ssl->f_recv_timeout == NULL ) { MBEDTLS_SSL_DEBUG_MSG( 1, ( "Bad usage of mbedtls_ssl_set_bio() " "or mbedtls_ssl_set_bio()" ) ); return( MBEDTLS_ERR_SSL_BAD_INPUT_DATA ); } if( nb_want > in_buf_len - (size_t)( ssl->in_hdr - ssl->in_buf ) ) { MBEDTLS_SSL_DEBUG_MSG( 1, ( "requesting more data than fits" ) ); return( MBEDTLS_ERR_SSL_BAD_INPUT_DATA ); } #if defined(MBEDTLS_SSL_PROTO_DTLS) if( ssl->conf->transport == MBEDTLS_SSL_TRANSPORT_DATAGRAM ) { uint32_t timeout; /* * The point is, we need to always read a full datagram at once, so we * sometimes read more then requested, and handle the additional data. * It could be the rest of the current record (while fetching the * header) and/or some other records in the same datagram. */ /* * Move to the next record in the already read datagram if applicable */ if( ssl->next_record_offset != 0 ) { if( ssl->in_left < ssl->next_record_offset ) { MBEDTLS_SSL_DEBUG_MSG( 1, ( "should never happen" ) ); return( MBEDTLS_ERR_SSL_INTERNAL_ERROR ); } ssl->in_left -= ssl->next_record_offset; if( ssl->in_left != 0 ) { MBEDTLS_SSL_DEBUG_MSG( 2, ( "next record in same datagram, offset: %" MBEDTLS_PRINTF_SIZET, ssl->next_record_offset ) ); memmove( ssl->in_hdr, ssl->in_hdr + ssl->next_record_offset, ssl->in_left ); } ssl->next_record_offset = 0; } MBEDTLS_SSL_DEBUG_MSG( 2, ( "in_left: %" MBEDTLS_PRINTF_SIZET ", nb_want: %" MBEDTLS_PRINTF_SIZET, ssl->in_left, nb_want ) ); /* * Done if we already have enough data. */ if( nb_want <= ssl->in_left) { MBEDTLS_SSL_DEBUG_MSG( 2, ( "<= fetch input" ) ); return( 0 ); } /* * A record can't be split across datagrams. If we need to read but * are not at the beginning of a new record, the caller did something * wrong. */ if( ssl->in_left != 0 ) { MBEDTLS_SSL_DEBUG_MSG( 1, ( "should never happen" ) ); return( MBEDTLS_ERR_SSL_INTERNAL_ERROR ); } /* * Don't even try to read if time's out already. * This avoids by-passing the timer when repeatedly receiving messages * that will end up being dropped. */ if( mbedtls_ssl_check_timer( ssl ) != 0 ) { MBEDTLS_SSL_DEBUG_MSG( 2, ( "timer has expired" ) ); ret = MBEDTLS_ERR_SSL_TIMEOUT; } else { len = in_buf_len - ( ssl->in_hdr - ssl->in_buf ); if( ssl->state != MBEDTLS_SSL_HANDSHAKE_OVER ) timeout = ssl->handshake->retransmit_timeout; else timeout = ssl->conf->read_timeout; MBEDTLS_SSL_DEBUG_MSG( 3, ( "f_recv_timeout: %lu ms", (unsigned long) timeout ) ); if( ssl->f_recv_timeout != NULL ) ret = ssl->f_recv_timeout( ssl->p_bio, ssl->in_hdr, len, timeout ); else ret = ssl->f_recv( ssl->p_bio, ssl->in_hdr, len ); MBEDTLS_SSL_DEBUG_RET( 2, "ssl->f_recv(_timeout)", ret ); if( ret == 0 ) return( MBEDTLS_ERR_SSL_CONN_EOF ); } if( ret == MBEDTLS_ERR_SSL_TIMEOUT ) { MBEDTLS_SSL_DEBUG_MSG( 2, ( "timeout" ) ); mbedtls_ssl_set_timer( ssl, 0 ); if( ssl->state != MBEDTLS_SSL_HANDSHAKE_OVER ) { if( ssl_double_retransmit_timeout( ssl ) != 0 ) { MBEDTLS_SSL_DEBUG_MSG( 1, ( "handshake timeout" ) ); return( MBEDTLS_ERR_SSL_TIMEOUT ); } if( ( ret = mbedtls_ssl_resend( ssl ) ) != 0 ) { MBEDTLS_SSL_DEBUG_RET( 1, "mbedtls_ssl_resend", ret ); return( ret ); } return( MBEDTLS_ERR_SSL_WANT_READ ); } #if defined(MBEDTLS_SSL_SRV_C) && defined(MBEDTLS_SSL_RENEGOTIATION) else if( ssl->conf->endpoint == MBEDTLS_SSL_IS_SERVER && ssl->renego_status == MBEDTLS_SSL_RENEGOTIATION_PENDING ) { if( ( ret = mbedtls_ssl_resend_hello_request( ssl ) ) != 0 ) { MBEDTLS_SSL_DEBUG_RET( 1, "mbedtls_ssl_resend_hello_request", ret ); return( ret ); } return( MBEDTLS_ERR_SSL_WANT_READ ); } #endif /* MBEDTLS_SSL_SRV_C && MBEDTLS_SSL_RENEGOTIATION */ } if( ret < 0 ) return( ret ); ssl->in_left = ret; } else #endif { MBEDTLS_SSL_DEBUG_MSG( 2, ( "in_left: %" MBEDTLS_PRINTF_SIZET ", nb_want: %" MBEDTLS_PRINTF_SIZET, ssl->in_left, nb_want ) ); while( ssl->in_left < nb_want ) { len = nb_want - ssl->in_left; if( mbedtls_ssl_check_timer( ssl ) != 0 ) ret = MBEDTLS_ERR_SSL_TIMEOUT; else { if( ssl->f_recv_timeout != NULL ) { ret = ssl->f_recv_timeout( ssl->p_bio, ssl->in_hdr + ssl->in_left, len, ssl->conf->read_timeout ); } else { ret = ssl->f_recv( ssl->p_bio, ssl->in_hdr + ssl->in_left, len ); } } MBEDTLS_SSL_DEBUG_MSG( 2, ( "in_left: %" MBEDTLS_PRINTF_SIZET ", nb_want: %" MBEDTLS_PRINTF_SIZET, ssl->in_left, nb_want ) ); MBEDTLS_SSL_DEBUG_RET( 2, "ssl->f_recv(_timeout)", ret ); if( ret == 0 ) return( MBEDTLS_ERR_SSL_CONN_EOF ); if( ret < 0 ) return( ret ); if ( (size_t)ret > len || ( INT_MAX > SIZE_MAX && ret > (int)SIZE_MAX ) ) { MBEDTLS_SSL_DEBUG_MSG( 1, ( "f_recv returned %d bytes but only %" MBEDTLS_PRINTF_SIZET " were requested", ret, len ) ); return( MBEDTLS_ERR_SSL_INTERNAL_ERROR ); } ssl->in_left += ret; } } MBEDTLS_SSL_DEBUG_MSG( 2, ( "<= fetch input" ) ); return( 0 ); } ``` 尝试过写个简单的断点续传的程序,还是报同样的错误。 请问各位大佬有什么头绪解决这个问题,或者说mbedtls是不是还有些参数可以配置, 怎么修改webclient_read,让mbedtls_ssl_fetch_input中的nb_want不会一直增加下去?
查看更多
2
个回答
默认排序
按发布时间排序
kuxiaogua999
2024-11-20
这家伙很懒,什么也没写!
已解决,单片机ssl解密太慢,下载文件超时了,导致出错了。
梦笑真美
2024-11-15
这家伙很懒,什么也没写!
http下载支持断点续传,文件大也没关系,你的http请求heard是啥
撰写答案
登录
注册新账号
关注者
0
被浏览
264
关于作者
kuxiaogua999
这家伙很懒,什么也没写!
提问
13
回答
3
被采纳
0
关注TA
发私信
相关问题
1
libcurl2rtt编译失败
2
rt-thread + mbedTLS 连接阿里云ssl握手不成功
3
rt-thread+polarssl https连接阿里云握手失败?
4
mbedtls+ stm32f411 握手耗时15s
5
mbedtls 定义全局变量就会死机
6
求助 mbedtls 验证 CA 证书的问题
7
MbedTLS软件包编译失败 unknown type name 'DIR'
8
mbedtls/config.h文件缺失
9
mbedtls_client_read data error 错误
10
socket使用SAL TLS没有反应
推荐文章
1
RT-Thread应用项目汇总
2
玩转RT-Thread系列教程
3
国产MCU移植系列教程汇总,欢迎查看!
4
机器人操作系统 (ROS2) 和 RT-Thread 通信
5
五分钟玩转RT-Thread新社区
6
【技术三千问】之《玩转ART-Pi》,看这篇就够了!干货汇总
7
关于STM32H7开发板上使用SDIO接口驱动SD卡挂载文件系统的问题总结
8
STM32的“GPU”——DMA2D实例详解
9
RT-Thread隐藏的宝藏之completion
10
【ART-PI】RT-Thread 开启RTC 与 Alarm组件
最新文章
1
RT Thread 源码分析笔记 :线程和调度器
2
RT-Thread项目助手v0.2.0 - 支持Env Windows
3
RttreadV5.10上,GD32F450Z RTC时间显示问题
4
rt-smart启动流程分析
5
EtherKit快速上手PROFINET
热门标签
RT-Thread Studio
串口
Env
LWIP
SPI
AT
Bootloader
Hardfault
CAN总线
FinSH
ART-Pi
USB
DMA
文件系统
RT-Thread
SCons
RT-Thread Nano
线程
MQTT
STM32
RTC
FAL
rt-smart
ESP8266
I2C_IIC
UART
WIZnet_W5500
ota在线升级
PWM
cubemx
flash
freemodbus
BSP
packages_软件包
潘多拉开发板_Pandora
定时器
ADC
flashDB
GD32
socket
编译报错
中断
Debug
rt_mq_消息队列_msg_queue
SFUD
msh
keil_MDK
ulog
MicroPython
C++_cpp
本月问答贡献
出出啊
1517
个答案
342
次被采纳
小小李sunny
1444
个答案
290
次被采纳
张世争
813
个答案
177
次被采纳
crystal266
547
个答案
161
次被采纳
whj467467222
1222
个答案
149
次被采纳
本月文章贡献
出出啊
1
篇文章
2
次点赞
小小李sunny
1
篇文章
1
次点赞
张世争
1
篇文章
3
次点赞
crystal266
2
篇文章
2
次点赞
whj467467222
2
篇文章
2
次点赞
回到
顶部
发布
问题
分享
好友
手机
浏览
扫码手机浏览
投诉
建议
回到
底部