CPU는 악성 코드에 의해 데이터와 개인 정보가 도난당하는 것을 어떻게 보호할 수 있습니까? Intel SGX에 대한 기본 소개
이 글은 Intel SGX에 대한 기본적인 소개를 담고 있습니다. 도움이 필요한 친구들이 참고할 수 있기를 바랍니다.
Intel SGX 기본 소개
Intel SGX(Intel Software Guard Extension)는 Intel 명령어 세트 아키텍처의 확장입니다. SGX는 메모리의 암호화되고 신뢰할 수 있는 실행 영역인 Enclave를 제공합니다. 여기서 CPU는 악성 코드에 의해 데이터와 개인 정보가 도난당하지 않도록 보호합니다.
Principle
SGX는 새로운 프로세서 명령을 사용하여 메모리에 EPC(Enclave Page Cache) 영역의 일부를 할당하고, 그 안의 데이터를 암호화 엔진인 MEE(Memory Encryption Engine)를 통해 암호화합니다. CPU. EPC의 암호화된 콘텐츠는 CPU에 들어갈 때까지 일반 텍스트로 해독되지 않습니다. 따라서 SGX에서는 운영 체제나 VMM, 심지어 BIOS까지 신뢰할 필요가 없으며 개인 데이터가 유출되지 않도록 CPU만 신뢰하면 됩니다.
Application
실제 응용에서는 개인 데이터를 암호화하여 클라우드 상의 서클에 암호문 형태로 전송하고, 원격 인증을 통해 해당 비밀키를 서클에 전달할 수 있습니다. 그런 다음 데이터는 CPU의 암호화 보호 하에 계산을 수행하는 데 사용되며 결과는 암호문으로 사용자에게 반환됩니다. 이 모드에서는 데이터 유출 걱정 없이 클라우드 컴퓨팅의 강력한 컴퓨팅 성능을 활용할 수 있습니다.
EDL(Enclave Definition Language)
EDL은 SGX 프로그래밍의 핵심으로 Enclave에서 데이터를 읽고 쓰고 처리하는 모든 기능을 정의합니다. 컴파일 단계에서 SDK가 제공하는 Edger8r 도구는 EDL에 정의된 기능을 기반으로 환경과 일반 메모리 간의 브리징 기능을 생성하고 해당 보안 감지를 수행합니다.
기능은 신뢰할 수 있는 함수(ecall)와 신뢰할 수 없는 함수(ocall)로 구분됩니다.
ecall: 신뢰할 수 있는 영역(trusted)에서 정의되고, 서클 외부에서 호출되고, 서클 내에서 실행됩니다.
ocall: 신뢰할 수 없는 영역(untrusted)에서 정의되고, 둘러싸인 내부에서 호출되고, 둘러싸인 외부에서 실행됩니다.
// demo.edl enclave { // Add your definition of "secret_t" here trusted { public void get_secret([out] secret_t* secret); }; untrusted { // This OCALL is for illustration purposes only. // It should not be used in a real enclave, // unless it is during the development phase // for debugging purposes. void dump_secret([in] const secret_t* secret); }; };
SGX 설치
드라이버, PSW, SDK 등을 포함한 설치 파일이나 소스 코드를 통해 SGX를 설치할 수 있습니다. 두 가지 설치 방법 모두 Linux 커널 버전에 해당하는 헤더 파일을 설치해야 합니다.
위 내용은 CPU는 악성 코드에 의해 데이터와 개인 정보가 도난당하는 것을 어떻게 보호할 수 있습니까? Intel SGX에 대한 기본 소개의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











대 코드 시스템 요구 사항 : 운영 체제 : Windows 10 이상, MacOS 10.12 이상, Linux 배포 프로세서 : 최소 1.6GHz, 권장 2.0GHz 이상의 메모리 : 최소 512MB, 권장 4GB 이상의 저장 공간 : 최소 250MB, 권장 1GB 및 기타 요구 사항 : 안정 네트워크 연결, Xorg/Wayland (LINUX)

