对称加密技AES 在手机上运行

听到工作室讨论加密算法。

我掏出几年前我做的Android   使用 AES算法的工具。

实现是用C/C++,用JNI调用。

代码有没混淆,有学习AES和JNI的同学可以瞅瞅。

----------------------------

如图:

第一个文本行是要加密的源数据,第二个文本行是钥匙。
点击加密
第一个标签是加密结果,第二个也是同样的
点击解密
拿着加密结果和钥匙解出来的源数据出现在第三个标签


package cn.bao;
import android.app.Activity;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;
import android.widget.TextView;
public class AESActivity extends Activity {
	//JNI
	static {
		System.loadLibrary("aes");
	}
	public native String encryption(String src,int len, String key);
	public native String dncryption(String src,int len, String key);
	public EditText et;
	public EditText et2;
	public TextView tv1;
	public TextView tv2;
	public TextView tv3;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        et = (EditText) this.findViewById(R.id.et);
        et2 = (EditText) this.findViewById(R.id.et2);
        tv1 = (TextView) this.findViewById(R.id.tv1);
        tv2 = (TextView) this.findViewById(R.id.tv2);
        tv3 = (TextView) this.findViewById(R.id.tv3);
    }
    public void click(View view){
    	String src = et.getText().toString();
    	int len = src.length();
    	String key = et2.getText().toString();
    	String s = encryption(src,len, key);
    	tv1.setText("加密结果"+s);
    	tv3.setText(s);
    }
    public void click2(View view){
    	String src = tv3.getText().toString();
    	int len = src.length();
    	String key = et2.getText().toString();
    	String s = dncryption(src,len, key);
    	tv2.setText("解密结果"+s);
    }
}

cn_bao_AESActivity.h

/* DO NOT EDIT THIS FILE - it is machine generated */
#include <jni.h>
/* Header for class cn_bao_AESActivity */

#ifndef _Included_cn_bao_AESActivity
#define _Included_cn_bao_AESActivity
#ifdef __cplusplus
extern "C" {
#endif
/*
 * Class:     cn_bao_AESActivity
 * Method:    encryption
 * Signature: (Ljava/lang/String;ILjava/lang/String;)Ljava/lang/String;
 */
JNIEXPORT jstring JNICALL Java_cn_bao_AESActivity_encryption
  (JNIEnv *, jobject, jstring, jint, jstring);

/*
 * Class:     cn_bao_AESActivity
 * Method:    dncryption
 * Signature: (Ljava/lang/String;ILjava/lang/String;)Ljava/lang/String;
 */
JNIEXPORT jstring JNICALL Java_cn_bao_AESActivity_dncryption
  (JNIEnv *, jobject, jstring, jint, jstring);

#ifdef __cplusplus
}
#endif
#endif

aes.h

#pragma once
#include <bitset>
#include <string>
#include <utility>
using namespace std;

class AES
{
    // 默认 PKCS5Padding
public:
    char m_key[16];

    AES(const char * key);

private:
    typedef unsigned char byte;
    static const int KEY_SIZE = 16;    //    密钥长度为128位
    static const int N_ROUND = 11;
    byte plainText[16];    //    明文
    byte state[16];    //    当前分组。
    byte cipherKey[16];    //    密钥
    byte roundKey[N_ROUND][16];    //轮密钥
    byte cipherText[16];    //密文
    byte SBox[16][16];    //    S盒
    byte InvSBox[16][16];    //    逆S盒
    void EncryptionProcess();
    void DecryptionProcess();
    void Round(const int& round);
    void InvRound(const int& round);
    void FinalRound();
    void InvFinalRound();
    void KeyExpansion();
    void AddRoundKey(const int& round);
    void SubBytes();
    void InvSubBytes();
    void ShiftRows();
    void InvShiftRows();
    void MixColumns();
    void InvMixColumns();
    void BuildSBox();
    void BuildInvSBox();
    void InitialState(const byte* text);
    void InitialCipherText();
    void InitialplainText();
    byte GFMultplyByte(const byte& left, const byte& right);
    const byte* GFMultplyBytesMatrix(const byte* left, const byte* right);

