RC4流加密,这次非常简单。需要注意的是,会进行两步swap操作,最后一次的时候不再需要key,仅第一次需要key
// RC4_Encryption.cpp : 定义控制台应用程序的入口点。
/*
对于每一个字节而言,与加密后得到的0~2^8-1 之间的一个数进行异或
需要一个s的状态向量 k为密钥 还需要一个t向量
t向量用来盛放扩展后的密钥,扩展为256字节
首先k进行拓展存放到s里,s要盛放0~2^8-1
然后进行swap操作(两次)
第一次: 设置一个变量j , j = (j+ s[i] + t[i])%256 ,之后s[i]
与s[j]进行交换
第二次 : 设置一个变量tempValue 用来盛放这一次要获得的字节的值,
首先还是需要一个j 这次j = (j + state[i])%256 进行一次交换
然后tempValue 获得的下标为(state[i] + state[j])%256
最后明文与s[tempValue]进行异或
*/
#include "stdafx.h"
#include <stdio.h>
#include <string.h>
#include <malloc.h>
char plainText[] = "Hello RC4!!!!!!!!!!!!!!!!!";
char key[] = "0123456789";
const char * base64char = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
const char padding_char = '=';
/*编码代码
* const unsigned char * sourcedata, 源数组
* char * base64 ,码字保存
*/
int base64_encode(char * sourcedata, char * base64)
{
int i = 0, j = 0;
unsigned char trans_index = 0; // 索引是8位,但是高两位都为0
const int datalength = strlen((const char*)sourcedata);
for (; i < datalength; i += 3){
// 每三个一组,进行编码
// 要编码的数字的第一个
trans_index = ((sourcedata[i] >> 2) & 0x3f);
base64[j++] =</