XOR Cipher

XOR Encryption is an encryption method used to encrypt data and is hard to crack by brute-force method, i.e generating random encryption keys to match with the correct one.

Below is a simple implementation in C++. The concept of implementation is to first define XOR – encryption key and then to perform XOR operation of the characters in the String with this key which you want to encrypt. To decrypt the encrypted characters we have to perform XOR operation again with the defined key. Here we are encrypting the entire String.

C++

filter_none

edit
close

play_arrow

link
brightness_4
code

// C++ program to implement XOR - Encryption
#include<bits/stdc++.h>
  
// The same function is used to encrypt and
// decrypt
void encryptDecrypt(char inpString[])
{
    // Define XOR key
    // Any character value will work
    char xorKey = 'P';
  
    // calculate length of input string
    int len = strlen(inpString);
  
    // perform XOR operation of key
    // with every caracter in string
    for (int i = 0; i < len; i++)
    {
        inpString[i] = inpString[i] ^ xorKey;
        printf("%c",inpString[i]);
    }
}
  
// Driver program to test above function
int main()
{
    char sampleString[] = "GeeksforGeeks";
  
    // Encrypt the string
    printf("Encrypted String: ");
    encryptDecrypt(sampleString);
    printf("\n");
  
    // Decrypt the string
    printf("Decrypted String: ");
    encryptDecrypt(sampleString);
  
    return 0;
}

chevron_right


Java

filter_none

edit
close

play_arrow

link
brightness_4
code

// Java program to implement XOR - Encryption
class XOREncryption
{
    // The same function is used to encrypt and
    // decrypt
    static String encryptDecrypt(String inputString)
    {
        // Define XOR key
        // Any character value will work
        char xorKey = 'P';
  
        // Define String to store encrypted/decrypted String
        String outputString = "";
  
        // calculate length of input string
        int len = inputString.length();
  
        // perform XOR operation of key
        // with every caracter in string
        for (int i = 0; i < len; i++) 
        {
            outputString = outputString + 
            Character.toString((char) (inputString.charAt(i) ^ xorKey));
        }
  
        System.out.println(outputString);
        return outputString;
    }
  
    // Driver code
    public static void main(String[] args)
    {
        String sampleString = "GeeksforGeeks";
  
        // Encrypt the string
        System.out.println("Encrypted String");
        String encryptedString = encryptDecrypt(sampleString);
  
        // Decrypt the string
        System.out.println("Decrypted String");
        encryptDecrypt(encryptedString);
    }
}
  
// This code is contributed by Vivekkumar Singh

chevron_right


Python3

filter_none

edit
close

play_arrow

link
brightness_4
code

# Python3 program to implement XOR - Encryption
  
# The same function is used to encrypt and
# decrypt
def encryptDecrypt(inpString):
  
    # Define XOR key
    # Any character value will work
    xorKey = 'P';
  
    # calculate length of input string
    length = len(inpString);
  
    # perform XOR operation of key
    # with every caracter in string
    for i in range(length):
      
        inpString = (inpString[:i] + 
             chr(ord(inpString[i]) ^ ord(xorKey)) +
                     inpString[i + 1:]);
        print(inpString[i], end = "");
      
    return inpString;
  
# Driver Code
if __name__ == '__main__':
    sampleString = "GeeksforGeeks";
  
    # Encrypt the string
    print("Encrypted String: ", end = "");
    sampleString = encryptDecrypt(sampleString);
    print("\n");
  
    # Decrypt the string
    print("Decrypted String: ", end = "");
    encryptDecrypt(sampleString);
  
# This code is contributed by Princi Singh

chevron_right


C#

filter_none

edit
close

play_arrow

link
brightness_4
code

// C# program to implement XOR - Encryption
using System;
      
public class XOREncryption
{
    // The same function is used to encrypt and
    // decrypt
    static String encryptDecrypt(String inputString)
    {
        // Define XOR key
        // Any character value will work
        char xorKey = 'P';
  
        // Define String to store encrypted/decrypted String
        String outputString = "";
  
        // calculate length of input string
        int len = inputString.Length;
  
        // perform XOR operation of key
        // with every caracter in string
        for (int i = 0; i < len; i++) 
        {
            outputString = outputString + 
            char.ToString((char) (inputString[i] ^ xorKey));
        }
  
        Console.WriteLine(outputString);
        return outputString;
    }
  
    // Driver code
    public static void Main(String[] args)
    {
        String sampleString = "GeeksforGeeks";
  
        // Encrypt the string
        Console.WriteLine("Encrypted String");
        String encryptedString = encryptDecrypt(sampleString);
  
        // Decrypt the string
        Console.WriteLine("Decrypted String");
        encryptDecrypt(encryptedString);
    }
}
  
// This code has been contributed by 29AjayKumar

chevron_right



Output:



Encrypted String: 55;#6?"55;#
Decrypted String: GeeksforGeeks

The basic idea behind XOR – encryption is, if you don’t know the XOR-encryption key before decrypting the encrypted data, it is impossible to decrypt the data. For example, if you XOR two unknown variables you cannot tell what the output of those variables is. Consider the operation A XOR B, and this returns true. Now if the value of one of the variable is known we can tell the value of another variable. If A is True then B should be False or if A is False then B should be true according to the properties of the boolean XOR operation. Without knowing one of the value we can not decrypt the data and this idea is used in XOR – encryption.

Related Articles:
Vigenère Cipher
Caesar Cipher

This article is contributed by Harsh Agarwal. If you like GeeksforGeeks and would like to contribute, you can also write an article using contribute.geeksforgeeks.org or mail your article to contribute@geeksforgeeks.org. See your article appearing on the GeeksforGeeks main page and help other Geeks.

Please write comments if you find anything incorrect, or you want to share more information about the topic discussed above.



My Personal Notes arrow_drop_up