详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt165
DES 支持8位加密解密,3Des支持24位,Aes支持32位。3Des是Des算法做三次。位数的单位是字节byte,不是bits。
3Des是把24位分成3组,第一组八位用来加密,第二组8位用于解密,第三组8位用于加密,所以,如果秘钥为123456781234567812345678(3组1-8),则相当于做了一次12345678的Des加密。例如:第一次用12345678秘钥对123进行加密得到 "LDiFUdf0iew=",然后用第二组的12345678对其进行解密(逆向加密过程),得到了123,第三次又一次加密得到 "LDiFUdf0iew="。
三种加密方式代码里不同的地方:
byte temp[] = new byte[位数];
SecretKey des_key = new SecretKeySpec(temp, "加密算法");
加密算法名对应的是:Aes Des Desede
改了这两个地方就可以实现不同加密方式。加密方式底层不一样,DES是把原文编程2进制的一串01,然后和密文做运算,交换什么什么位置。
[java] view plaincopyprint?
-
public class MainActivity extends Activity implements OnClickListener {
-
-
private EditText des_key, des_src, des_dst;
-
private Button btn_encode, btn_decode;
-
-
@Override
-
protected void onCreate(Bundle savedInstanceState) {
-
super.onCreate(savedInstanceState);
-
setContentView(R.layout.activity_main);
-
des_key = (EditText) findViewById(R.id.des_key);
-
des_src = (EditText) findViewById(R.id.des_src);
-
des_dst = (EditText) findViewById(R.id.des_dst);
-
btn_encode = (Button) findViewById(R.id.btn_encode);
-
btn_decode = (Button) findViewById(R.id.btn_decode);
-
btn_encode.setOnClickListener(this);
-
btn_decode.setOnClickListener(this);
-
}
-
-
@Override
-
public void onClick(View v) {
-
String key_str = des_key.getText().toString();
-
if (!TextUtils.isEmpty(key_str)) {
-
try {
-
// DES不管长了短了,都变成八位
-
// AES 长度变为128 new SecretKeySpec(temp, "Aes");
-
// 3Des 长度变为24 new SecretKeySpec(temp, "Desced");
-
byte temp[] = new byte[8];
-
byte b[] = key_str.getBytes("UTF-8");
-
System.arraycopy(b, 0, temp, 0, Math.min(b.length, temp.length));
-
// Des只支持八位
-
SecretKey des_key = new SecretKeySpec(temp, "Des");
-
Cipher cipher = Cipher.getInstance("Des");
-
switch (v.getId()) {
-
case R.id.btn_encode:
-
String src_str = des_src.getText().toString();
-
if (!TextUtils.isEmpty(src_str)) {
-
cipher.init(Cipher.ENCRYPT_MODE, des_key);
-
byte[] bytes = cipher
-
.doFinal(src_str.getBytes("UTF-8"));
-
// 是用Base64编码的二进制字节数组
-
des_dst.setText(Base64.encodeToString(bytes,
-
Base64.DEFAULT));
-
}
-
break;
-
-
case R.id.btn_decode:
-
String dst_str = des_dst.getText().toString();
-
if (!TextUtils.isEmpty(dst_str)) {
-
cipher.init(Cipher.DECRYPT_MODE, des_key);
-
// 是用Base64编码的二进制字节数组
-
byte[] bytes = cipher.doFinal(Base64.decode(dst_str,
-
Base64.DEFAULT));
-
des_src.setText(new String(bytes, "UTF-8"));
-
}
-
break;
-
}
-
} catch (Exception e) {
-
e.printStackTrace();
-
}
-
}
-
}
-
}
布局:
[java] view plaincopyprint?
-
<span style="font-size:18px;"><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
-
xmlns:tools="http://schemas.android.com/tools"
-
android:layout_width="match_parent"
-
android:layout_height="match_parent"
-
android:orientation="vertical" >
-
-
<EditText
-
android:id="@+id/des_key"
-
android:layout_width="wrap_content"
-
android:layout_height="wrap_content"
-
android:hint="秘钥" />
-
-
<EditText
-
android:id="@+id/des_src"
-
android:layout_width="wrap_content"
-
android:layout_height="wrap_content"
-
android:hint="原文" />
-
-
<EditText
-
android:id="@+id/des_dst"
-
android:layout_width="wrap_content"
-
android:layout_height="wrap_content"
-
android:hint="密文" />
-
-
<Button
-
android:id="@+id/btn_encode"
-
android:layout_width="wrap_content"
-
android:layout_height="wrap_content"
-
android:text="加密" />
-
-
<Button
-
android:id="@+id/btn_decode"
-
android:layout_width="wrap_content"
-
android:layout_height="wrap_content"
-
android:text="解密" />
-
-
</LinearLayout></span>