Golang 实现凯撒密码

栏目: Go · 发布时间: 7年前

一.凯撒密码加密代码思路

基本思路:

  1. 设置明文 和 位移步长(秘钥)
  2. 将明文转成小写,准备 明文字节切片 与 密文切片
  3. 循环将每个明文字符 按照 位移步长 做位移,存入密文切片
  4. 返回密文

Golang 实现凯撒密码

  • 导入包
import (
    "fmt"
    "strings" // 包含字符串操作相关方法
)
  • 凯撒密码加密代码
//一、凯撒密码加密
func caesarEn(strRaw string, step byte) string {
    //1.明文 转成 小写
    str_raw := strings.ToLower(strRaw)
    //2.位移步长
    step_move := step
    //3.将字符串 转为 明文字符切片
    str_slice_src := []byte(str_raw)
    fmt.Println("明文字符切片:", str_slice_src)

    //4. 创建 密文字符切片
    str_slice_dst := str_slice_src

    //5.循环明文切片
    for i := 0; i < len(str_slice_src); i++ {
        //6.如果当前循环的明文字符 在位移 范围内,则直接 加上 位移步长 存入 密文字符切片
        if str_slice_src[i] < 123-step_move {
            str_slice_dst[i] = str_slice_src[i] + step_move
        } else { //7.如果 明文字符 超出 范围,则 位移后 步长再减去 26
            str_slice_dst[i] = str_slice_src[i] + step_move - 26
        }
    }
    //8.输出结果
    fmt.Println("加密结果为:", step_move, str_slice_dst, string(str_slice_dst))
    return string(str_slice_dst)
}

二.凯撒密码解密代码思路

基本思路:

  1. 设置密文 和 位移步长
  2. 准备 密文字符切片 与 明文字符切片
  3. 循环将每个 密文字符 按照位移步长 做位移,存入明文切片
  4. 返回明文

Golang 实现凯撒密码

  • 凯撒密码解密代码
//二、凯撒密码解密
func caesarDe(strCipher string, step byte) string {
    //1.明文 转成 小写
    str_cipher := strings.ToLower(strCipher)
    //2.位移步长
    step_move := step
    //3.将字符串 转为 明文字符切片
    str_slice_src := []byte(str_cipher)
    fmt.Println("密文字符切片:", str_slice_src)

    //4. 创建 密文字符切片
    str_slice_dst := str_slice_src

    //5.循环明文切片
    for i := 0; i < len(str_slice_src); i++ {
        //6.如果当前循环的明文字符 在位移 范围内,则直接 加上 位移步长 存入 密文字符切片
        if str_slice_src[i] >= 97+step_move {
            str_slice_dst[i] = str_slice_src[i] - step_move
        } else { //7.如果 明文字符 超出 范围,则 位移后 步长再减去 26
            str_slice_dst[i] = str_slice_src[i] + 26 - step_move
        }
    }
    //8.输出结果
    fmt.Println("解密结果为:", step_move, str_slice_dst, string(str_slice_dst))
    return string(str_slice_dst)
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

基于模型的设计

基于模型的设计

2011-8 / 69.00元

《基于模型的设计:MSP430/F28027/F28335DSP篇》的最大特色就是软硬件结合,在使用最新版本Simulink的基础上,结合多型号板卡实现设计开发。书中不仅详细剖析了MSP430/F28027/F28335板卡功能,而且使用Simulink演示了从建模到模型验证、从定点设计到处理器在环、从代码生成到硬件联调等诸多方面,内容充实,确实是一本学习基于模型设计进行DSP开发的较为理想的工程......一起来看看 《基于模型的设计》 这本书的介绍吧!

随机密码生成器
随机密码生成器

多种字符组合密码

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具