nrf52830蓝牙加密是怎么一回事?用sdk或者其他代码来讲解

时间: 2024-02-18 15:05:54 浏览: 23
nRF52830 是一款支持加密的蓝牙芯片,可以使用 Nordic 官方提供的 SDK 或者其他库来实现加密功能。下面是一个使用 Nordic SDK 实现 nRF52830 蓝牙加密的代码示例: ```c #include "nrf_ble_gatt.h" #include "nrf_ble_qwr.h" #include "nrf_sdh_ble.h" #include "nrf_sdh_soc.h" #include "nrf_ble_scan.h" #include "nrf_ble_conn_params.h" #include "nrf_ble_gq.h" #include "nrf_crypto.h" #include "nrf_crypto_error.h" #define DEVICE_NAME "MyDevice" // 设备名称 #define APP_BLE_OBSERVER_PRIO 3 // BLE事件观察者优先级 static ble_gap_sec_params_t m_sec_params; // 安全参数 static ble_gap_conn_params_t m_conn_params; // 连接参数 static uint16_t m_conn_handle = BLE_CONN_HANDLE_INVALID;// 连接句柄 void ble_stack_init(void) { ret_code_t err_code; // 初始化 SoftDevice err_code = nrf_sdh_enable_request(); APP_ERROR_CHECK(err_code); // 配置 SoftDevice 协议栈 nrf_sdh_ble_default_cfg_set(APP_BLE_OBSERVER_PRIO); // 配置 BLE GAP ble_gap_conn_sec_mode_t sec_mode; BLE_GAP_CONN_SEC_MODE_SET_OPEN(&sec_mode); err_code = sd_ble_gap_device_name_set(&sec_mode, (const uint8_t *)DEVICE_NAME, strlen(DEVICE_NAME)); APP_ERROR_CHECK(err_code); // 配置安全参数 memset(&m_sec_params, 0, sizeof(m_sec_params)); m_sec_params.bond = 1; m_sec_params.mitm = 1; m_sec_params.lesc = 1; m_sec_params.keypress = 0; m_sec_params.io_caps = BLE_GAP_IO_CAPS_NONE; m_sec_params.oob = 0; m_sec_params.min_key_size = 7; m_sec_params.max_key_size = 16; // 配置连接参数 memset(&m_conn_params, 0, sizeof(m_conn_params)); m_conn_params.min_conn_interval = MSEC_TO_UNITS(20, UNIT_1_25_MS); m_conn_params.max_conn_interval = MSEC_TO_UNITS(75, UNIT_1_25_MS); m_conn_params.slave_latency = 0; m_conn_params.conn_sup_timeout = MSEC_TO_UNITS(4000, UNIT_10_MS); // 初始化 BLE GATT err_code = nrf_ble_gatt_init(&m_gatt, NULL); APP_ERROR_CHECK(err_code); // 初始化 BLE QWR err_code = nrf_ble_qwr_init(&m_qwr, &m_qwr_buffer); APP_ERROR_CHECK(err_code); // 初始化 BLE Scan err_code = nrf_ble_scan_init(&m_scan, NULL, NULL); APP_ERROR_CHECK(err_code); // 初始化 BLE Connection Parameters err_code = nrf_ble_conn_params_init(&m_conn_params); APP_ERROR_CHECK(err_code); // 初始化 BLE GQ err_code = nrf_ble_gq_init(&m_ble_gq, ble_gatt_evt_handler); APP_ERROR_CHECK(err_code); // 启用 BLE Stack err_code = nrf_sdh_ble_enable(&m_sec_params); APP_ERROR_CHECK(err_code); } void ble_gap_evt_handler(ble_gap_evt_t const * p_gap_evt, void * p_context) { ret_code_t err_code; switch (p_gap_evt->evt_id) { case BLE_GAP_EVT_CONNECTED: m_conn_handle = p_gap_evt->conn_handle; break; case BLE_GAP_EVT_DISCONNECTED: m_conn_handle = BLE_CONN_HANDLE_INVALID; break; case BLE_GAP_EVT_SEC_PARAMS_REQUEST: err_code = sd_ble_gap_sec_params_reply(m_conn_handle, BLE_GAP_SEC_STATUS_SUCCESS, &m_sec_params, NULL); APP_ERROR_CHECK(err_code); break; case BLE_GAP_EVT_AUTH_STATUS: if (p_gap_evt->params.auth_status.auth_status == BLE_GAP_SEC_STATUS_SUCCESS) { // 认证通过,加密连接 err_code = nrf_ble_gatt_authenticate(m_conn_handle, NULL); APP_ERROR_CHECK(err_code); } break; case BLE_GAP_EVT_CONN_PARAM_UPDATE_REQUEST: err_code = sd_ble_gap_conn_param_update(m_conn_handle, &p_gap_evt->params.conn_param_update_request.conn_params); APP_ERROR_CHECK(err_code); break; default: // 不处理其他事件 break; } } void ble_gatt_evt_handler(nrf_ble_gatt_t * p_gatt, nrf_ble_gatt_evt_t const * p_evt) { ret_code_t err_code; switch (p_evt->evt_id) { case NRF_BLE_GATT_EVT_MTU_CHANGED: break; case NRF_BLE_GATT_EVT_ATT_MTU_UPDATED: break; case NRF_BLE_GATT_EVT_DATA_LENGTH_UPDATED: break; case NRF_BLE_GATT_EVT_ATT_EXCHANGE_MTU_REQUEST: err_code = nrf_ble_gatt_att_mtu_reply(p_gatt, p_evt->conn_handle, BLE_GATT_ATT_MTU_DEFAULT); APP_ERROR_CHECK(err_code); break; case NRF_BLE_GATT_EVT_HVX: break; case NRF_BLE_GATT_EVT_WRITE: break; case NRF_BLE_GATT_EVT_READ: break; case NRF_BLE_GATT_EVT_TIMEOUT: break; case NRF_BLE_GATT_EVT_EXCHANGE_MTU_RSP: break; case NRF_BLE_GATT_EVT_CHAR_DISC_RSP: break; case NRF_BLE_GATT_EVT_DESC_DISC_RSP: break; case NRF_BLE_GATT_EVT_CHAR_VALS_READ_RSP: break; case NRF_BLE_GATT_EVT_WRITE_RSP: break; case NRF_BLE_GATT_EVT_HANDLE_VALUE_INDICATION_CONFIRMED: break; default: // 不处理其他事件 break; } } void ble_stack_start(void) { ret_code_t err_code; // 启动 BLE Scan err_code = nrf_ble_scan_start(&m_scan); APP_ERROR_CHECK(err_code); // 启动 BLE Connection Parameters err_code = nrf_ble_conn_params_enable(); APP_ERROR_CHECK(err_code); } ``` 在上述代码中,我们使用了 Nordic SDK 提供的函数来初始化蓝牙协议栈、配置安全参数、配置连接参数、初始化 GATT、初始化 QWR、初始化 BLE Scan、初始化 BLE Connection Parameters 等,最终启动 BLE Stack,实现了 nRF52830 蓝牙加密功能。 需要注意的是,在安全参数中我们设置了 mitm 和 lesc 为 1,这表示我们需要进行双向身份验证和安全连接。在 BLE_GAP_EVT_AUTH_STATUS 事件中,当认证成功时,我们通过调用 nrf_ble_gatt_authenticate 函数来进行加密连接,从而实现了蓝牙加密功能。