    const byte* Cipher(const byte* text, const byte* key, const int& keySize);
    const byte* InvCipher(const byte* text, const byte* key, const int& keySize);

    char GetHex(char c);
    int BytesToHexString(const unsigned char* pSrc, char* pDst, int nSrcLength);
    char * HexStringToBytes(const unsigned char* pSrc, char* pDst, int nSrcLength);

private:
    string Encryption(const char * src, int len);
    string Decryption(const char * src, int len);

public:
    static string s_Encryption(const char * src, int len, const char * key = "1234567890123456");
    static string s_Decryption(const char * src, int len, const char * key = "1234567890123456");
};

aes.cc

#include<stdio.h>
#include"cn_bao_AESActivity.h"
#include"aes.h"
#include <android/log.h>
#include<jni.h>
#include<malloc.h>
#include <string.h>
#define LOG_TAG "System.out"
#define LOGD(...) __android_log_print(ANDROID_LOG_DEBUG, LOG_TAG, __VA_ARGS__)
#define LOGI(...) __android_log_print(ANDROID_LOG_INFO, LOG_TAG, __VA_ARGS__)
//

string AES::s_Encryption(const char * src, int len, const char * key /* = */) {
	AES aes(key);
	return aes.Encryption(src, len);
}

string AES::s_Decryption(const char * src, int len, const char * key /* = */) {
	AES aes(key);
	return aes.Decryption(src, len);
}

int AES::BytesToHexString(const unsigned char* pSrc, char* pDst,
		int nSrcLength) {
	int i;
	const char tab[] = "0123456789abcdef"; // 0x0-0xf的字符查找表

	for (i = 0; i < nSrcLength; i++) {
		*pDst++ = tab[*pSrc >> 4]; // 输出高4位
		*pDst++ = tab[*pSrc & 0x0f]; // 输出低4位
		pSrc++;
	}

	*pDst = '\0';
	return (nSrcLength * 2);
}

char AES::GetHex(char c) {
	if ('0' <= c && c <= '9') {
		c -= '0';
	} else if ('a' <= c && c <= 'z') {
		c -= 'a';
		c += 10;
	} else if ('A' <= c && c <= 'Z') {
		c -= 'A';
		c += 10;
	}
	return c;
}

char * AES::HexStringToBytes(const unsigned char* pSrc, char* pDst,
		int nSrcLength) {
	int i;
	char * result = pDst;
	int bytes = nSrcLength / 2;
	for (i = 0; i < bytes; i++) {
		char c = *pSrc;
		*pDst++ = (GetHex(pSrc[0]) << 4) + GetHex(pSrc[1]);
		pSrc += 2;
	}
	return result;
}

string AES::Encryption(const char * src, int len) {
	const char * input = src;

	int round = len / 16;
	int padNum = 16 - (len - round * 16);

	int outSize = round * 32 + 33;
	char * output = new char[outSize];
	output[outSize - 1] = '\0';

	const byte * cipherText = NULL;
	for (int r = 0; r < round; r++) {
		cipherText = Cipher((const byte*) input, (const byte*) m_key, 16);
		input += 16;
		BytesToHexString(cipherText, output, 16);
		output += 32;
	}

	// padding
	char pad[16];
	memcpy(pad, input, 16 - padNum);
	memset(pad + 16 - padNum, padNum, padNum);
	cipherText = Cipher((const byte*) pad, (const byte*) m_key, 16);
	BytesToHexString(cipherText, output, 16);
	output += 32;
	output -= (outSize - 1);

	string result = "";
	result = output;
	delete[] output;
	return result;
}

string AES::Decryption(const char * src, int len) {
	int round = len / 32;
	if (round > 0 && len - round * 32 != 0) {
		return "";
	}

	char * input = new char[len / 2];char
	* deleteBuf = HexStringToBytes((unsigned char *) src, input, len);
	char output[17];
	output[16] = '\0';

	string result = "";
	const byte * cipherText = NULL;
	for (int r = 0; r < round; r++) {
		cipherText = InvCipher((const byte*) input, (const byte*) m_key, 16);
		memcpy(output, cipherText, 16);
		if (r == round - 1) {
			*(output + 16 - output[15]) = '\0';
		}
		input += 16;
		result += output;
	}

	delete[] deleteBuf;
	return result;
}

