Home > Backend Development > Golang > How to write a simple Caesar cipher encryption program using Golang

How to write a simple Caesar cipher encryption program using Golang

PHPz
Release: 2023-04-24 10:43:34
Original
1175 people have browsed it

The Caesar cipher is a simple encryption algorithm, also known as the shift cipher. Its principle is to move each letter in the plaintext by a fixed amount to obtain the ciphertext. In this article, we will learn how to write a simple Caesar cipher encryption program using Golang.

First, let us review the principles of encryption and decryption of the Caesar cipher. For a given letter, its value after being encrypted by Caesar cipher can be expressed by the following formula:

Ciphertext = (plaintext key) mod 26

In this formula, "Plaintext" represents the original letters, "key" represents the amount we want to move the letters, and "mod 26" represents mapping the letters to 26 positions in the alphabet to get the ciphertext.

Next, we will implement a simple Caesar cipher encryption program, we will input the plaintext and key as input, and then output the ciphertext.

First, we need to import the "fmt" package so that we can read user input and output results. We will also use string constants to define the order of the 26 letters so that we can select specific letters from them.

package main

import "fmt"

const alphabet = "abcdefghijklmnopqrstuvwxyz"
Copy after login

Next, we will define a function that accepts a string and an integer as input and returns a string. This function will implement the encryption function of Caesar cipher:

func caesarCipher(s string, k int) string {
    var result []byte

    for i := 0; i = 'a' && c = 'A' && c <p>In the above function, we first define an empty byte slice to save the encrypted result. We then use a loop to iterate through each character in the input string. If the character is a lowercase letter, we convert it to an integer, then add the key to that value, and finally use a modulus operation to map it to a position in the alphabet. Finally, we add the encrypted letters to the result. </p><p>For the case of uppercase letters, we can also take similar treatment, the difference is that we need to convert it to lowercase letters first, then map it to the position in the alphabet, and finally convert it to uppercase letter. </p><p>Finally, we will write a simple main function to read user input and print the results to the terminal. Here is the complete program: </p><pre class="brush:php;toolbar:false">package main

import (
    "fmt"
    "unicode"
)

const alphabet = "abcdefghijklmnopqrstuvwxyz"

func caesarCipher(s string, k int) string {
    var result []byte

    for i := 0; i = 'a' && c = 'A' && c <p>Now, we can run the program and test whether it was successful. The following is a screenshot of a sample input and output: </p><p><img src="https://img.php.cn/upload/article/000/000/068/168230421494581.png" alt="How to write a simple Caesar cipher encryption program using Golang" title="How to write a simple Caesar cipher encryption program using Golang"></p><p> As can be seen from the above figure, our program has successfully implemented the Caesar cipher encryption function. Of course, this is just a very basic encryption method and it can be easily cracked. Therefore, in practical applications, more complex encryption algorithms need to be used to protect sensitive data and information. </p>
Copy after login

The above is the detailed content of How to write a simple Caesar cipher encryption program using Golang. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template