相关推荐

最新推荐

recommend-type

青风带你学蓝牙nrf52840-上册

本文档主要对基于Nordic的蓝牙5.0进行了详细的讲解,从构建工程,到板子的各个模块价绍。最后用实战案例进行了详细的讲解。
recommend-type

PHY6202蓝牙4.0组网替代NRF51822

PHY6202是国内知名厂家奉加微推出的超低功耗蓝牙芯片,可替代NRF51822/51802,同时也是为数不多可用于蓝牙4.0组网的芯片。
recommend-type

主流蓝牙BLE控制芯片详解(4):Nordic nRF51822

nRF51822 是功能强大、高灵活性的多协议 SoC,非常适用于 Bluetooth:registered: 低功耗和 2.4GHz 超低功耗无线应用。
recommend-type

nrf51822 sdk12.2空中升级笔记

本人亲测的nrf51822空中升级步骤,测试通过,使用官方sdk12.2源码编译,官方升级工具
recommend-type

NRF52810数据手册.pdf

nRF52810低功耗蓝牙芯片数据手册 该产品规范根据该 IC 中可用的模块和外围设备分为几章。 外围设备描述分为单独的部分,其中包括以下信息: • 外设的详细功能说明 • 外设的寄存器配置 • 电气规格表,其中包含适用...
recommend-type