void AES::EncryptionProcess() { //    加密过程
	InitialState(plainText);
	KeyExpansion(); //    密钥扩展
	AddRoundKey(0); //    轮密钥加
	for (int i = 1; i < N_ROUND - 1; ++i) {
		Round(i);
	}
	FinalRound();
	InitialCipherText();
}

void AES::DecryptionProcess() { //    解密过程
	InitialState(cipherText);
	KeyExpansion();
	InvFinalRound();
	for (int i = N_ROUND - 2; i > 0; --i) {
		InvRound(i);
	}
	AddRoundKey(0);
	InitialplainText();
}

void AES::Round(const int& round) { //    正常轮
	SubBytes();
	ShiftRows();
	MixColumns();
	AddRoundKey(round);
}

void AES::InvRound(const int& round) { //    正常轮的逆
	AddRoundKey(round);
	InvMixColumns();
	InvShiftRows();
	InvSubBytes();
}

void AES::FinalRound() { //    最后轮
	SubBytes();
	ShiftRows();
	AddRoundKey(N_ROUND - 1);
}

void AES::InvFinalRound() { //    最后轮的逆
	AddRoundKey(N_ROUND - 1);
	InvShiftRows();
	InvSubBytes();
}

void AES::KeyExpansion() { //    密钥扩展
	const byte rcon[N_ROUND][4] = { { 0x00, 0x00, 0x00, 0x00 }, { 0x01, 0x00,
			0x00, 0x00 }, { 0x02, 0x00, 0x00, 0x00 },
			{ 0x04, 0x00, 0x00, 0x00 }, { 0x08, 0x00, 0x00, 0x00 }, { 0x10,
					0x00, 0x00, 0x00 }, { 0x20, 0x00, 0x00, 0x00 }, { 0x40,
					0x00, 0x00, 0x00 }, { 0x80, 0x00, 0x00, 0x00 }, { 0x1b,
					0x00, 0x00, 0x00 }, { 0x36, 0x00, 0x00, 0x00 } };
	for (int i = 0; i < 16; ++i) {
		roundKey[0][i] = cipherKey[i];
	}
	for (int i = 0; i < 4; ++i) { //  roundKey[0][16]为cipherKey的转置矩阵
		for (int j = 0; j < 4; ++j) {
			roundKey[0][4 * i + j] = cipherKey[4 * j + i];
		}
	}
	for (int roundIndex = 1; roundIndex < N_ROUND; ++roundIndex) {
		byte rotWord[4] = { 0x00 };
		rotWord[0] = roundKey[roundIndex - 1][3];
		rotWord[1] = roundKey[roundIndex - 1][7];
		rotWord[2] = roundKey[roundIndex - 1][11];
		rotWord[3] = roundKey[roundIndex - 1][15];
		std::swap < byte > (rotWord[0], rotWord[1]);
		std::swap < byte > (rotWord[1], rotWord[2]);
		std::swap < byte > (rotWord[2], rotWord[3]);
		for (int i = 0; i < 4; ++i) {
			rotWord[i] = SBox[rotWord[i] >> 4][rotWord[i] & 0x0f];
			roundKey[roundIndex][4 * i] = roundKey[roundIndex - 1][4 * i]
					^ rotWord[i] ^ rcon[roundIndex][i];
		}
		for (int j = 1; j < 4; ++j) {
			for (int i = 0; i < 4; ++i) {
				roundKey[roundIndex][4 * i + j] = roundKey[roundIndex - 1][4 * i
						+ j] ^ roundKey[roundIndex][4 * i + j - 1];
			}
		}
	}
}

void AES::AddRoundKey(const int& round) { //    轮密钥加
	for (int i = 0; i < 16; ++i) { //    利用当前分组state和第round组扩展密钥进行按位异或
		state[i] ^= roundKey[round][i];
	}
}

void AES::SubBytes() { //    字节代换
	for (int i = 0; i < 16; ++i) {
		state[i] = SBox[state[i] >> 4][state[i] & 0x0f];
	}
}

void AES::InvSubBytes() { //    逆字节代换
	for (int i = 0; i < 16; ++i) {
		state[i] = InvSBox[state[i] >> 4][state[i] & 0x0f];
	}
}

void AES::ShiftRows() { //    行变换
//state第一行保持不变
// Do nothing.
//state第二行循环左移一个字节
	std::swap < byte > (state[4], state[5]);
	std::swap < byte > (state[5], state[6]);
	std::swap < byte > (state[6], state[7]);
	//state第三行循环左移两个字节
	std::swap < byte > (state[8], state[10]);
	std::swap < byte > (state[9], state[11]);
	//state第三行循环左移三个字节
	std::swap < byte > (state[14], state[15]);
	std::swap < byte > (state[13], state[14]);
	std::swap < byte > (state[12], state[13]);
}

void AES::InvShiftRows() { //    行变换反演
//state第一行保持不变
// Do nothing.
//state第二行循环右移一个字节
	std::swap < byte > (state[6], state[7]);
	std::swap < byte > (state[5], state[6]);
	std::swap < byte > (state[4], state[5]);
	//state第三行循环右移两个字节
	std::swap < byte > (state[9], state[11]);
	std::swap < byte > (state[8], state[10]);
	//state第三行循环右移三个字节
	std::swap < byte > (state[12], state[13]);
	std::swap < byte > (state[13], state[14]);
	std::swap < byte > (state[14], state[15]);
}

void AES::MixColumns() { //    列混淆
	byte matrix[4][4] = { { 0x02, 0x03, 0x01, 0x01 },
			{ 0x01, 0x02, 0x03, 0x01 }, { 0x01, 0x01, 0x02, 0x03 }, { 0x03,
					0x01, 0x01, 0x02 } };
	const byte* temp = GFMultplyBytesMatrix((byte*) matrix, state);
	for (int i = 0; i < 16; ++i) {
		state[i] = temp[i];
	}
	delete[] temp;
}

void AES::InvMixColumns() { //    列混淆反演
	byte matrix[4][4] = { { 0x0e, 0x0b, 0x0d, 0x09 },
			{ 0x09, 0x0e, 0x0b, 0x0d }, { 0x0d, 0x09, 0x0e, 0x0b }, { 0x0b,
					0x0d, 0x09, 0x0e } };
	const byte* temp = GFMultplyBytesMatrix((byte*) matrix, state);
	for (int i = 0; i < 16; ++i) {
		state[i] = temp[i];
	}
	delete[] temp;
}

