Asymmetric Signature SHA256withRSA Menggunakan Python

Subscribe Dengan Account Google Untuk Membaca Artikel Tanpa Iklan
Asymmetric Signature SHA256withRSA Menggunakan Python

Di tutorial ini kita belajar cara membuat enkripsi menggunakan python.

Enkripsi yang akan kita pelajari adalah Asymmetric Signature SHA256withRSA , ini merupakan standar dari enkripsi RSA.

Enkripsi ini merupakan enkripsi standar yang digunakan dalam Standar Nasional Open API Pembayaran atau sering disebut dengan SNAP.

SNAP merupakan standard pembayaran yang dikeluarkan oleh Bank Indonesia.

Untuk mengikuti tutorial ini Anda perlu menginstall library pycryptodome menggunakan pip.

pip install pycryptodome

A. Generate RSA




from Crypto.PublicKey import RSA


key = RSA.generate(2048)
privateKey = key.exportKey()
publicKey = key.publickey().exportKey()


B. Asymmetric Signature SHA256withRSA



from Crypto.Hash import SHA256
from Crypto.PublicKey import RSA
from Crypto.Signature import PKCS1_v1_5
import base64



secretKey = "Bulan-Purnama-Di-kota-Malang"


a) Signature Function

Dibagian ini kita membuat script untuk signature :

def sign():
digest = SHA256.new(bytes(secretKey, 'utf-8'))
private_key = RSA.importKey(privateKey)
signature = PKCS1_v1_5.new(private_key).sign(digest)
signature = base64.b64encode(signature).decode()
return signature

 

b) Signature Verification

Dibagian ini kita membuat script untuk memverifikasi signature yang dibuat di fungsi sign

def verifyKey(signature):
try:
signatureDecodeb64 = base64.b64decode(signature)
digest = SHA256.new(bytes(secretKey, 'utf-8'))
public_key = RSA.importKey(publicKey)
verifier = PKCS1_v1_5.new(public_key)
verified = verifier.verify(digest, signatureDecodeb64)
print(verified)
except Exception as e:
print(str(e))

C. Vidio Tutorial



Baca artikel lainya:


  1. Hello world, membangun microservice dengan FastAPI

  2. FastAPI APIRouter, Membangun microservice dngan FastAPI

  3. Mini Wallet Bagian 1 - Django Template dan Static File

  4. Mini Wallet Bagian 2 - Django Template Base HTML

  5. Mini Wallet Bagian 3 - Dajngo Model dan Koneksi Database MySQL

  6. Tutorial bassic Mysql bagian 1 - Create Read Update Delete

  7. Tutorial bassic Mysql bagian 2 - Inner, Left, Right, Cross Join

  8. Tutorial bassic Mysql bagian 3 - Filtering Data

  9. Tutorial bassic Mysql bagian 4 - Grouping Data 

  10. Tutorial bassic Mysql bagian 5 - Operator dan Clausa

  11. Tutorial bassic Mysql bagian 6 - Replace Statement

  12. Tutorial bassic Mysql bagian 7 - Constraint Data

  13. Tutorial bassic Mysql bagian 8 - Mengubah Struktur tabel

  14. Tutorial bassic Mysql bagian 9 - Subquery

  15. Tutorial bassic Mysql bagian 10 - Virtual Tabel

  16. Tutorial bassic Mysql bagian 11 - Control Flow Function

  17. Membuat service OTP bagian 1 - OTP dan PIN

  18. Membuat service OTP bagian 2 - Sequence Diagram

  19. Membuat service OTP bagian 3 - Model dan Serializer

  20. Membuat  service OTP bagian 4 - Validate OTP

  21. Membuat  service OTP bagian 5 - Api Client Service

  22. Membuat service user login bagian 1 - Konfigurasi Database

  23. Membuat service user login bagian 2 - Serializer dan JWT

  24. Membuat CRUD service product bagian 1 - Models Product

  25. Membuat CRUD service product bagian 2 - Function Serializer

  26. Membuat CRUD service product bagian 3 - Api Client Service

  27. Membaut CRUD service product bagian 4 - Auth User

  28. Membuat CRUD service product bagian 5 - TDR File Log

  29. Membuat CRUD service product bagian 6 - Unit Test

  30. Membuat service user register bagian 1 - Django

  31. Membuat Service user register bagian 2 - Django

  32. Membuat service filter dan download file CSV di django

  33. Django upload file menggunakan FileSystemStorage