windows10 SGX开发环境搭建及简单应用的开发

2024-02-08 08:38

本文主要是介绍windows10 SGX开发环境搭建及简单应用的开发,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目 录

实验环境:

SGX开发环境搭建:

开发一个简单的可信应用:

1. 创建Enclave项目

 2. 创建C++空项目

3. 编译并执行

实验环境:

windows 10系统,Visual Studio 2017

SGX开发环境搭建:

1. Intel ME下载及安装:Intel ME下载地址

2. SGX SDK 下载及安装:SGX SDK下载地址(解压后,双击安装程序进行安装)

3. 检查是否配置成功:打开VS2017,新建C++项目,出现SGX Enclave Project选项,说明环境配置成功

开发一个简单的可信应用:

       本程序(名称:BubbleSort)根据冒泡排序算法通过编写冒泡排序函数,对用户随机输入的五个数按照从小到大进行排列。本程序包含一个冒泡排序函数(BubbleSort)和一个程序主函数(main)。将冒泡排序函数(BubbleSort)放入可信区,main函数通过ECALL函数调用可信区内的冒泡排序函数(BubbleSort)。具体操作步骤如下:

1. 创建Enclave项目

(1)创建一个Intel Eclave项目(BubbleSort):打开VS2017,新建-->项目,选择SGX Enclave Project选项,编辑名称为BubbleSort

 

(2)BubbleSort项目创建成功之后,修改Source Files文件夹下的BubbleSort.edl文件内容,在trusted中声明函数BubbleSort(该函数的作用是实现冒泡排序算法)

 

(3)修改Source Files文件夹下的BubbleSort.cpp文件内容,添加在上一步中所声明的函数(BubbleSort)的实现代码:

 

(4)修改BubbleSort项目的属性:

       右键BubbleSort项目,选择“属性”打开BubbleSort属性页,在最上端的“配置(C)”处选择“所有配置”,其右边的“平台(P)”处选择“Win32”,在“配置属性”下面的“调试”,在右侧“要启动的调试器”中选择“Intel(R) SGX Debugger”,下面的“Working Directory”后面修改为“$(OutDir)”,点击“确定”

 2. 创建C++空项目

(1)创建名为main(BubbleSort)的空项目(用以调用可信区间的BubbleSort函数,实现对随机数组的排序):右键“解决方案‘BubbleSort’”-->添加-->新建项目-->空项目

(2)在main(BubbleSort)项目的“源文件”下添加“main.cpp”,添加如下代码:

 

(3)在main(BubbleSort)项目中导入Enclave项目(BubbleSort)的依赖

 ①右键main(BubbleSort)项目:

选择“Intel SGX Configuration-->Import Enclave”,在BubbleSort.edl前面勾选,点击“OK”

 

 

②右键main(BubbleSort)项目:

选择“属性”,打开main(BubbleSort)属性页,在最上端的“配置(C)”处选择“所有配置”,其右边的“平台(P)”处选择“Win32”;

选择“配置属性”-->“调试”,将工作目录修改为“$(OutDir)”,点击“确定”

 

③右键“解决方案‘BubbleSort’ --> 属性 ”:

点击“通用属性”下的“启动项目”,点击“单启动项目”,并在下面选择“main(BubbleSort)”;

点击“项目依赖项”,在右边选择项目"main(BubbleSort)",并在下面的“依赖于(D)”中勾选“BubbleSort”,点击确定

3. 编译并执行

(1)编译结果:

 

 

 

 

 

 

 

 

(2)出现报错:

 该错误说明SGX PSW没有安装成功或者本机不支持SGX,只需将vs2017的配置由“Debug”改为“Simulation”,即通过SGX SDK中内置的模拟器来运行和调试Enclave程序

 (3)执行结果:(成功执行!)

这篇关于windows10 SGX开发环境搭建及简单应用的开发的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/690488

相关文章

Android开发中gradle下载缓慢的问题级解决方法

《Android开发中gradle下载缓慢的问题级解决方法》本文介绍了解决Android开发中Gradle下载缓慢问题的几种方法,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、网络环境优化二、Gradle版本与配置优化三、其他优化措施针对android开发中Gradle下载缓慢的问

MobaXterm远程登录工具功能与应用小结

《MobaXterm远程登录工具功能与应用小结》MobaXterm是一款功能强大的远程终端软件,主要支持SSH登录,拥有多种远程协议,实现跨平台访问,它包括多会话管理、本地命令行执行、图形化界面集成和... 目录1. 远程终端软件概述1.1 远程终端软件的定义与用途1.2 远程终端软件的关键特性2. 支持的

使用Go语言开发一个命令行文件管理工具

《使用Go语言开发一个命令行文件管理工具》这篇文章主要为大家详细介绍了如何使用Go语言开发一款命令行文件管理工具,支持批量重命名,删除,创建,移动文件,需要的小伙伴可以了解下... 目录一、工具功能一览二、核心代码解析1. 主程序结构2. 批量重命名3. 批量删除4. 创建文件/目录5. 批量移动三、如何安

Android 悬浮窗开发示例((动态权限请求 | 前台服务和通知 | 悬浮窗创建 )

《Android悬浮窗开发示例((动态权限请求|前台服务和通知|悬浮窗创建)》本文介绍了Android悬浮窗的实现效果,包括动态权限请求、前台服务和通知的使用,悬浮窗权限需要动态申请并引导... 目录一、悬浮窗 动态权限请求1、动态请求权限2、悬浮窗权限说明3、检查动态权限4、申请动态权限5、权限设置完毕后

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

redis群集简单部署过程

《redis群集简单部署过程》文章介绍了Redis,一个高性能的键值存储系统,其支持多种数据结构和命令,它还讨论了Redis的服务器端架构、数据存储和获取、协议和命令、高可用性方案、缓存机制以及监控和... 目录Redis介绍1. 基本概念2. 服务器端3. 存储和获取数据4. 协议和命令5. 高可用性6.

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

本地搭建DeepSeek-R1、WebUI的完整过程及访问

《本地搭建DeepSeek-R1、WebUI的完整过程及访问》:本文主要介绍本地搭建DeepSeek-R1、WebUI的完整过程及访问的相关资料,DeepSeek-R1是一个开源的人工智能平台,主... 目录背景       搭建准备基础概念搭建过程访问对话测试总结背景       最近几年,人工智能技术

在Mysql环境下对数据进行增删改查的操作方法

《在Mysql环境下对数据进行增删改查的操作方法》本文介绍了在MySQL环境下对数据进行增删改查的基本操作,包括插入数据、修改数据、删除数据、数据查询(基本查询、连接查询、聚合函数查询、子查询)等,并... 目录一、插入数据:二、修改数据:三、删除数据:1、delete from 表名;2、truncate

基于Python开发PPTX压缩工具

《基于Python开发PPTX压缩工具》在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,不便于传输和存储,所以本文将使用Python开发一个PPTX压缩工具,需要的可以了解下... 目录引言全部代码环境准备代码结构代码实现运行结果引言在日常办公中,PPT文件往往因为图片过大而导致文件体积过大,