void AES::BuildSBox() { //    构建S盒
	byte box[16][16] = {
	/*        0     1     2     3     4     5     6     7     8     9     a     b     c     d     e     f */
	/*0*/{ 0x63, 0x7c, 0x77, 0x7b, 0xf2, 0x6b, 0x6f, 0xc5, 0x30, 0x01, 0x67,
			0x2b, 0xfe, 0xd7, 0xab, 0x76 },
	/*1*/{ 0xca, 0x82, 0xc9, 0x7d, 0xfa, 0x59, 0x47, 0xf0, 0xad, 0xd4, 0xa2,
			0xaf, 0x9c, 0xa4, 0x72, 0xc0 },
	/*2*/{ 0xb7, 0xfd, 0x93, 0x26, 0x36, 0x3f, 0xf7, 0xcc, 0x34, 0xa5, 0xe5,
			0xf1, 0x71, 0xd8, 0x31, 0x15 },
	/*3*/{ 0x04, 0xc7, 0x23, 0xc3, 0x18, 0x96, 0x05, 0x9a, 0x07, 0x12, 0x80,
			0xe2, 0xeb, 0x27, 0xb2, 0x75 },
	/*4*/{ 0x09, 0x83, 0x2c, 0x1a, 0x1b, 0x6e, 0x5a, 0xa0, 0x52, 0x3b, 0xd6,
			0xb3, 0x29, 0xe3, 0x2f, 0x84 },
	/*5*/{ 0x53, 0xd1, 0x00, 0xed, 0x20, 0xfc, 0xb1, 0x5b, 0x6a, 0xcb, 0xbe,
			0x39, 0x4a, 0x4c, 0x58, 0xcf },
	/*6*/{ 0xd0, 0xef, 0xaa, 0xfb, 0x43, 0x4d, 0x33, 0x85, 0x45, 0xf9, 0x02,
			0x7f, 0x50, 0x3c, 0x9f, 0xa8 },
	/*7*/{ 0x51, 0xa3, 0x40, 0x8f, 0x92, 0x9d, 0x38, 0xf5, 0xbc, 0xb6, 0xda,
			0x21, 0x10, 0xff, 0xf3, 0xd2 },
	/*8*/{ 0xcd, 0x0c, 0x13, 0xec, 0x5f, 0x97, 0x44, 0x17, 0xc4, 0xa7, 0x7e,
			0x3d, 0x64, 0x5d, 0x19, 0x73 },
	/*9*/{ 0x60, 0x81, 0x4f, 0xdc, 0x22, 0x2a, 0x90, 0x88, 0x46, 0xee, 0xb8,
			0x14, 0xde, 0x5e, 0x0b, 0xdb },
	/*a*/{ 0xe0, 0x32, 0x3a, 0x0a, 0x49, 0x06, 0x24, 0x5c, 0xc2, 0xd3, 0xac,
			0x62, 0x91, 0x95, 0xe4, 0x79 },
	/*b*/{ 0xe7, 0xc8, 0x37, 0x6d, 0x8d, 0xd5, 0x4e, 0xa9, 0x6c, 0x56, 0xf4,
			0xea, 0x65, 0x7a, 0xae, 0x08 },
	/*c*/{ 0xba, 0x78, 0x25, 0x2e, 0x1c, 0xa6, 0xb4, 0xc6, 0xe8, 0xdd, 0x74,
			0x1f, 0x4b, 0xbd, 0x8b, 0x8a },
	/*d*/{ 0x70, 0x3e, 0xb5, 0x66, 0x48, 0x03, 0xf6, 0x0e, 0x61, 0x35, 0x57,
			0xb9, 0x86, 0xc1, 0x1d, 0x9e },
	/*e*/{ 0xe1, 0xf8, 0x98, 0x11, 0x69, 0xd9, 0x8e, 0x94, 0x9b, 0x1e, 0x87,
			0xe9, 0xce, 0x55, 0x28, 0xdf },
	/*f*/{ 0x8c, 0xa1, 0x89, 0x0d, 0xbf, 0xe6, 0x42, 0x68, 0x41, 0x99, 0x2d,
			0x0f, 0xb0, 0x54, 0xbb, 0x16 } };
	for (int i = 0; i < 16; ++i) {
		for (int j = 0; j < 16; ++j) {
			SBox[i][j] = box[i][j];
		}
	}
}

