A tool to encrypt any static content, and (optionally) create a basic password-protected frontend that can be hosted statically.
Like StatiCrypt but reduced to just the bare minimum code required to get the job done.
See static-encrypt-cli for a Rust CLI companion to this tool.
This tool is inspired by and works similarly to StatiCrypt.
- 
Enter the HTML or any plaintext you want to encrypt into the Content box. 
- 
Enter the password you want to use to encrypt the content into the Password box. Use a long password. 
- 
Press the Encryptbutton.
- 
Either: - Press Download HTML fileto download a ready-to-use web page containing your encrypted content, or
- Copy the string inside the  Encrypted contentbox and integrate it into your own frontend or use case (see next sections)
 
- Press 
The generated HTML file uses document.write() to replace the entire document when the correct password is entered. So you can input arbitrary HTML into the "Content" box to simulate a new page loading in:
- Populate HTML into the "Content" box then encrypt and download the HTML page normally:
- The HTML will be displayed only when the correct password is input:
Both the encrypt and decrypt functions are written in vanilla JavaScript with no dependencies and are provided as standalone files for easy integration. Some example uses are described below:
On the static-encrypt webpage, both the encrypt and decrypt functions are directly accessible in the web browser DevTools console for bulk usage.
Example: encrypt several strings quickly
const contentList = ['Static content 1', 'Static content 2', 'Static content 3', 'Static content 4', 'Static content 5'];
const encryptedContentList = await Promise.all(contentList.map(v => globalThis.encrypt(v, 'correcthorsebatterystaple')));
/*
[
    "LNQ5Afufy7LdgDzA6YT7cvVKh95OP7qGPe25VtcW+u8sFvJFblg6WDoFFWlXWiQ28YCMzr7VKOA9wJnX2uBKvekXG0nU/j+tcAArKA==",
    "iWaofdEYn1etH2ITbVJXn42qpacHO8vvRq0UPr0xEjD7j26zh7ZMT/0O3aXFcru9wcDcHJ1cmvBetLaNWVNzOOsmb0FYiq+Ucmax+A==",
    "pf0KN7JApJxc4gi9erUB84Szp1hdRya5shJiya2G9DscY4ekX9hAQKtBw7jRCIaMX/e3FH7jJG9PJpVzb2h4pF4PMXliBCQV4ypUMA==",
    "IGHUEb4RhwdLnO2KH++gxrlwPBaPPC+13k/m9zg380Y82LAaD0iMASevkdFVnYbAza6Yxji/IwJTacJoOeijvPoP8DCbj4qhd/g+YA==",
    "wEBT/qm0g5hbGYcUyAMOQZwnjHADwuAjKBvDRmw/PcAAEoma0FKuZbZrHjq8z/2IUlzbhMdnLGC91ODfqu+4j3HH7/idKha1BzVK/w=="
]
*/Example: decrypt several strings quickly
await Promise.all(encryptedContentList.map(v => globalThis.decrypt(v, 'correcthorsebatterystaple')));
/*
[
    "Static content 1",
    "Static content 2",
    "Static content 3",
    "Static content 4",
    "Static content 5"
]
*/- Import the decryptfunction provided in/decrypt.js:
import { decrypt } from 'https://cdn.statically.io/gh/ardislu/static-encrypt/master/decrypt.js';- Pass the encrypted content string and the password to the decryptfunction:
const plaintext = await decrypt('ZE33hvS/TCP2pcI0SMp57SHYnxk+mB6u86y0IX9dJJAU7X7d77Wkg4h0iVlcgudL3HKtE8CDx++v90/Ic24Aq0YQgU1zzjuTHg==', 'hunter2');- The decryptfunction will throw an error if the incorrect password is passed, or return the plaintext:
plaintext
// 'Hello, world!'You can also import the function dynamically (useful for lazy-loading or testing in DevTools):
const { decrypt } = await import('https://cdn.statically.io/gh/ardislu/static-encrypt/master/decrypt.js');*.d.ts files are generated from the JSDoc comments using tsc:
tsc --declaration --emitDeclarationOnly --allowJs .\decrypt.js .\encrypt.js
These *.d.ts files allow encrypt and decrypt to be imported in .ts files with typing.
Host the files on any web host configured to serve static files and add a default file extension of .html to plain paths. For example, using local-web-server:
ws --static.extensions html 


