bluedroid BLE public key生成代码

时间: 2023-10-02 10:05:14 浏览: 45
以下是基于 Android Bluedroid BLE 栈的 public key 生成代码示例: ```c #include "bt_target.h" #include "bt_types.h" #include "btu.h" #include "btif/include/btif_common.h" #include "btif/include/btif_config.h" #include "btif/include/btif_util.h" #include "stack/crypto_api.h" #include "stack/crypto_toolbox/crypto_toolbox.h" #include "stack/include/smp_api.h" #include "stack/include/bt_octets.h" #define ECC_KEY_LEN 32 static const uint8_t ecdh_p256_base_point_x[] = { 0x3f, 0x20, 0x84, 0x24, 0xa2, 0x7f, 0xb3, 0x5e, 0x13, 0x08, 0x8f, 0x5c, 0xb8, 0x3b, 0x08, 0x0f, 0xa7, 0x19, 0x26, 0xe7, 0x6a, 0x64, 0x1d, 0x3d, 0xf1, 0x2e, 0x2b, 0x7f, 0x62, 0x6a, 0xed, 0x51 }; static const uint8_t ecdh_p256_base_point_y[] = { 0x17, 0x8a, 0xee, 0x7c, 0x69, 0x52, 0x8d, 0x9e, 0x3a, 0x7c, 0x2c, 0x65, 0x6e, 0x9c, 0x60, 0x95, 0x99, 0x37, 0xd4, 0x7f, 0xbc, 0x27, 0xb0, 0x86, 0xce, 0x39, 0x52, 0xc9, 0x13, 0xcb, 0xfc, 0x82 }; static void bluedroid_ble_generate_public_key() { uint8_t priv_key[ECC_KEY_LEN]; uint8_t public_key_x[ECC_KEY_LEN]; uint8_t public_key_y[ECC_KEY_LEN]; uint8_t base_point_x[ECC_KEY_LEN]; uint8_t base_point_y[ECC_KEY_LEN]; uint8_t random_num[ECC_KEY_LEN]; memset(priv_key, 0, ECC_KEY_LEN); memset(public_key_x, 0, ECC_KEY_LEN); memset(public_key_y, 0, ECC_KEY_LEN); memset(base_point_x, 0, ECC_KEY_LEN); memset(base_point_y, 0, ECC_KEY_LEN); memset(random_num, 0, ECC_KEY_LEN); memcpy(base_point_x, ecdh_p256_base_point_x, ECC_KEY_LEN); memcpy(base_point_y, ecdh_p256_base_point_y, ECC_KEY_LEN); CryptoRand((uint8_t*)random_num, ECC_KEY_LEN); if (CryptoECCKeyGen(priv_key, public_key_x, public_key_y, base_point_x, base_point_y, random_num) < 0) { // Key generation failed! return; } // Use public_key_x and public_key_y as public key } ``` 在该示例代码中,我们首先定义了 ECDSA 椭圆曲线参数 `ecdh_p256_base_point_x` 和 `ecdh_p256_base_point_y`,然后生成了一个随机数 `random_num` 作为私钥的种子,最终通过 `CryptoECCKeyGen` 函数生成公钥。你可以根据需要修改上述代码,并在你的应用程序中使用它来生成 Bluedroid BLE 栈的 public key。

相关推荐

最新推荐

recommend-type

android Ble 蓝牙4.0 GATT 错误代码

android Ble 蓝牙4.0 GATT 错误代码对照 133 129
recommend-type

JQuery 动态生成Table表格实例代码

JQuery动态生成Table表格 主要用到了JQuery中的append和appendto的方法,具体代码如下: &lt;!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"&gt; &lt;html&gt;...
recommend-type

JS代码实现table数据分页效果

•这是HTML代码,很简单滴(我好像看到了被嫌弃的小眼神) &lt;!DOCTYPE html&gt; &lt;html&gt; &lt;head lang="en"&gt; &lt;meta charset="UTF-"&gt; [removed][removed] [removed][removed] &lt;link rel=...
recommend-type

BLE蓝牙-4.0-学习笔记

蓝牙4.0 BLE center与peripheral建立连接绑定过程 2 蓝牙4.0 BLE peripheral 广播设置 7 ...蓝牙4.0 BLE key处理过程看任务、事件、消息机制 50 CC254x 内部存储结构 FLASH 53 蓝牙4.0 BLE FLASH 操作 58
recommend-type

AN_19071701-C1_Telink 8232 BLE SDK Developer Handbook

泰凌微的蓝牙8232的开发手册,介绍泰凌微整个SDK的架构,8232的硬件如何调用,介绍泰凌微蓝牙每个软件驱动使用
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

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

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

可见光定位LED及其供电硬件具体型号,广角镜头和探测器,实验设计具体流程步骤,

1. 可见光定位LED型号:一般可使用5mm或3mm的普通白色LED,也可以选择专门用于定位的LED,例如OSRAM公司的SFH 4715AS或Vishay公司的VLMU3500-385-120。 2. 供电硬件型号:可以使用常见的直流电源供电,也可以选择专门的LED驱动器,例如Meanwell公司的ELG-75-C或ELG-150-C系列。 3. 广角镜头和探测器型号:一般可采用广角透镜和CMOS摄像头或光电二极管探测器,例如Omron公司的B5W-LA或Murata公司的IRS-B210ST01。 4. 实验设计流程步骤: 1)确定实验目的和研究对象,例如车辆或机器人的定位和导航。
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。