void AES::BuildInvSBox() { //    构建逆S盒
	byte box[16][16] = {
	/*        0     1     2     3     4     5     6     7     8     9     a     b     c     d     e     f */
	/*0*/{ 0x52, 0x09, 0x6a, 0xd5, 0x30, 0x36, 0xa5, 0x38, 0xbf, 0x40, 0xa3,
			0x9e, 0x81, 0xf3, 0xd7, 0xfb },
	/*1*/{ 0x7c, 0xe3, 0x39, 0x82, 0x9b, 0x2f, 0xff, 0x87, 0x34, 0x8e, 0x43,
			0x44, 0xc4, 0xde, 0xe9, 0xcb },
	/*2*/{ 0x54, 0x7b, 0x94, 0x32, 0xa6, 0xc2, 0x23, 0x3d, 0xee, 0x4c, 0x95,
			0x0b, 0x42, 0xfa, 0xc3, 0x4e },
	/*3*/{ 0x08, 0x2e, 0xa1, 0x66, 0x28, 0xd9, 0x24, 0xb2, 0x76, 0x5b, 0xa2,
			0x49, 0x6d, 0x8b, 0xd1, 0x25 },
	/*4*/{ 0x72, 0xf8, 0xf6, 0x64, 0x86, 0x68, 0x98, 0x16, 0xd4, 0xa4, 0x5c,
			0xcc, 0x5d, 0x65, 0xb6, 0x92 },
	/*5*/{ 0x6c, 0x70, 0x48, 0x50, 0xfd, 0xed, 0xb9, 0xda, 0x5e, 0x15, 0x46,
			0x57, 0xa7, 0x8d, 0x9d, 0x84 },
	/*6*/{ 0x90, 0xd8, 0xab, 0x00, 0x8c, 0xbc, 0xd3, 0x0a, 0xf7, 0xe4, 0x58,
			0x05, 0xb8, 0xb3, 0x45, 0x06 },
	/*7*/{ 0xd0, 0x2c, 0x1e, 0x8f, 0xca, 0x3f, 0x0f, 0x02, 0xc1, 0xaf, 0xbd,
			0x03, 0x01, 0x13, 0x8a, 0x6b },
	/*8*/{ 0x3a, 0x91, 0x11, 0x41, 0x4f, 0x67, 0xdc, 0xea, 0x97, 0xf2, 0xcf,
			0xce, 0xf0, 0xb4, 0xe6, 0x73 },
	/*9*/{ 0x96, 0xac, 0x74, 0x22, 0xe7, 0xad, 0x35, 0x85, 0xe2, 0xf9, 0x37,
			0xe8, 0x1c, 0x75, 0xdf, 0x6e },
	/*a*/{ 0x47, 0xf1, 0x1a, 0x71, 0x1d, 0x29, 0xc5, 0x89, 0x6f, 0xb7, 0x62,
			0x0e, 0xaa, 0x18, 0xbe, 0x1b },
	/*b*/{ 0xfc, 0x56, 0x3e, 0x4b, 0xc6, 0xd2, 0x79, 0x20, 0x9a, 0xdb, 0xc0,
			0xfe, 0x78, 0xcd, 0x5a, 0xf4 },
	/*c*/{ 0x1f, 0xdd, 0xa8, 0x33, 0x88, 0x07, 0xc7, 0x31, 0xb1, 0x12, 0x10,
			0x59, 0x27, 0x80, 0xec, 0x5f },
	/*d*/{ 0x60, 0x51, 0x7f, 0xa9, 0x19, 0xb5, 0x4a, 0x0d, 0x2d, 0xe5, 0x7a,
			0x9f, 0x93, 0xc9, 0x9c, 0xef },
	/*e*/{ 0xa0, 0xe0, 0x3b, 0x4d, 0xae, 0x2a, 0xf5, 0xb0, 0xc8, 0xeb, 0xbb,
			0x3c, 0x83, 0x53, 0x99, 0x61 },
	/*f*/{ 0x17, 0x2b, 0x04, 0x7e, 0xba, 0x77, 0xd6, 0x26, 0xe1, 0x69, 0x14,
			0x63, 0x55, 0x21, 0x0c, 0x7d } };
	for (int i = 0; i < 16; ++i) {
		for (int j = 0; j < 16; ++j) {
			InvSBox[i][j] = box[i][j];
		}
	}
}

void AES::InitialState(const byte* text) { //    state初始时候为明(密)文矩阵的转置矩阵
	for (int i = 0; i < 4; ++i) { //转置text存放在state中
		for (int j = 0; j < 4; ++j) {
			state[4 * i + j] = text[4 * j + i];
		}
	}
}

void AES::InitialCipherText() { //    state被复制到输出矩阵中
	for (int i = 0; i < 4; ++i) { //转置state存放在cipherText中
		for (int j = 0; j < 4; ++j) {
			cipherText[4 * i + j] = state[4 * j + i];
		}
	}
}

void AES::InitialplainText() { //    state被复制到输入矩阵中
	for (int i = 0; i < 4; ++i) { //转置state存放在plainText中
		for (int j = 0; j < 4; ++j) {
			plainText[4 * i + j] = state[4 * j + i];
		}
	}
}

