當前位置:首頁 » 密碼管理 » 異或加密c

異或加密c

發布時間: 2022-08-21 07:28:57

c語言中怎樣用異或運算來給一行文字加密和解密求解

char str[100] = "123";
//加密
for (int i = 0; str[i] != '\0'; i++)
str[i] ^= 0;

//解密 原理是一個A異或B異或C=A
for (int i = 0; str[i] != '\0'; i++)
str[i] ^= 0;

❷ C語言用異或運算逐個字元加密

文件以可讀可寫模式打開,當從讀操作切換到寫操作,或者從寫切換到到讀操作時必須先刷新一次文件緩沖區(就是把當前對文件的改變寫入磁碟),否則就不能正常操作。而fseek在移動文件指針的同時刷新了緩沖區。fseek(fp1,0,SEEK_CUR)這句的目的不是移動文件指針,而是為了刷新緩沖區。 不然fputc以後就不能fgetc了。

❸ C語言 異或運算

上式相當於b^=a;a^=b;因此,a=b=233。相當於,a^b^a,得到b原來的值。

❹ C語言:1. 輸入一個整數mm作為密碼,將字元串中每個字元與mm做一次按位異或操作,進行加密

錯誤1:中文引號改成英文引號
錯誤2:scanf("%d",mm);改成scanf("%d",&mm);
錯誤3:for(;a[i]!='\0';i++)改成for(--i;i>=0;i--)
錯誤4:a[i]=a[i]^mm^mm;改成a[i]=a[i]^mm;

❺ C語言異或加密這個編程怎麼寫

字元A 異或 字元C 在c語言里這樣寫:
char val = 'A' ^ 'C';

❻ C語言 異或加密

C語言異或加密實現的原理為,將任意值,與相同值兩次異或後,結果與原值相同。所以可以通過將源數據與一個固定的值(秘鑰key)異或後,得到密文,然後將密文再次與秘鑰異或,得到原文。這樣就實現了異或加密及解密。
C語言中的異或是一種按位操作的計算,其計算原理為,操作數對應位上的值相同,則結果位上值為0,否則為1.異或的運算符號為^,於是真值表如下:
0^0=0
0^1=1
1^0=1
1^1=0
這樣區分源數據和秘鑰值,有如下四種可能:
0^0=0
0^0=0
0^1=1
1^1=0
1^0=1
1^0=1
1^1=0
0^1=1
以上是將一個值,用另一個值連續異或兩次後的計算過程,可以看到,最終的值與原始值是相同的。這就是異或加密的基礎原理。

❼ 異或加密與解密(C語言)注釋

異或運算有一個特性


c = a xor b
那麼
a = c xor b

根據這樣的特性,你有一個信息a,然後你產生一個密碼b,把它和a異或運算之後就變成了c。這就是一種加密,解密的時候,把c重新和b異或運算,就變回了a。

順帶說一下,異或是很弱的加密方法,很容易被破解的。

❽ c語言用按位異或對文字加密

不是打不開,應該是你的這個程序始終運行不完,生成的n.txt文件太大,打開需要一個過程,當文件大於100M後,打開就很慢了,大概在我的機器上需要一分鍾,再大比如1000多M估計就需要很久才能打開了。
while(b!=EOF){fputc(b,f2);}問題出在這個循環上,b始終沒有變化,這樣該字元不可能為結束符,因此會一直循環下去。
這個問題的思路應該是:
1、打開文件m.txt,打開文件n.txt;
2、循環讀取字元,讀到一個,將該字元與key異或運算,然後馬上寫入 n.txt;
3、循環結束後關閉上述兩個文件。

❾ C語言 文件異或加密

異或加密是所有加密中最容易實施且代碼量相對精簡的一種加密方式,其原理為任意數據被同一個值(key)兩次異或後,值不變。

這種特性,使得異或加密演算法的加解密流程是完全相同的,也就是說加解密可以用同一個函數實現。


一、演算法思路。

依次讀入文件字元,並用key值對其異或,結果輸入到目標文件中。

二、演算法描述。

1 打開源文件及目標文件。

2 獲取密鑰值(key)。

3 讀入一個字元。

4 對其進行異或計算。

5 結果寫入目標文件。

6 重復3-5直到文件結尾。

7 關閉文件。

三、代碼實現。

為使代碼簡潔易懂,輸入文件設定為in.txt, 輸出文件設定為out.txt, key值設定為0x5C。

假定所有文件及目錄可讀寫。

#include<stdio.h>
#defineIN"in.txt"
#defineOUT"out.txt"
#defineKEY0x5C
voidscrambler(constchar*in,constchar*out,unsignedcharkey)
{
FILE*i,*o;
intc;

i=fopen(in,"rb");
o=fopen(out,"wb");//打開文件,因為假定可讀寫,所以對是否成功不做判斷
while((c=fgetc(i))!=EOF)//讀入字元直到文件結尾
{
c^=key;//執行異或加密或解密
fputc(c,o);//寫入文件
}

fclose(i);
fclose(o);
}

intmain()
{
scrambler(IN,OUT,KEY);
return0;
}

但是異或加密也是有缺陷的。最大的缺陷是加密操作是二進制層面的,獲取到的加密文件大部分將是不可讀的亂碼。這也是為什麼在打開文件的時候要以二進制方式的原因。

鑒於此,在此不便給出測試樣例及輸入輸出,可自行調試。

❿ 如何利用異或運算進行簡單加密解密

利用「^」異或運算對字元串進行加密
思路:1.先創建字元串輸入的Scanner;
2.通過char[] array = password.toCharArray();// 獲取字元數組;
3.遍歷字元數組,按目前理解要用到遍歷:數組所有元素進行訪問,比如你要輸出數組里所有的信息時,就要用到
4.進行異或運算
按位做「異或」運算是:位值相同得1,不同得0
例如:
< 加密過程:>
原解釋的二進制為 1 1 0 0 ----原文
設定的key的二進制為 0 1 1 0 ----密匙
兩者做「異或」結果為 0 1 0 1 ----密文
< 解密過程:>
0 1 0 1----密文
0 1 1 0----密匙
兩者「異或」就得到了原文 1 1 0 0 ----原文
詳細代碼:
package com.lixiyu;
import java.util.Scanner;
public class Example {
public static void main(String[] args){
Scanner sca=new Scanner(System.in);
System.out.println("請輸入一個英文字元串或解密字元串");
String line=sca.nextLine();//獲取用戶輸入信息
char[] array=line.toCharArray();//獲取字元數組
for (int i=0;i<array.length;i++){//歷遍字元數組
array[i]=(char) (array[i]^20000);//對數組每個元素進行異或運算
}
System.out.println("加密解密結果如下:");
System.out.println(new String(array));//輸出密鑰
}
}
異或運算:
1 ^ 1 = 0
1 ^ 0 = 1
0 ^ 1 = 1
0 ^ 0 = 0
字元'A' 的ASCII編碼為65 : 00000000 01000001
取整數7 : 00000000 00000000 00000000 00000111
XOR運算後 : 00000000 00000000 00000000 01000110
簡單加密演算法代碼如下 :
public class Test {
public static final int KEY = 7;
public static void main(String[] args) {
String str = "Hello World!";
StringBuffer str2 = new StringBuffer(); //存儲加密後的字元串
StringBuffer str3 = new StringBuffer(); //存儲解密後的字元串
//加密過程
for(int i=0;i<str.length();i++)
{
char c = (char)(str.charAt(i) ^ KEY);
str2.append(c);
}
//解密過程
for(int i=0;i<str2.length();i++)
{
char c = (char)(str2.charAt(i) ^ KEY);
str3.append(c);
}
System.out.println("原始 的字元串為:" + str);
System.out.println("加密後 的字元串為:" + str2);
System.out.println("解密後 的字元串為:" + str3);
}
}
輸出:
原始 的字元串為:Hello World!
加密後 的字元串為:Obkkh'Phukc&
解密後 的字元串為:Hello World!

熱點內容
c語言dos 發布:2025-05-15 21:18:17 瀏覽:662
sci編譯英文 發布:2025-05-15 21:16:57 瀏覽:381
大貓如何設置密碼 發布:2025-05-15 21:15:32 瀏覽:763
什麼叫蘋果版的和安卓版的手機 發布:2025-05-15 21:05:18 瀏覽:253
編程找點 發布:2025-05-15 20:43:10 瀏覽:587
php上傳臨時文件夾 發布:2025-05-15 20:43:00 瀏覽:657
impala資料庫 發布:2025-05-15 20:42:12 瀏覽:649
android安裝插件 發布:2025-05-15 20:41:31 瀏覽:241
神秘顧客訪問 發布:2025-05-15 20:33:39 瀏覽:298
安卓市場手機版從哪裡下載 發布:2025-05-15 20:17:28 瀏覽:815