mirror of
https://github.com/Sevichecc/Urara-Blog.git
synced 2025-04-30 15:59:33 +08:00
116 lines
3.8 KiB
Markdown
116 lines
3.8 KiB
Markdown
---
|
||
title: JavaScript · Caesar Cipher 凯撒加密
|
||
summary: 用JavaScrpit编码实现凯撒加密算法
|
||
created: 2022-03-08T16:01:08.850Z
|
||
tags:
|
||
- JavaScript
|
||
categories:
|
||
- JavaScript
|
||
lastmod: 2022-04-07T07:20:47.694Z
|
||
---
|
||
|
||
## 题目
|
||
|
||
来源:[操作字符串对象 | 百度前端技术学园](http://ife.baidu.com/javascript/string.html#%E5%AD%97%E7%AC%A6%E4%B8%B2)
|
||
|
||
编码实现凯撒加密算法,根据输入的偏移量,实现对字符串的加密和解密.
|
||
|
||
恺撒加密(Caesar cipher),是一种最简单且最广为人知的替换加密技术。明文中的所有字母都在字母表上向后(或向前)按照一个固定数目进行偏移后被替换成密文。
|
||
|
||
例如,当偏移量是 3 的时候,所有的字母 A 将被替换成 D,B 变成 E,以此类推。
|
||
|
||
**需求说明**
|
||
|
||
- 点击加密按钮,根据用户输入的偏移量,对明文进行加密,加密后的为密文,显示在密文输入框中
|
||
- 点击解密按钮,根据用户输入的偏移量,对密文进行加密,解密出来的为明文,显示在明文输入框中
|
||
|
||
## 解法
|
||
|
||
- `string.replace` 替换数字
|
||
- 用`.charCodeAt()` 获取字母编码
|
||
- 正则表达式`/[A-Za-z]/g`选择字母
|
||
- 偏移量超过范围的,往反方向偏移
|
||
- 结果验证:[凯撒密码加密/解密 - 一个工具箱 ](http://www.atoolbox.net/Tool.php?Id=778)
|
||
|
||
### HTML
|
||
|
||
```html
|
||
<label>偏移:</label>
|
||
<input type="text" name="offset" size="5" value="3" />
|
||
<br />
|
||
<label>
|
||
明文:
|
||
<label></label>
|
||
<input type="text" name="plain" size="50" value="This is a test." />
|
||
<br />
|
||
<label>密文:</label>
|
||
<input type="text" name="enc" size="50" />
|
||
<br />
|
||
<input type="button" value="加密" onClick="encrypt()" />
|
||
|
||
<input type="button" value="解密" onClick="decrypt()" />
|
||
</label>
|
||
```
|
||
|
||
### JS
|
||
|
||
```js
|
||
let offsetInput = document.querySelector('input[name=offset]')
|
||
let plain = document.querySelector('input[name=plain')
|
||
let enc = document.querySelector('input[name=enc]')
|
||
|
||
// 加密
|
||
function encrypt() {
|
||
let offset = Number(offsetInput.value)
|
||
function conver(s) {
|
||
let charCode = s.charCodeAt(0)
|
||
// 替换大写字母 A-Z:65-90
|
||
if (charCode <= 90 && charCode >= 65) {
|
||
return String.fromCharCode(charCode + offset < 90 ? charCode + offset : charCode - offset)
|
||
} else {
|
||
//替换小写字母 a-z:97-122
|
||
return String.fromCharCode(charCode + offset < 122 ? charCode + offset : charCode - offset)
|
||
}
|
||
}
|
||
enc.value = plain.value.replace(/[A-Za-z]/g, conver)
|
||
|
||
// 替换大写字母 A-Z:65-90
|
||
// function transUpper(s) {
|
||
// let charCode = s.charCodeAt();
|
||
// return String.fromCharCode(
|
||
// charCode + offset <= 90 ? charCode + offset : charCode - offset
|
||
// );
|
||
// }
|
||
|
||
// //替换小写字母 a-z:97-122
|
||
// function transLower(s) {
|
||
// let charCode = s.charCodeAt();
|
||
// return String.fromCharCode(
|
||
// charCode + offset <= 122 ? charCode + offset : charCode - offset
|
||
// );
|
||
// }
|
||
// let encUpper = plain.replace(/[A-Z]/g, transUpper);
|
||
// enc.value = encUpper.replace(/[a-z]/g, transLower);
|
||
}
|
||
|
||
// 解密
|
||
function decrypt() {
|
||
let offset = Number(offsetInput.value)
|
||
function conver(s) {
|
||
let charCode = s.charCodeAt(0)
|
||
// 替换大写字母 A-Z:65-90
|
||
if (charCode <= 90 && charCode >= 65) {
|
||
return String.fromCharCode(charCode - offset < 65 ? charCode + offset : charCode - offset)
|
||
} else {
|
||
//替换小写字母 a-z:97-122
|
||
return String.fromCharCode(charCode - offset < 97 ? charCode + offset : charCode - offset)
|
||
}
|
||
}
|
||
plain.value = enc.value.replace(/[A-Za-z]/g, conver)
|
||
}
|
||
```
|
||
|
||
## 参考
|
||
|
||
- [凯撒密码 javascript](https://blog.csdn.net/dikanjiang6340/article/details/101264748?utm_relevant_index=1)
|
||
- [Caesar Cipher in Javascript - Stack Overflow](https://stackoverflow.com/questions/44232645/caesar-cipher-in-javascript?newreg=0a8ff4c05c484b01a7df20821475fb15)
|