AES::byte AES::GFMultplyByte(const byte& left, const byte& right) { //有限域GF(2^8)上的乘法
	byte temp[8];
	unsigned long uRight = (unsigned long) right;
	bitset < 8 > bits((int) right); //把right化为8个二进制位存放在bits中
	unsigned short bits1[8] = { 0 };
	for (int i = 0; i < 8; i++) {
		bits1[i] = uRight % 2;
		uRight /= 2;
	}

	//memcpy(bits1, &right, 1);
	temp[0] = left;
	for (int i = 1; i < 8; ++i) {
		if (temp[i - 1] >= 0x80) //若 (temp[i-1] 首位为"1"
				{
			temp[i] = temp[i - 1] << 1;
			temp[i] = temp[i] ^ 0x1b; //与(00011011)异或
		} else {
			temp[i] = temp[i - 1] << 1;
		}
	}
	byte result = 0x00;
	for (int i = 0; i < 8; ++i) {
		if (bits[i] == 1) {
			result ^= temp[i];
		}
	}
	return result;
}

const AES::byte* AES::GFMultplyBytesMatrix(const byte* left,
		const byte* right) { //有限域GF(2^8)上的矩阵(4*4)乘法
	AES::byte* result = new AES::byte[16];
	for (int i = 0; i < 4; ++i) {
		for (int j = 0; j < 4; ++j) {
			result[4 * i + j] = GFMultplyByte(left[4 * i], right[j]);
			for (int k = 1; k < 4; ++k) {
				result[4 * i + j] ^= GFMultplyByte(left[4 * i + k],
						right[4 * k + j]);
			}
		}
	}
	return result;
}

AES::AES(const char * key) {
	memcpy(m_key, key, 16);
	BuildSBox();
	BuildInvSBox();
}

const AES::byte* AES::Cipher(const byte* text, const byte* key,
		const int& keySize) { //    用key给text加密
	for (int i = 0; i < 16; ++i) {
		plainText[i] = text[i];
	}

	for (int i = 0; i < keySize; ++i) {
		cipherKey[i] = key[i];
	}

	EncryptionProcess();
	return cipherText;
}

const AES::byte* AES::InvCipher(const byte* text, const byte* key,
		const int& keySize) { //    用key给text解密
	for (int i = 0; i < 16; ++i) {
		cipherText[i] = text[i];
	}

	for (int i = 0; i < keySize; ++i) {
		cipherKey[i] = key[i];
	}

	DecryptionProcess();
	return plainText;
}

//
//在c++代码中的 jstring转c char操作
char* Jstring2CStr(JNIEnv* env, jstring jstr) {
	char* rtn = NULL;
	jclass clsstring = (env)->FindClass("java/lang/String");
	jstring strencode = (env)->NewStringUTF("GB2312");
	jmethodID mid = (env)->GetMethodID(clsstring, "getBytes",
			"(Ljava/lang/String;)[B");
	jbyteArray barr = (jbyteArray)(env)->CallObjectMethod(jstr, mid, strencode); // String .getByte("GB2312");
	jsize alen = (env)->GetArrayLength(barr);
	jbyte* ba = (env)->GetByteArrayElements(barr, JNI_FALSE);
	if (alen > 0) {
		rtn = (char*) malloc(alen + 1); //"\0"
		memcpy(rtn, ba, alen);
		rtn[alen] = 0;
	}
	(env)->ReleaseByteArrayElements(barr, ba, 0); //
	return rtn;
}

JNIEXPORT jstring JNICALL Java_cn_bao_AESActivity_encryption(JNIEnv * env,
		jobject obj, jstring src, jint len, jstring key) {
	const char*  src0 =  Jstring2CStr(env,src);
	const char*  key0 = Jstring2CStr(env,key);
	string ss = AES::s_Encryption(src0, len, key0 );
	const char* s = ss.c_str();
	LOGI(s);
	return (env)->NewStringUTF(s);
}
JNIEXPORT jstring JNICALL Java_cn_bao_AESActivity_dncryption(JNIEnv * env,
		jobject obj, jstring src, jint len, jstring key) {
	const char*  src0 =  Jstring2CStr(env,src);
	const char*  key0 = Jstring2CStr(env,key);
	string ss = AES::s_Decryption(src0, len, key0 );
	const char* s = ss.c_str();
	LOGI(s);
	return (env)->NewStringUTF(s);
}

貌似传不了压缩文件 需要的话 346126185@qqcom

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值