`

【加密解密】恺撒加密(Javascript实现)

阅读更多

恺撒加密(Caesar cipher),是一种最简单且最广为人知的替换加密技术。明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。

例如,当偏移量是3的时候,所有的字母A将被替换成D,B变成E,以此类推。

当年恺撒曾用此方法与其将军们进行联系。

 

当偏移量是左移3的时候(解密时的密钥就是3):

明文字母表:ABCDEFGHIJKLMNOPQRSTUVWXYZ

密文字母表:DEFGHIJKLMNOPQRSTUVWXYZABC

 

使用时,加密者查找明文字母表中需要加密的消息中的每一个字母所在位置,并且写下密文字母表中对应的字母。需要解密的人则根据事先已知的密钥反过来操作,得到原来的明文。例如:

明文:THE QUICK BROWN FOX JUMPS OVER THE LAZY DOG

密文:WKH TXLFN EURZQ IRA MXPSV RYHU WKH ODCB GRJ

恺撒密码的加密、解密方法还能够通过同余的数学方法进行计算。

 

    使用凯撒密码(偏移3)加解密
    <scriptlanguage="JavaScript">

    // encrypt using Caesar
    functiondo_encrypt() {
        var key   = document.cipher.offset.value;
        // console.log(key);
        var plain = document.cipher.plain.value;
        var ctext = "";

        // do the encoding
        for( var i = 0; i < plain.length; i ++ ) {
            var pcode = plain.charCodeAt( i );
            var ccode = pcode;
            if ( pcode >= 65 && pcode <= 90 ) {
                ccode = ( ( pcode - 65 ) + key * 1 ) % 26 + 65;
            }
            if ( pcode >= 97 && pcode <= 122 ) {
                ccode = ( ( pcode - 97 ) + key * 1 ) %26 + 97;
            }
            // console.log(pcode + "," + ccode);
            ctext += String.fromCharCode(ccode);
        }

        document.cipher.enc.value = ctext;
    }

    functiondo_decrypt() {
        var key   = document.cipher.offset.value;
        // console.log(key);
        var ctext = document.cipher.enc.value;
        var plain = "";

        // do the encoding
        for( var i = 0; i < ctext.length; i ++ ) {
            var ccode = ctext.charCodeAt( i );
            var pcode = ccode;
            if ( ccode >= 65 && ccode <= 90 ) {
                pcode = ( ( ccode - 65 ) - key * 1 +26 ) % 26 + 65;
            }
            if ( ccode >= 97 && ccode <= 122 ) {
                pcode = ( ( ccode - 97 ) - key * 1 + 26) % 26 + 97;
            }
            // console.log(ccode + "," + pcode);
            plain += String.fromCharCode(pcode);
        }
        // console.log(-3 % 26);

        document.cipher.plain.value = plain;
    }
    </script>

    <formname="cipher">
        <table>
            <tr><td>偏移:</td><td><inputtype="text"name="offset"size=5value=3></td></tr>
            <tr><td>明文:</td><td><inputtype="text"name="plain"size=50value="This is a test."></td></tr>
            <tr><td>密文:</td><td><inputtype="text"name="enc"size=50></td></tr>
        </table>
    <inputtype="button"value="加密"onClick="do_encrypt()">&nbsp;
    <inputtype="button"value="解密"onClick="do_decrypt()">
    </form>

 

 

  • 大小: 9.4 KB
分享到:
评论

相关推荐

    java和javascript之间的DES加密解密

    下面将详细阐述DES加密解密的基本原理、Java和JavaScript的实现方式以及如何在两者之间进行互操作。 1. **DES加密算法**: DES是一种分组密码,使用64位的数据块和56位的密钥进行操作。它通过一系列复杂的数学变换...

    Qt实现AES加密解密

    在Qt中,我们可以利用QCryptographicHash、QByteArray和QBuffer等类来实现AES加密和解密。 1. **AES加密算法**: AES有三种不同的密钥长度,即128位(AES_128)、192位(AES_192)和256位(AES_256)。这些长度的选择直接...

    AES实现前端JS和后端java加密解密

    在本文中,我们将深入探讨如何在前端JavaScript和后端Java中实现AES的加密与解密。 前端JavaScript实现AES加密: 1. **引入库**:前端通常会使用如CryptoJS这样的JavaScript库来实现AES加密。CryptoJS是一个开放...

    C#加密解密DeEncryptHelper.zip

    DES加密/解密类。 加密 加密数据 解密 解密数据 得到随机安全码(哈希加密)。 得到随机哈希加密字符串 哈希加密一个字符串 RSA加密解密及RSA签名和验证 RSA 的密钥产生 产生私钥 和公钥 RSA 方式加密 RSA的解密...

    java实现文件加密解密

    "java实现文件加密解密" Java 实现文件的加密与解密是指利用 Java 语言将资源文件(包括图片、动画等类型)进行简单的加密和解密。这种策略的原因和好处是将准备好的资源存储在云上,使用时通过网络进行读取即可,...

    用 MFC 实现 DES 加密解密算法

    本文将深入探讨如何使用MFC(Microsoft Foundation Classes)库实现DES(Data Encryption Standard)加密解密算法,以及如何支持文件的打开和保存操作。 DES是一种对称加密算法,由IBM在1970年代开发,并在1977年被...

    易飞用户加密解密

    《易飞用户加密解密详解》 在信息技术领域,数据安全是至关重要的议题,而用户加密解密技术正是保障信息安全的重要手段。本文将围绕“易飞用户加密解密”这一主题,深入探讨其原理、应用及操作流程,帮助读者更好地...

    C# RSA加密解密

    本篇文章将深入探讨C#如何实现RSA加密解密,并结合Winform界面进行演示。 **1. RSA算法基础** RSA算法基于数论原理,包括大数因子分解的困难性。它包含两个密钥:公钥和私钥。公钥可以公开,用于加密;私钥必须...

    MFC实现DES加密解密实现

    在这个项目中,我们将探讨如何使用MFC在VC++环境中实现DES加密和解密。 首先,DES是一种块加密算法,它将明文数据分为64位的块进行处理。但是,由于其中7位是奇偶校验位,实际有效密钥长度为56位。DES通过一系列...

    脚本加密解密器脚本加密解密器

    在IT行业中,脚本加密与解密是一项关键的技术,尤其对于保护源代码、防止未授权访问和盗用来说至关重要。脚本加密解密器是一种工具,它的主要功能是将...而选择合适的加密解密器,并正确使用,是实现这一目标的关键。

    维吉尼亚加密解密C++实现

    维吉尼亚加密解密C++实现:深入解析与优化建议 一、维吉尼亚加密算法原理 维吉尼亚加密算法是一种多字母表替换密码技术,它通过使用一系列交错的凯撒密码来加密文本,从而提高了密码的安全性。该算法的核心在于...

    C++实现密码学 RSA加密解密算法

    "C++实现密码学 RSA加密解密算法" RSA加密解密算法是密码学中一种常用的加密算法,以 Ron Rivest、Adi Shamir 和 Leonard Adleman 三人命名。该算法基于大数分解问题的困难性,使用公钥加密和私钥解密的方式来保护...

    python实现AES加密解密

    本文实例为大家分享了python实现AES加密解密的具体代码,供大家参考,具体内容如下 (1)对于AES加密解密相关知识 (2)实现的功能就是输入0-16个字符,然后经过AES的加密解密最后可以得到原先的输入,运行的结果...

    C# .net MD5加密解密工具及加密解密类

    C# .net MD5加密解密工具及加密解密类。使用方便,可直接下载加密解密代码在项目中使用。

    MFC 实现文本文件加密解密

    在这个特定的案例中,"MFC实现文本文件加密解密"是一个使用MFC框架编写的程序,它允许用户对文本文件进行加密和解密操作,确保敏感数据在传输或存储时的安全性。 在VC2010环境下,开发者通常会利用MFC的类库,如...

    php实现的加密解密处理类.zip

    这个“php实现的加密解密处理类”压缩包文件提供了一个专门用于加密和解密操作的PHP类库,使得开发人员能够更方便、安全地处理这些关键信息。下面将详细探讨相关的知识点。 首先,我们来了解一下加密的基本概念。...

    用C语言实现的AES加密解密算法

    在本项目中,"用C语言实现的AES加密解密算法"是针对AES算法的一种C语言实现,这允许开发者在不依赖特定库的情况下,在C环境中进行数据的加密和解密操作。 首先,我们需要理解AES的工作原理。AES的核心是基于替换和...

    VB.NET实现AES加密解密

    VB.NET实现AES加密解密代码,可直接使用

    Javascript 加密解密 CryptoJS

    JavaScript加密解密库CryptoJS是开发人员在Web应用中实现安全数据处理的常用工具,尤其在需要保护用户敏感信息如密码、API密钥等场景下。这个库支持多种加密算法,包括对称加密(如AES、DES)、非对称加密(如RSA)...

    c#加密解密加密解密加密解密加密解密加密解密

    c#加密解密加密解密加密解密加密解密加密解密c#加密解密加密解密加密解密加密解密加密解密

Global site tag (gtag.js) - Google Analytics