loading黑马程序员之密钥加密活动(1-2)

-------android培训 、java培训、期待与您交流! ----------

问题:

密钥加密是将密钥数字串值循环加到明文(需要加密的文字串)上,使得明文变形而不可阅读,变形后的文字串称为密文。
此加密的方式在日后的工作中也可能会经常用到!!!现在学习、正好。
例如, 密钥为5201314,明文为“I Love You Wq”,则循环加密的过程及结果为:
这里的密钥加密是循环加密,例如密钥为5201314,当密钥的最后一位(4)加完后,密码还没有加密完,就从密钥的第一位(5)再开始加。
加密后密文为: N"Lpyf$^qu!Zr

例1:  
输入密钥:123
输入密码:123
输出密文:246
解析例子1:
    49+1=char(50)=2
    50+2=char(52)=4
    51+3=char(54)=6

例2:
           密钥为:5201314
          明文为:I Love You Wq
加密后密文为: N"Lpyf$^qu!Zr



答案:


package com.heima;

import java.util.Scanner;

/**
 * 云八第一次活动:密钥加密活动
 * @author 杨显彬
 *
 */
public class Code {

	public static void main(String[] args) {
		Scanner sc = new Scanner(System.in);//从键盘获取输入
		char[] text = null;//明文
		int[] key = null;//密钥
		System.out.println("请输入明文,回车结束:");
		text = sc.nextLine().toCharArray();//从用户的键盘输入得到明文,并转成字节数组
		System.out.println("请输入密钥(纯数字),回车结束:");
		char[] keyStr = null;//密钥char数组,用于接收用户输入再转换成int数组
		keyStr = sc.nextLine().toCharArray();//从用户的键盘输入得到密钥,并转成字节数组
		key = new int[keyStr.length];//根据char密钥长度初始化int密钥
		//遍历char数组,把char转换成int
		for(int i=0;i<keyStr.length;i++){
			key[i] = (int)(keyStr[i]-48);
		}
		//加密
		String code = encipher(text,key);
		System.out.println("加密后的密码:"+code);
	}
	/**
	 * 返回用密钥key对明文code加密后的字符串
	 * @param code
	 * @param key
	 * @return
	 */
	public static String encipher(char[] code,int[] key){
		StringBuilder sb = new StringBuilder();//密文
		int position = 0;//初始化密钥指针
		//遍历密码,为密码一个一个的加密
		for(int i=0;i<code.length;i++){
			int codeAscii = (int)code[i];//密码对应的ascii值
			char ciphertext = (char)(codeAscii + key[position]);//加密后的密文
			position++;//加密后,密钥指针往后移动一位
			sb.append(ciphertext);//密码加密后,添加进密码集合
			//如果指针移动到密钥的末尾,则把指针归0,实现重复使用密钥
			if(position==key.length){
				position = 0;
			}
		}
		return sb.toString();
	}

}

------- android培训  、 java培训 、期待与您交流! ----------

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我会根据你的要求设计一个C++程序,实现加密、解密、密钥菜单和欧拉公式实现RAS加密解密。以下是程序的代码: ```c++ #include <iostream> #include <string> #include <cmath> using namespace std; // 求一个数的欧拉函数值 unsigned int Euler(unsigned int n) { unsigned int result = n; for (unsigned int i = 2; i <= sqrt(n); ++i) { if (n % i == 0) { result = result / i * (i - 1); while (n % i == 0) { n /= i; } } } if (n > 1) { result = result / n * (n - 1); } return result; } // 求一个数关于模数的逆元 unsigned int Inverse(unsigned int a, unsigned int mod) { unsigned int m0 = mod, t, q; unsigned int x0 = 0, x1 = 1; if (mod == 1) { return 0; } while (a > 1) { q = a / mod; t = mod; mod = a % mod; a = t; t = x0; x0 = x1 - q * x0; x1 = t; } if (x1 < 0) { x1 += m0; } return x1; } // 加密函数,参数为明文、公钥和模数 string Encrypt(string plain, unsigned int e, unsigned int n) { string cipher; for (auto ch : plain) { unsigned int m = ch; // 将明文转为数值 unsigned int c = static_cast<unsigned int>(pow(m, e)) % n; cipher += to_string(c) + " "; } return cipher; } // 解密函数,参数为密文、私钥和模数 string Decrypt(string cipher, unsigned int d, unsigned int n) { string plain; size_t i = 0; while (i < cipher.size()) { // 从密文中提取出一个数值 size_t j = cipher.find(' ', i); if (j == string::npos) { j = cipher.size(); } unsigned int c = stoi(cipher.substr(i, j - i)); // 使用私钥解密 unsigned int m = static_cast<unsigned int>(pow(c, d)) % n; // 将数值转为字符 plain += static_cast<char>(m); i = j + 1; } return plain; } int main() { unsigned int p, q, n, e, d; cout << "请输入两个素数p、q:" << endl; cin >> p >> q; n = p * q; unsigned int phi = (p - 1) * (q - 1); cout << "欧拉函数值phi = " << phi << endl; // 找出一个与phi互质的公钥e do { cout << "请输入一个与phi互质的公钥e:" << endl; cin >> e; } while (e <= 1 || e >= phi || phi % e == 0 || Euler(e) != e - 1); // 计算对应的私钥d d = Inverse(e, phi); cout << "私钥d = " << d << endl; cout << "请选择操作:" << endl; cout << "1. 加密" << endl; cout << "2. 解密" << endl; int choice; cin >> choice; if (choice == 1) { string plain; cout << "请输入明文:" << endl; cin >> plain; string cipher = Encrypt(plain, e, n); cout << "密文:" << cipher << endl; } else if (choice == 2) { string cipher; cout << "请输入密文:" << endl; cin >> cipher; string plain = Decrypt(cipher, d, n); cout << "明文:" << plain << endl; } else { cout << "无效的选项!" << endl; } return 0; } ``` 在程序中,首先要求用户输入两个素数p和q,然后计算出n=pq和欧拉函数值phi=(p-1)(q-1)。接着程序会要求用户输入一个与phi互质的公钥e,计算对应的私钥d。然后程序会显示一个菜单,让用户选择加密或解密操作。如果用户选择加密操作,程序会要求用户输入明文,然后调用Encrypt函数进行加密,并输出密文。如果用户选择解密操作,程序会要求用户输入密文,然后调用Decrypt函数进行解密,并输出明文。 需要注意的是,由于加密和解密涉及到大整数的计算,因此在程序中使用了unsigned int类型来存储整数,而不是普通的int类型。同时,由于加密和解密过程中需要进行指数运算,因此使用了C++标准库中的pow函数来进行计算。这样的实现方式在小数据量下是可行的,但在大数据量下可能会出现溢出的问题。如果需要进行更加安全的加密和解密,建议使用专门的密码学库。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值