메모장은 Java 코드를 직접 실행할 수는 없지만 다른 도구를 사용하여 명령 줄 컴파일러 (Javac)를 사용하여 Bytecode 파일 (filename.class)을 생성하면 달성 할 수 있습니다. Java Interpreter (Java)를 사용하여 바이트 코드를 해석하고 코드를 실행하고 결과를 출력하십시오.

VS 코드 확장을 설치하는 이유는 다음과 같습니다. 네트워크 불안정성, 불충분 한 권한, 시스템 호환성 문제, C 코드 버전은 너무 오래된, 바이러스 백신 소프트웨어 또는 방화벽 간섭입니다. 네트워크 연결, 권한, 로그 파일, 업데이트 대 코드 업데이트, 보안 소프트웨어 비활성화 및 대 코드 또는 컴퓨터를 다시 시작하면 점차 문제를 해결하고 해결할 수 있습니다.

Linux 시스템의 5 가지 기본 구성 요소는 다음과 같습니다. 1. Kernel, 2. System Library, 3. System Utilities, 4. 그래픽 사용자 인터페이스, 5. 응용 프로그램. 커널은 하드웨어 리소스를 관리하고 시스템 라이브러리는 사전 컴파일 된 기능을 제공하며 시스템 유틸리티는 시스템 관리에 사용되며 GUI는 시각적 상호 작용을 제공하며 응용 프로그램은 이러한 구성 요소를 사용하여 기능을 구현합니다.

Visual Studio Code (VSCODE)는 Microsoft가 개발 한 크로스 플랫폼, 오픈 소스 및 무료 코드 편집기입니다. 광범위한 프로그래밍 언어에 대한 가볍고 확장 성 및 지원으로 유명합니다. VSCODE를 설치하려면 공식 웹 사이트를 방문하여 설치 프로그램을 다운로드하고 실행하십시오. VScode를 사용하는 경우 새 프로젝트를 만들고 코드 편집, 디버그 코드, 프로젝트 탐색, VSCODE 확장 및 설정을 관리 할 수 있습니다. VSCODE는 Windows, MacOS 및 Linux에서 사용할 수 있으며 여러 프로그래밍 언어를 지원하며 Marketplace를 통해 다양한 확장을 제공합니다. 이점은 경량, 확장 성, 광범위한 언어 지원, 풍부한 기능 및 버전이 포함됩니다.

VS 코드는 Mac에서 사용할 수 있습니다. 강력한 확장, GIT 통합, 터미널 및 디버거가 있으며 풍부한 설정 옵션도 제공합니다. 그러나 특히 대규모 프로젝트 또는 고도로 전문적인 개발의 경우 VS 코드는 성능 또는 기능 제한을 가질 수 있습니다.

git 저장소 주소를 보려면 다음 단계를 수행하십시오. 1. 명령 줄을 열고 리포지토리 디렉토리로 이동하십시오. 2. "git remote -v"명령을 실행하십시오. 3. 출력 및 해당 주소에서 저장소 이름을 봅니다.

VS Code는 Full Name Visual Studio Code로, Microsoft가 개발 한 무료 및 오픈 소스 크로스 플랫폼 코드 편집기 및 개발 환경입니다. 광범위한 프로그래밍 언어를 지원하고 구문 강조 표시, 코드 자동 완료, 코드 스 니펫 및 스마트 프롬프트를 제공하여 개발 효율성을 향상시킵니다. 풍부한 확장 생태계를 통해 사용자는 디버거, 코드 서식 도구 및 GIT 통합과 같은 특정 요구 및 언어에 확장을 추가 할 수 있습니다. VS 코드에는 코드에서 버그를 신속하게 찾아서 해결하는 데 도움이되는 직관적 인 디버거도 포함되어 있습니다.