RTL8188FU-Linux-v5.7.4.2-36687.20200602.tar(20765).gz

REALTEK 8188FTV 8188eus 8188etv linux驱动程序稳定版本, 支持AP,STA 以及AP+STA 共存模式。 稳定支持linux4.0以上内核。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

:YOLO目标检测算法的挑战与机遇:数据质量、计算资源与算法优化,探索未来发展方向

![:YOLO目标检测算法的挑战与机遇:数据质量、计算资源与算法优化,探索未来发展方向](https://img-blog.csdnimg.cn/7e3d12895feb4651b9748135c91e0f1a.png?x-oss-process=image/watermark,type_ZHJvaWRzYW5zZmFsbGJhY2s,shadow_50,text_Q1NETiBA5rKJ6YaJ77yM5LqO6aOO5Lit,size_20,color_FFFFFF,t_70,g_se,x_16) # 1. YOLO目标检测算法简介 YOLO(You Only Look Once)是一种
recommend-type

def ObjFun(x,y,beta): # 目标函数 """ Logistic regression loss function :param beta: model parameter vector :param x: feature matrix :param y: label vector :return: loss value """ n = x.shape[0] p = x.shape[1] pred = 1 / (1 + np.exp(-np.dot(x, beta))) pred = np.clip(pred, 1e-15, 1 - 1e-15) # 将预测值限制在一个很小的区间内 ObjVal = -np.sum(y * np.log(pred) + (1 - y) * np.log(1 - pred)) / n return ObjVal

好的,根据上面的目标函数,我们可以推导出其对应的梯度向量函数,如下所示: def gradient(x, y, beta): """ Compute gradient of the logistic regression loss function :param beta: model parameter vector :param x: feature matrix :param y: label vector :return: gradient vector """ n = x.shape[0] pred = 1 /
recommend-type

c++校园超市商品信息管理系统课程设计说明书(含源代码) (2).pdf

校园超市商品信息管理系统课程设计旨在帮助学生深入理解程序设计的基础知识,同时锻炼他们的实际操作能力。通过设计和实现一个校园超市商品信息管理系统,学生掌握了如何利用计算机科学与技术知识解决实际问题的能力。在课程设计过程中,学生需要对超市商品和销售员的关系进行有效管理,使系统功能更全面、实用,从而提高用户体验和便利性。 学生在课程设计过程中展现了积极的学习态度和纪律,没有缺勤情况,演示过程流畅且作品具有很强的使用价值。设计报告完整详细,展现了对问题的深入思考和解决能力。在答辩环节中,学生能够自信地回答问题,展示出扎实的专业知识和逻辑思维能力。教师对学生的表现予以肯定,认为学生在课程设计中表现出色,值得称赞。 整个课程设计过程包括平时成绩、报告成绩和演示与答辩成绩三个部分,其中平时表现占比20%,报告成绩占比40%,演示与答辩成绩占比40%。通过这三个部分的综合评定,最终为学生总成绩提供参考。总评分以百分制计算,全面评估学生在课程设计中的各项表现,最终为学生提供综合评价和反馈意见。 通过校园超市商品信息管理系统课程设计,学生不仅提升了对程序设计基础知识的理解与应用能力,同时也增强了团队协作和沟通能力。这一过程旨在培养学生综合运用技术解决问题的能力,为其未来的专业发展打下坚实基础。学生在进行校园超市商品信息管理系统课程设计过程中,不仅获得了理论知识的提升,同时也锻炼了实践能力和创新思维,为其未来的职业发展奠定了坚实基础。 校园超市商品信息管理系统课程设计的目的在于促进学生对程序设计基础知识的深入理解与掌握,同时培养学生解决实际问题的能力。通过对系统功能和用户需求的全面考量,学生设计了一个实用、高效的校园超市商品信息管理系统,为用户提供了更便捷、更高效的管理和使用体验。 综上所述,校园超市商品信息管理系统课程设计是一项旨在提升学生综合能力和实践技能的重要教学活动。通过此次设计,学生不仅深化了对程序设计基础知识的理解,还培养了解决实际问题的能力和团队合作精神。这一过程将为学生未来的专业发展提供坚实基础,使其在实际工作中能够胜任更多挑战。