」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 跨平台使用 RSA 加密和解密保護數據

跨平台使用 RSA 加密和解密保護數據

發佈於2024-11-08
瀏覽:277

Securing Data with RSA Encryption and Decryption Across Platforms

RSA加密簡介

在當今的數位環境中,保護敏感資料對於個人和組織都至關重要。 RSA (Rivest-Shamir-Adleman) 加密作為保護資料的強大解決方案脫穎而出。它是一種非對稱加密演算法,這意味著它使用一對金鑰:用於加密的公鑰和用於解密的私鑰。 RSA 加密的主要好處之一是私鑰永遠不需要分享,這最大限度地降低了私鑰外洩的風險。

本文探討如何在三種流行的程式語言(JavaScript、Python 和 PHP)中使用 RSA 加密,從而更輕鬆地保護跨平台應用程式中的資料。

跨平台加密與解密:場景

假設您正在建立一個 Web 應用程序,其中敏感資訊(如身份驗證資料或個人詳細資料)必須在客戶端(前端)和伺服器(後端)之間安全傳輸。例如,您可以在客戶端使用 JavaScript 加密訊息,然後使用 Python 或 PHP 在伺服器上解密。

RSA 非常適合這種場景,因為它提供了一種語言加密和另一種語言解密的靈活性,確保了跨平台相容性。

RSA 實作:JavaScript、Python 和 PHP

JavaScript(附 JSEncrypt 的 Next.js)
加密:

import JSEncrypt from 'jsencrypt';

// Function to encrypt a message using a public key
const encryptWithPublicKey = (message) => {
  const encryptor = new JSEncrypt();
  const publicKey = process.env.NEXT_PUBLIC_PUBLIC_KEY.replace(/\\n/g, "\n");
  encryptor.setPublicKey(publicKey);
  const encryptedMessage = encryptor.encrypt(message);
  return encryptedMessage;
};

解密:

import JSEncrypt from 'jsencrypt';

// Function to decrypt a message using a private key
const decryptWithPrivateKey = (encryptedMessage) => {
  const decryptor = new JSEncrypt();
  const privateKey = process.env.PRIVATE_KEY.replace(/\\n/g, "\n");
  decryptor.setPrivateKey(privateKey);
  const decryptedMessage = decryptor.decrypt(encryptedMessage);
  return decryptedMessage;
};

解釋:

公鑰加密: JSEncrypt 函式庫使用公鑰加密訊息。這保證了只有對應的私鑰才能解密。
私鑰解密: 使用私鑰解密訊息,私鑰安全地儲存在環境變數中。
安全考量:透過使用RSA,我們確保客戶端發送的資料是加密且安全的。

Python(使用 rsa 函式庫)
加密:

import rsa
import base64

def encrypt_with_public_key(message: str, public_key_str: str) -> str:
    public_key = rsa.PublicKey.load_pkcs1_openssl_pem(public_key_str.encode())
    encrypted_message = rsa.encrypt(message.encode(), public_key)
    return base64.b64encode(encrypted_message).decode()

解密:

import rsa
import base64

def decrypt_with_private_key(encrypted_message: str, private_key_str: str) -> str:
    private_key = rsa.PrivateKey.load_pkcs1(private_key_str.encode())
    encrypted_bytes = base64.b64decode(encrypted_message.encode())
    decrypted_message = rsa.decrypt(encrypted_bytes, private_key)
    return decrypted_message.decode()

解釋:

公鑰加密: 使用公鑰對訊息進行加密,確保只有預期的私鑰持有者才能解密它。
Base64編碼:加密後,對訊息進行Base64編碼,以確保與文字傳輸的兼容性。
私鑰解密:私鑰用於解密Base64編碼的加密訊息,確保機密性。

PHP(使用 OpenSSL)
加密:

function encrypt_with_public_key($message) {
    $publicKey = getenv('PUBLIC_KEY');
    openssl_public_encrypt($message, $encrypted, $publicKey);
    return base64_encode($encrypted);
}

解密:

function decrypt_with_private_key($encryptedMessage) {
    $privateKey = getenv('PRIVATE_KEY');
    $encryptedData = base64_decode($encryptedMessage);
    openssl_private_decrypt($encryptedData, $decrypted, $privateKey);
    return $decrypted;
}

解釋:

公鑰加密: openssl_public_encrypt 函式使用公鑰對訊息進行加密,確保只有私鑰才能解密。
私鑰解密: openssl_private_decrypt 函式使用私鑰解密訊息,確保敏感資訊的安全。
環境變數:公鑰和私鑰都安全地儲存在環境變數中,增強安全性。

加密最佳實踐

使用環境變數:始終將密鑰儲存在環境變數中,而不是將它們硬編碼到應用程式中。這降低了暴露敏感資訊的風險。
加密敏感資料:加密個人和敏感數據,例如密碼、財務詳細資料或個人識別資訊 (PII),以防止未經授權的存取。
使用 HTTPS: 確保您的應用程式透過 HTTPS 進行通信,以保護傳輸中的資料。
安全金鑰管理:定期輪換加密金鑰並確保它們安全儲存。

