Instantly share code, notes, and snippets.

Embed
What would you like to do?
List of JavaScript Crypto libraries.

JavaScript Crypto Libraries

I start with a list and plan to create a comparison table.

WebCryptoAPI

http://www.w3.org/TR/WebCryptoAPI/

This specification describes a JavaScript API for performing basic cryptographic operations in web applications, such as hashing, signature generation and verification, and encryption and decryption. Additionally, it describes an API for applications to generate and/or manage the keying material necessary to perform these operations. Uses for this API range from user or service authentication, document or code signing, and the confidentiality and integrity of communications.

  • W3C Working Draft 25 June 2013

sjcl

http://bitwiseshiftleft.github.io/sjcl/

Stanford Javascript Crypto Library

js-nacl

https://github.com/tonyg/js-nacl

Emscripten-compiled Javascript version of NaCl, the Networking and Cryptography library.

jsbn

http://www-cs-students.stanford.edu/~tjw/jsbn/

RSA and ECC in JavaScript

  • Version 1.4 (7/1/2013)

ursa

https://github.com/Obvious/ursa

RSA public/private key crypto for Node.

jsencrypt

https://github.com/travist/jsencrypt

Provides a simple wrapper around the fantastic work done by Tom Wu for RSA Encryption for JavaScript.

OpenPGP.js

https://github.com/openpgpjs/openpgpjs

OpenPGP implementation for JavaScript

jwcrypto

https://github.com/mozilla/jwcrypto

JavaScript implementation of JSON Web Signatures, JSON Web Tokens, and JSON Web Certificates

cryptico

https://github.com/wwwtyro/cryptico

An easy-to-use encryption system utilizing RSA and AES for javascript.

pidCrypt

https://www.pidder.de/pidcrypt/?start

a JavaScript crypto library

forge

https://github.com/digitalbazaar/forge

A native implementation of TLS in Javascript and tools to write crypto-based and network-heavy webapps

  • based on jsbn

CryptoJS

http://code.google.com/p/crypto-js/

JavaScript implementations of standard and secure cryptographic algorithms

crypto

http://ats.oka.nu/titaniumcore/js/crypto/readme.txt

JavaScript Cryptography Toolkit

This library is an object oriented cryptography toolkit that implements several fundamental cryptographic algorithms including TWOFISH, SERPENT, RIJNDAEL, RSA with key-generation and SHA(SHA-1,224,256,384,512) for JavaScript. This library works in ActionScript as well. The unique feature of this library is asynchronous processing. A heavyweight process such as 4096bit RSA key generation will be done asynchronously so that this library does not cause problems such as freezing browsers, "slow-downing" warning dialogs, etc.

  • asynchronous RSA key generation
  • based on jsbn

jscrypto

http://code.google.com/p/jscryptolib/

A JavaScript Cryptography Library

This library is an object oriented cryptography library that implements several fundamental cryptographic algorithms including AES, SHA-1, HMAC, BASE64, RSA, ECC and IBE for JavaScript. This library works in ActionScript as well.

Cifre

https://github.com/openpeer/cifre

Cifre is a fast crypto toolkit for modern client-side JavaScript. This is done by taking the best crypto code for js on the net and updating it to use modern technologies. There are plans to collaborate with the forge project.

  • MIT License
  • 2013-07-30 14:09:58

PolyCrypt

http://polycrypt.net/

A WebCrypto Polyfill

FoxyCrypt

https://github.com/polycrypt/foxycrypt

A Firefox extension for the Web Cryptography API

cryptojs

http://cryptojs.altervista.org/

JavaScript Cryptography

  • Last modified: - 09/05/2012
@rmhrisk

This comment has been minimized.

Show comment
Hide comment
@rmhrisk

rmhrisk commented Mar 1, 2016

@lpetrov

This comment has been minimized.

Show comment
Hide comment
@lpetrov

lpetrov commented Mar 1, 2016

@Duskfall

This comment has been minimized.

Show comment
Hide comment
@Duskfall

Duskfall Mar 10, 2016

Imho asmcrypto is the best right now. Tested AES functions

Duskfall commented Mar 10, 2016

