1. C++ ASCII 加密
#include <stdio.h>
#include <string.h>
// 將十進制數decimal轉換為k進制數,並以字元串形式存放在字元數組s中
char *CountRule(int decimal,int k,char *s) {
int ch,i,n;
for(n = 0; decimal > 0; ++n) {
s[n] = decimal%k + '0';
decimal /= k;
}
s[n] = '\0';
for(i = 0; i < n/2; ++i) {
ch = s[i];
s[i] = s[n - i - 1];
s[n - i - 1] = ch;
}
return s;
}
// 將k進制串轉換為十進制數,並以整數返回
unsigned Transform(char s[], int k) {
int n = 1,j,len;
unsigned num = 0;
len = strlen(s);
for(j = len - 1;j >= 0; j--) {
num += n*(s[j] - '0');
n *= k;
}
return num;
}
unsigned char *Encrypt(unsigned char *plaintext,char *key,unsigned char *cryptogram) {
int i,j,klen,blen;
char ch,binarystr[9];
unsigned char *p = plaintext;
unsigned char *c = cryptogram;
klen = strlen(key);
for(i = 0; p[i]; ++i) {
c[i] = p[i] - (key[i%klen] - '0'); // 初步加密
CountRule(c[i],2,binarystr); // 將數值s[i]轉換為二進制串
blen = strlen(binarystr);
if(blen < 8) {
for(j = blen; j >= 0; --j) // 如果binarystr不夠8位,空位留前面
binarystr[j + 8 - blen] = binarystr[j];
for(j = 0; j < 8 - blen; ++j) // 然後在前面填入'0'
binarystr[j] = '0';
}
for(j = 0; j < 8; j += 2) { // 實施核心加密過程:交換相鄰奇偶位
ch = binarystr[j];
binarystr[j] = binarystr[j + 1];
binarystr[j + 1] = ch;
}
c[i] = Transform(binarystr,2); // 再把串轉回到整數
}
c[i] = '\0';
return (unsigned char *)c;
}
unsigned char *Decrypt(unsigned char *cryptogram,char *key,unsigned char *plaintext) {
int i,j,klen,blen;
char ch,binarystr[9];
unsigned char *c = cryptogram;
unsigned char *p = plaintext;
klen = strlen(key);
for(i = 0; c[i]; ++i) { // 核心解密
CountRule(c[i],2,binarystr); // 將數值s[i]轉換為二進制串
blen = strlen(binarystr);
if(blen < 8) {
for(j = blen; j >= 0; --j) // 如果binarystr不夠8位,空位留前面
binarystr[j + 8 - blen] = binarystr[j];
for(j = 0; j < 8 - blen; ++j) // 然後在前面填入'0'
binarystr[j] = '0';
}
for(j = 0; j < 8; j += 2) { // 實施核心解密過程:交換相鄰奇偶位
ch = binarystr[j];
binarystr[j] = binarystr[j + 1];
binarystr[j + 1] = ch;
}
p[i] = Transform(binarystr,2); // 再把串轉回為整數
p[i] += (key[i%klen] - '0'); // 再進行初解密
}
p[i] = '\0';
return (unsigned char *)p;
}
int main() {
unsigned char plaintext[] = "東海縣文廣體局";
unsigned char secret[80],pt[80];
char key[] = "1B01";
printf("明文 : %s\n",plaintext);
Encrypt(plaintext,key,secret);
printf("密文 : %s\n",secret);
Decrypt(secret,key,pt);
printf("明文 : %s\n",pt);
return 0;
}
2. 從鍵盤輸入一個字元,對該字元進行加密處理輸出,規則是將其轉換為對應的ASCII碼加2之後對應的字元
#include<stdio.h>
main(){
charch;
ch=getchar();
ch+=2;
putchar(ch);
}
3. 加密演算法 1) 用被加密數據異或字母「D」的ASCII碼。 2) 將步驟1)得到的數據異或字母「X」的ASCII碼。
#include <stdio.h>
main()
{
unsigned char i;
i=1;//設要加密的數字=1(等於幾都行)
i=i ^ 'D';
i^='X';
prinft("%d",i);
}
4. 數字加密成ASCII碼,求大概演算法
有很多種方法,最簡單的是字典法,把你的數字按照字典對應到你的字元,比如0-^ 1-@ 2-t 3-y 4-T 5-u 6-o 7-O 8-p 9-s 這樣 123就可以替換為@ty當然,這種方法過於簡單,規律極易暴露,不過可以多備幾套字典,比如序號 0123456789A! !wWdaS^$):w% 'Jh%^0_1@#....以序號區分,這樣就可以將12341轉換為A!wWdaw或者w%Jh%^J,應該說用起來還不錯
5. C語言 輸入字元串輸出對應字母的ASCII編碼 加密
#include<stdio.h>
#include<string.h>
char pass[101];
int main()
{
int i;
char s[101],key[101];
puts("設定密碼:");
scanf("%s",pass);
puts("輸入源字元串:");
scanf("%s",s);
puts("輸入密碼:");
scanf("%s",key);
while(strcmp(pass,key))
{
/*for(i=0;i<strlen(s);i++)
printf("%d ",s[i]+4);
puts("");*/
puts("密碼錯誤!重新輸入:");
scanf("%s",key);
}
puts(s);
for(i=0;i<strlen(s);i++)
printf("%d ",s[i]);
puts("");
}
6. Html文件中出現加密 我想知道這是何種形式的加密 是ASCII加密么 如果是怎麼能給轉換回正常的ASCII加密
解密函數就在此 mydata 找到這個看下就知道了
7. C語言實現將字元串進行加密處理,每個字元的加密規則是,將其轉換為對應的ASCII碼加3後對應 的字元輸出
輸入的是英文字元的話,直接加3就可以,但是如果是中文字元的話,如果直接高位和地位加3也可以,但是解密的時候就有一個不確定的存在,因為中文字元的ascii編碼是有0xfe這樣的存在,加上3的話就到時候還原就變得不確定。所以如果是中文字元加密的話,應該把兩個ascii碼轉合並為兩個位元組無符號類型,然後再加3。
8. 輸入一行數字加密後輸出ASCII碼 加密規則:先將數字對應的ASCII碼-10,輸出減10後數字對應的ASCII碼
不回答。很抱歉,我想你最起碼的也應該嘗試一下自己去寫出代碼,哪怕有各種錯誤,至少努力了,也會通過改正這些錯誤得到更深的理解
9. 【急】加密規則:字元的ASCII碼加上該字元在字母表中的次序,則字元串「iPad」加密後的十六進製表示是
C,查ASCII表得編號67,在字母表中的次序是3,相加得70,查ASCII表得編號為70的字元是F,對應的十六進制為46。
iPad:
i:105 + 9 = 114 密碼r 十六進制72
P:80 + 16 = 96密碼『 十六進制60
a:97 + 1 = 98密碼b 十六進制62
d:100 + 4 = 104密碼h 十六進制68
密碼r』bh 十六進制72-60-62-68