為什麼選擇RSA加密?

增強資料安全性:RSA加密確保敏感資料在傳輸過程中保持安全,防止未經授權的存取。
非對稱加密: RSA 使用公鑰進行加密,使用私鑰進行解密,從而確保私鑰永遠不需要共用。
跨平台相容性: RSA 可以跨不同平台和程式語言無縫運作,使其成為客戶端和伺服器端使用不同技術的 Web 應用程式的理想選擇。

結論

RSA 加密提供了一種跨多個程式設計環境保護敏感資料的可靠方法。透過在 JavaScript、Python 和 PHP 中實現 RSA 加解密,您可以保護敏感資訊、增強安全性並確保跨平台相容性。無論是為了保護 API 呼叫、保護使用者資料或確保訊息的機密性,RSA 都提供了強大的加密解決方案。

如果您發現本指南有幫助,請考慮與其他開發人員分享,並繼續關注有關加密和資料安全的更多見解!

加密 #RSA #Cyber​​Security #DataSecurity #WebDevelopment #CrossPlatformSecurity #JavaScript #Python #PHP

版本聲明 本文轉載於:https://dev.to/shubhamkhan/securing-data-with-rsa-encryption-and-decryption-across-platforms-30d7?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 如何使用 PHP 和 MySQL 以印地語儲存和顯示 Unicode 字串?
    如何使用 PHP 和 MySQL 以印地語儲存和顯示 Unicode 字串?
    使用PHP 和MySQL 儲存和顯示Unicode 字串(हिन्दी)嘗試儲存和顯示Unicode 字串時,您可能會遇到挑戰,特別是在印地語等語言中,由於編碼問題。為了解決這些問題,必須在資料庫和 PHP 腳本中設定適當的字元編碼和排序規則。 資料庫配置對於 MySQL資料庫,將資料庫和資料表編碼...
    程式設計 發佈於2024-11-08
  • 如何在 PHP 中將 UTF-8 字元轉換為 ISO-8859-1 並返回?
    如何在 PHP 中將 UTF-8 字元轉換為 ISO-8859-1 並返回?
    將UTF-8 字元轉換為ISO-88591 並傳回PHP當使用使用不同編碼的多個腳本時,需要在字元集之間進行轉換。其中一種轉換涉及將 UTF-8 字元轉換為 ISO-88591,反之亦然。 儘管存在 utf_encode() 和 _decode(),但將 UTF-8 直接轉換為 ISO-88591 ...
    程式設計 發佈於2024-11-08
  • 以下是一些標題選項,使用問題格式,重點關注文章中提出的挑戰和解決方案:

選項 1(直接且簡潔):
* 如何避免 Angul 中的模板標籤衝突
    以下是一些標題選項,使用問題格式,重點關注文章中提出的挑戰和解決方案: 選項 1(直接且簡潔): * 如何避免 Angul 中的模板標籤衝突
    為AngularJS 和Django 定制模板標籤由於模板標籤衝突,將AngularJS 與Django 集成可能會帶來挑戰,兩者都使用{{}}。為了克服這個問題,需要調整 AngularJS 或 Django 的模板標籤語法。 AngularJS 範本標籤自訂:在 AngularJS 1.0 中,...
    程式設計 發佈於2024-11-08
  • 每個開發人員都應該了解的高階 JavaScript 概念
    每個開發人員都應該了解的高階 JavaScript 概念
    JavaScript 是许多开发人员日常使用的语言,但其生态系统中存在许多隐藏的瑰宝,即使是经验丰富的开发人员也可能不熟悉。本文探讨了一些鲜为人知的 JavaScript 概念,它们可以显着提高您的编程技能。我们将介绍 代理、符号、生成器等概念,通过示例演示每个概念并解决问题以说明其强大功能。 最...
    程式設計 發佈於2024-11-08
  • 直接用mysqli_函數取代mysql_函數會帶來挑戰嗎?
    直接用mysqli_函數取代mysql_函數會帶來挑戰嗎?
    盲目地用 mysqli_ 取代 mysql_ 函數會導致問題嗎? 將程式碼庫更新到 PHP 7 需要將已棄用的 mysql_ 函數替換為 mysqli_ 對應函數。然而,一個常見的誤解是您可以直接進行全面替換。 答案:不,事情沒那麼簡單雖然函數名稱可能會出現類似地,與 mysql_ 相比,mysql...
    程式設計 發佈於2024-11-08
  • 為什麼 `malloc()` 在 C++ 中會導致「無效轉換」錯誤?
    為什麼 `malloc()` 在 C++ 中會導致「無效轉換」錯誤?
    Malloc 分配問題:了解「無效轉換」錯誤提供的程式碼在嘗試使用malloc 分配記憶體時引入了一個常見問題( )。此錯誤源自於將 malloc() 的回傳值直接指派給 char 指標而沒有進行正確的轉換。 malloc() 函數在堆中保留一塊記憶體並傳回一個通用的 void 指標。但是,程式碼將...
    程式設計 發佈於2024-11-08
  • 如何在 Zend Framework 中確定客戶端的時區?
    如何在 Zend Framework 中確定客戶端的時區?
    客戶端時區確定確定客戶端時區對於時間敏感的應用程式至關重要。這個問題探討如何在 Zend Framework 中取得此資訊。 以秒偏移量形式檢索時區取得時區的首選方法是作為 UTC 的秒數。例如,俄羅斯莫斯科將返回 36060,而英國倫敦將返回 0。 建議的解決方案建議的解決方案涉及利用jQuery...
    程式設計 發佈於2024-11-08
  • 如何使用 React 建立通知功能
    如何使用 React 建立通知功能
    Hello everyone ?? In today's tutorial, we'll guide you through building a real-time notifications feature using SuperViz, a powerful platform for rea...
    程式設計 發佈於2024-11-08
  • 了解命令式程式設計和聲明式程式設計之間的區別
    了解命令式程式設計和聲明式程式設計之間的區別
    當我剛開始學習React時,我的老師說:「JavaScript是命令式編程,而React是聲明式編程。」然而,一開始這對我來說不太有意義。因此,我決定將其分解以更好地理解其中的差異。 將命令式和聲明式程式設計與披薩進行比較? 為了更容易理解,讓我們來比較一下這兩種烹飪方法。 ...
    程式設計 發佈於2024-11-08
  • 如何使用 JPA 和 Hibernate 以 UTC 格式儲存日期/時間和時間戳記?
    如何使用 JPA 和 Hibernate 以 UTC 格式儲存日期/時間和時間戳記?
    使用JPA 和Hibernate 以UTC 格式儲存日期/時間和時間戳在Java Persistence API (JPA) 和Hibernate 中,管理日期/時間不同時區的時間戳值可能是一個挑戰。為了確保 UTC(協調世界時)時間的一致儲存和檢索,正確配置框架至關重要。 考慮提供的附註解的 JP...
    程式設計 發佈於2024-11-08
  • java.lang.RuntimeException 和 java.lang.Exception 之間的主要區別是什麼?
    java.lang.RuntimeException 和 java.lang.Exception 之間的主要區別是什麼?
    揭示java.lang.RuntimeException 和java.lang.Exception 的獨特本質在Java 異常領域內,兩個經常遇到的異常類別出現:java.lang.RuntimeException 和java.lang.Exception。為了有效地理解異常處理的複雜性,剖析它們之...
    程式設計 發佈於2024-11-08
  • 為什麼嵌入框陰影在透明背景的圖片上消失?
    為什麼嵌入框陰影在透明背景的圖片上消失?
    了解圖像上的插入框陰影問題在網頁設計中,使用插入框陰影在元素內創建深度和尺寸是一種常見技術。然而,在處理包含圖像的容器時,事情並不總是那麼簡單。當嵌入框陰影似乎在嵌入影像上消失時,就會出現問題。 隱形陰影的情況考慮原始問題中提供的範例:body { background-color: #0000...
    程式設計 發佈於2024-11-08
  • 如何在 ReactJS 中維護懸停狀態:解決事件註冊問題
    如何在 ReactJS 中維護懸停狀態:解決事件註冊問題
    在ReactJS 中維護懸停狀態:解決事件註冊問題使用內聯樣式時,您會遇到ReactJS 中懸停和活動事件的問題,因為onMouseEnter 和onMouseLeave 方法被證明是不可靠的。 要解決此問題,請考慮使用下列事件處理程序之一:onMouseDownonMouseEnter onMou...
    程式設計 發佈於2024-11-08
  • 如何在 JavaScript 中準確檢查 Null 值和空字串?
    如何在 JavaScript 中準確檢查 Null 值和空字串?
    檢查 JavaScript 中的 Null 值在 JavaScript 中,確定值是否為 null 有時會令人困惑。為了提供更深入的理解,本文將深入研究在 JavaScript 情境中偵測空值的細節。 檢查空值提供的程式碼片段旨在檢查跨多個變數的null 值:if (pass == null || ...
    程式設計 發佈於2024-11-08
  • 在 Golang 中建立 Google Drive 下載器(第 1 部分)
    在 Golang 中建立 Google Drive 下載器(第 1 部分)
    介绍 在本教程中,我们将构建一个功能强大的下载器,允许从Google Drive和其他云提供商下载文件。借助 Golang 高效的并发模式,您将能够同时管理多个下载、流式传输大文件并实时跟踪进度。无论您是下载一些小文件还是处理大型数据集,该项目都将展示如何构建可扩展且强大的下载器,...
    程式設計 發佈於2024-11-08

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3