Imho asmcrypto is the best right now. Tested AES functions

@vikeri

This comment has been minimized.

Show comment
Hide comment
@PythonNut

This comment has been minimized.

Show comment
Hide comment
@PythonNut

PythonNut commented May 29, 2016

Also libsodium.js.

@maxnis

This comment has been minimized.

Show comment
Hide comment
@maxnis

maxnis Jan 6, 2017

One more to the list:
Clipperz

maxnis commented Jan 6, 2017

One more to the list:
Clipperz

@namomo

This comment has been minimized.

Show comment
Hide comment

namomo commented Apr 13, 2017

@wal-de-marlad

This comment has been minimized.

Show comment
Hide comment
@wal-de-marlad

wal-de-marlad commented May 30, 2017

IMO this is best one: WebCrypto GOST Library

@yonjah

This comment has been minimized.

Show comment
Hide comment
@yonjah

yonjah May 31, 2017

@wal-de-marlad what makes you think that ?
And what does it even mean best one ?
Is it the most audited implementation ? Does it uses a recommended algorithms ? Does it have the simplest API ?
(Having only one contributor and using some semi secret Russian algo similar to DES I would be surprised if it won't be one of the least recommended library out of the list provided here)

SJCL Is probably the only js library that was actually created by cryptography professionals.
Don't know if it makes it the "best" but I wouldn't consider using any other 3rd party library in anything important

yonjah commented May 31, 2017

@wal-de-marlad what makes you think that ?
And what does it even mean best one ?
Is it the most audited implementation ? Does it uses a recommended algorithms ? Does it have the simplest API ?
(Having only one contributor and using some semi secret Russian algo similar to DES I would be surprised if it won't be one of the least recommended library out of the list provided here)

SJCL Is probably the only js library that was actually created by cryptography professionals.
Don't know if it makes it the "best" but I wouldn't consider using any other 3rd party library in anything important

@AlessandroBudroni

This comment has been minimized.

Show comment
Hide comment
@AlessandroBudroni

AlessandroBudroni commented Jul 2, 2017

There is also milagro-crypto-js.

@gabrielizalo

This comment has been minimized.

Show comment
Hide comment
@gabrielizalo

gabrielizalo Jul 17, 2017

I have created a Repo with this info so people can help easily.
Also the list has a new format that I think will help us to compare the different options easily: JavaScript Crypto Libraries
Comments, missing libs and pull requests more than welcome.

gabrielizalo commented Jul 17, 2017

I have created a Repo with this info so people can help easily.
Also the list has a new format that I think will help us to compare the different options easily: JavaScript Crypto Libraries
Comments, missing libs and pull requests more than welcome.

@Tectract

This comment has been minimized.

Show comment
Hide comment
@Tectract

Tectract Sep 29, 2017

Can anyone point me to actual security analysis on any of these crypto libraries? HOW SECURE are they? Which ones have been cracked? How secure are these libraries to things like cache timing attacks? Which are considered the best, and why? How do they compare to the new W3C WebCrypto API? I think any libraries that haven't passed strong security testing should be relisted on this page under a DO NOT USE list.

I'm actually trying to move away from SJCL because the maintainer has abandoned the project and it doesn't play well with CommonJS require statements under some architectures. I looked for security analysis of SJCL and I couldn't find any, other than an offhand mention of a known vulnerability to cache timing attacks. Why do people trust crypto-js? Because the authors at Google would never do evil? They don't even host the code anymore, and the docs are minimal to say the least.

Tectract commented Sep 29, 2017

Can anyone point me to actual security analysis on any of these crypto libraries? HOW SECURE are they? Which ones have been cracked? How secure are these libraries to things like cache timing attacks? Which are considered the best, and why? How do they compare to the new W3C WebCrypto API? I think any libraries that haven't passed strong security testing should be relisted on this page under a DO NOT USE list.

I'm actually trying to move away from SJCL because the maintainer has abandoned the project and it doesn't play well with CommonJS require statements under some architectures. I looked for security analysis of SJCL and I couldn't find any, other than an offhand mention of a known vulnerability to cache timing attacks. Why do people trust crypto-js? Because the authors at Google would never do evil? They don't even host the code anymore, and the docs are minimal to say the least.

@gabrielizalo

This comment has been minimized.

Show comment
Hide comment
@gabrielizalo

gabrielizalo Oct 24, 2017

@Tectract Sorry but there is no such info you request. The SJCL lib is one of the most used with crypto-js and JSEncrypt.
Take a look of a new list I did based in this one, but added some data about the libraries that will help you to evaluate them: JavaScript Crypto Libraries.

gabrielizalo commented Oct 24, 2017

@Tectract Sorry but there is no such info you request. The SJCL lib is one of the most used with crypto-js and JSEncrypt.
Take a look of a new list I did based in this one, but added some data about the libraries that will help you to evaluate them: JavaScript Crypto Libraries.

@mnasyrov

This comment has been minimized.

Show comment
Hide comment
@mnasyrov

mnasyrov Dec 6, 2017

I want to share with CryptoBench.js - a benchmark testbed for some crypto libraries: asmcrypto.js, crypto-js, forge, libsodium.js, js-nacl, sjcl and tweetnacl.js.

mnasyrov commented Dec 6, 2017

I want to share with CryptoBench.js - a benchmark testbed for some crypto libraries: asmcrypto.js, crypto-js, forge, libsodium.js, js-nacl, sjcl and tweetnacl.js.

@jastam

This comment has been minimized.

Show comment
Hide comment
@jastam

jastam commented Jan 30, 2018

How about jsrsasign?

@blockafrik

This comment has been minimized.

Show comment
Hide comment
@blockafrik

blockafrik Mar 22, 2018

Can i get a library which implement RSA. Has a method that get secret and generate keypair and it simply implement encryption, decryption, signing and verifying

blockafrik commented Mar 22, 2018

Can i get a library which implement RSA. Has a method that get secret and generate keypair and it simply implement encryption, decryption, signing and verifying

@Rockbass

This comment has been minimized.

Show comment
Hide comment
@Rockbass

Rockbass Apr 5, 2018

Hi guys
Could you please advice some library to generate ECDSA keypair in browser which could be suitable for using with web3 (ethereum) on backend? I've tried with jsrasign but failed - web3 was not satisfied by results.

Rockbass commented Apr 5, 2018

Hi guys
Could you please advice some library to generate ECDSA keypair in browser which could be suitable for using with web3 (ethereum) on backend? I've tried with jsrasign but failed - web3 was not satisfied by results.

@fcorella

This comment has been minimized.

Show comment
Hide comment
@fcorella

fcorella Apr 14, 2018

The recently released PJCL may be the only JS crypto library that provides DSA and comes with sample code for implementing cryptographic authentication in web apps as explained in this blog post.

fcorella commented Apr 14, 2018

The recently released PJCL may be the only JS crypto library that provides DSA and comes with sample code for implementing cryptographic authentication in web apps as explained in this blog post.

@bkniffler

This comment has been minimized.

Show comment
Hide comment
@bkniffler

bkniffler Aug 21, 2018

@fcorella
PJCL looks interesting, but why isn't the code hosted on Github? Why isn't there a commonly used license? Where is the issue tracking? Why doesn't the example have a package.json so I can install the dependencies? I think a lot of people might be turned off by those things.

bkniffler commented Aug 21, 2018

@fcorella
PJCL looks interesting, but why isn't the code hosted on Github? Why isn't there a commonly used license? Where is the issue tracking? Why doesn't the example have a package.json so I can install the dependencies? I think a lot of people might be turned off by those things.

@developeranirudhprabhu

This comment has been minimized.

Show comment
Hide comment
@developeranirudhprabhu

developeranirudhprabhu Sep 23, 2018

Is there any means by which while using RSA I can encrypt data with Private key (or assume I receive data which is encrypted using private key) and I decrypt using Public key.
Any help would be appreciated

developeranirudhprabhu commented Sep 23, 2018

Is there any means by which while using RSA I can encrypt data with Private key (or assume I receive data which is encrypted using private key) and I decrypt using Public key.
Any help would be appreciated

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment