This plugin is deprecated. Feel free to use the nativescript-simple-libsodium
Simple Cross platform 256bit AES encryption / decryption based on Cross-Platform-AES
Note: I am not an expert of neigher iOS nor Android. So, please contribute if you think something you can do better :)
- iOS
- Android
- NodeJS
-
Cross platform support. Encryption-Decryption works across iOS, Android and Node.js.
-
Automatically RandomIV is added while encryption and remove first randomized blocks while decryption.
-
Support for Random IV (initialization vector) for encryption and decryption. Randomization is crucial for encryption schemes to achieve semantic security, a property whereby repeated usage of the scheme under the same key does not allow an attacker to infer relationships between segments of the encrypted message.
-
Support for SHA-256 for hashing the key. Never use plain text as encryption key. Always hash the plain text key and then use for encryption. AES permits the use of 256-bit keys. Breaking a symmetric 256-bit key by brute force requires 2^128 times more computational power than a 128-bit key. A device that could check a billion billion (10^18) AES keys per second would in theory require about 3×10^51 years to exhaust the 256-bit key space.
tns plugin add nativescript-crossplatform-aes
import { CrossPlatformAES } from 'nativescript-crossplatform-aes';
let cryptLib = new CrossPlatformAES();
let plainText = "this is my plain text"
let key = "your key"
let cipherText = cryptLib.encryptPlainTextWithRandomIV(plainText, key);
console.log(cipherText);
let decryptedString = cryptLib.decryptCipherTextWithRandomIV(cipherText, key)
console.log(decryptedString);
encryptPlainTextWithSuppliedIV(plainText: string, key: string, iv: string);
decryptCipherTextWithSuppliedIV(cipherText: string, key: string, iv: string);
generateRandomIV16();
Install the library
npm install @skavinvarnan/cryptlib --save
Then use it
const cryptLib = require('@skavinvarnan/cryptlib');
const plainText = "this is my plain text";
const key = "your key";
const cipherText = cryptLib.encryptPlainTextWithRandomIV(plainText, key);
console.log('cipherText %s', cipherText);
const decryptedString = cryptLib.decryptCipherTextWithRandomIV(cipherText, key);
console.log('decryptedString %s', decryptedString);