gpt4 book ai didi

java - 如何在不同 Activity 的android studio中加密/解密文本

转载 作者:行者123 更新时间:2023-12-02 10:00:46 31 4
gpt4 key购买 nike

我尝试在 android studio 中开发一个文本加密/解密应用程序。因此,我在 MainActivity.java 上运行了加密和解密的示例代码。

MainActivity.java

import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays;
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;

public class MainActivity extends AppCompatActivity {

Button btn,btn2;
static final String TAG = "SymmetricAlgorithmAES";
String secr="k";
String secr2="d";

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

//code to use my specified defined key
byte[] key = new byte[0];
try {
key = (secr+secr2).getBytes("UTF-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
MessageDigest sha = null;
try {
sha = MessageDigest.getInstance("SHA-1");
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
key = sha.digest(key);
key = Arrays.copyOf(key, 16); // use only first 128 bit

SecretKeySpec sks = new SecretKeySpec(key, "AES");

// Original text
String theTestText = "This is just a simple test";
TextView tvorig = (TextView)findViewById(R.id.tvorig);
tvorig.setText("\n[ORIGINAL]:\n" + theTestText + "\n");

// Encode the original data with AES
byte[] encodedBytes = null;
try {
Cipher c = Cipher.getInstance("AES");
c.init(Cipher.ENCRYPT_MODE, sks);
encodedBytes = c.doFinal(theTestText.getBytes());
} catch (Exception e) {
Log.e(TAG, "AES encryption error");
}
TextView tvencoded = (TextView)findViewById(R.id.tvencoded);
tvencoded.setText("" +
Base64.encodeToString(encodedBytes, Base64.DEFAULT) + "\n");

// Decode the encoded data with AES
byte[] decodedBytes = null;
try {
Cipher c = Cipher.getInstance("AES");
c.init(Cipher.DECRYPT_MODE, sks);
decodedBytes = c.doFinal(encodedBytes);
} catch (Exception e) {
Log.e(TAG, "AES decryption error");
}
TextView tvdecoded = (TextView)findViewById(R.id.tvdecoded);
tvdecoded.setText("[DECODED]:\n" + new String(decodedBytes) + "\n");

}

上面的代码可以正常工作并输出正确的结果。但是当我尝试修改代码并尝试在不同的 Activity 中编写加密和解密时,但解密部分无法正常工作。

这是加密部分的代码,它可以正常工作,没有任何错误。

加密.java

import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays;
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;

public class Encryption extends AppCompatActivity {

static final String TAG = "SymmetricAlgorithmAES";
String secr="k";
String secr2="d";

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.encryption);
enc_text_edt=(EditText)findViewById(R.id.enc_text_edt);
enc_text_btn=(Button)findViewById(R.id.enc_text_btn);
enctv=(TextView)findViewById(R.id.enctv);

//code to use my specified defined key
byte[] key = new byte[0];
try {
key = (secr+secr2).getBytes("UTF-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
MessageDigest sha = null;
try {
sha = MessageDigest.getInstance("SHA-1");
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
key = sha.digest(key);
key = Arrays.copyOf(key, 16); // use only first 128 bit

SecretKeySpec sks = new SecretKeySpec(key, "AES");

final SecretKeySpec finalSks = sks;
enc_text_btn.setOnClickListener(new OnClickListener() {

@Override
public void onClick(View v) {
try {

// Encode the original data with AES
byte[] encodedBytes = null;
try {
Cipher c = Cipher.getInstance("AES");
c.init(Cipher.ENCRYPT_MODE, finalSks);
encodedBytes = c.doFinal(enc_text_edt.getText().toString().getBytes());
} catch (Exception e) {
Log.e(TAG, "AES encryption error");
}


enctv.setText("[ENCRYPTED]:\n" +
Base64.encodeToString(encodedBytes, Base64.DEFAULT) + "\n");


enc_text_edt.setText("");


} catch (Exception e) {

e.printStackTrace();
}

}
});
}
}

解密代码

解密.java

import java.io.UnsupportedEncodingException;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.util.Arrays;
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;

public class Decryption extends AppCompatActivity {

Button dec_text_btn;
TextView dec_edtext_view, dectv;

static final String TAG = "SymmetricAlgorithmAES";
String secr = "k";
String secr2 = "d";

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.decryption);
dec_text_btn = (Button) findViewById(R.id.dec_text_btn);
dec_edtext_view = (EditText) findViewById(R.id.dec_edtext_view);
dectv = (TextView) findViewById(R.id.dectv);


//code to use my specified defined key
byte[] key = new byte[0];
try {
key = (secr + secr2).getBytes("UTF-8");
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
MessageDigest sha = null;
try {
sha = MessageDigest.getInstance("SHA-1");
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
key = sha.digest(key);
key = Arrays.copyOf(key, 16); // use only first 128 bit

SecretKeySpec sks = new SecretKeySpec(key, "AES");


final SecretKeySpec finalSks = sks;
dec_text_btn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {

try {

// Decode the encoded data with AES

byte[] decodedBytes = null;
try {
Cipher c = Cipher.getInstance("AES");
c.init(Cipher.DECRYPT_MODE, finalSks);
decodedBytes= c.doFinal(dec_edtext_view.getText().toString().getBytes());
} catch (Exception e) {
Log.e(TAG, "AES encryption error");
}

dectv.setText("[DECRYPTED]:\n" + new String(decodedBytes) + "\n");


} catch (Exception e) {
e.printStackTrace();
Toast.makeText(getApplicationContext(), "creptography exception see log cat....", Toast.LENGTH_SHORT).show();
}
}
});
}
}

请帮我解决这个错误。在执行解密部分时,它直接显示异常“creptography error see log cat”

最佳答案

读完你的代码后,我想我发现了问题,你编码为 Base64 但从未解码。在加密中,您执行以下操作

enctv.setText("[ENCRYPTED]:\n" +
Base64.encodeToString(encodedBytes, Base64.DEFAULT) + "\n");

我可以猜测用户将其复制到解密字段,但在他们单击按钮后,您就会这样做

decodedBytes= c.doFinal(dec_edtext_view.getText().toString().getBytes());

而不是从 Base64 解码。我还想添加一些注释:你的安全性并不安全,当 key 位于像这样的平面站点时,你几乎没有实现任何安全层。

注1:

key 应使用 SecureRandom 随机生成。您可以通过执行以下操作轻松完成:

byte[] key = new byte[16];
new SecureRandom().nextBytes(key);

注2:

使用 initialization vector aka IV如果用户输入了相同的消息,这非常有用。例如,考虑以下场景,您加密“Hello World”,结果为“ABCDEFGHIJK”。现在你再次发送它,它又是“ABCDEFGHIJK”。对于 IV,只要您为每条消息生成一个新的 IV,每次都会不同,您应该将此 IV 附加到消息中,以便稍后在解密时可以提取它。

注3:

声明Cipher时,使用的不仅仅是AES。有一篇关于如何提高安全性和知识的精彩文章:article link

注4:

如果发生异常,不要像什么都没发生一样继续执行,您应该正确处理它,而不是继续执行取决于导致异常的原因的代码。

注5:

更深入地学习Java,而不是跳到密码学,你的字段应该是私有(private)的,并且如果你稍后可能计划使用它,并且检查它是否为空,则某些final不要声明为空。不要在 get bytes 中声明“UTF-8”,使用常量声明 Charset例如“UTF-8”,这可以使用 Charset.forName("UTF-8")

轻松完成

关于java - 如何在不同 Activity 的android studio中加密/解密文本,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55656864/

31 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com