AESUtil.smali
.class public Lcom/iflytek/cloud/msc/util/AESUtil;
.super Ljava/lang/Object;
.source "SourceFile"
# static fields
.field private static final CipherMode:Ljava/lang/String; = "AES/ECB/PKCS5Padding"
# direct methods
.method public constructor <init>()V
.registers 1
.prologue
.line 12
invoke-direct {p0}, Ljava/lang/Object;-><init>()V
return-void
.end method
.method public static byte2hex([B)Ljava/lang/String;
.registers 6
.prologue
.line 173
new-instance v1, Ljava/lang/StringBuffer;
array-length v0, p0
mul-int/lit8 v0, v0, 0x2
invoke-direct {v1, v0}, Ljava/lang/StringBuffer;-><init>(I)V
.line 174
const-string v0, ""
.line 175
const/4 v0, 0x0
:goto_b
array-length v2, p0
if-ge v0, v2, :cond_28
.line 177
aget-byte v2, p0, v0
and-int/lit16 v2, v2, 0xff
invoke-static {v2}, Ljava/lang/Integer;->toHexString(I)Ljava/lang/String;
move-result-object v2
.line 178
invoke-virtual {v2}, Ljava/lang/String;->length()I
move-result v3
const/4 v4, 0x1
if-ne v3, v4, :cond_22
.line 179
const-string v3, "0"
invoke-virtual {v1, v3}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
.line 181
:cond_22
invoke-virtual {v1, v2}, Ljava/lang/StringBuffer;->append(Ljava/lang/String;)Ljava/lang/StringBuffer;
.line 175
add-int/lit8 v0, v0, 0x1
goto :goto_b
.line 183
:cond_28
invoke-virtual {v1}, Ljava/lang/StringBuffer;->toString()Ljava/lang/String;
move-result-object v0
invoke-virtual {v0}, Ljava/lang/String;->toUpperCase()Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public static decrypt(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
.registers 6
.prologue
const/4 v1, 0x0
.line 129
.line 131
:try_start_1
invoke-static {p0}, Lcom/iflytek/cloud/msc/util/AESUtil;->hex2byte(Ljava/lang/String;)[B
:try_end_4
.catch Ljava/lang/Exception; {:try_start_1 .. :try_end_4} :catch_10
move-result-object v0
.line 135
:goto_5
invoke-static {p1}, Lcom/iflytek/cloud/msc/util/AESUtil;->hex2byte(Ljava/lang/String;)[B
move-result-object v2
invoke-static {v0, v2}, Lcom/iflytek/cloud/msc/util/AESUtil;->decrypt([B[B)[B
move-result-object v2
.line 136
if-nez v2, :cond_16
.line 144
:goto_f
return-object v1
.line 132
:catch_10
move-exception v0
.line 133
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
move-object v0, v1
goto :goto_5
.line 140
:cond_16
:try_start_16
new-instance v0, Ljava/lang/String;
const-string v3, "UTF-8"
invoke-direct {v0, v2, v3}, Ljava/lang/String;-><init>([BLjava/lang/String;)V
:try_end_1d
.catch Ljava/io/UnsupportedEncodingException; {:try_start_16 .. :try_end_1d} :catch_1f
move-object v1, v0
.line 143
goto :goto_f
.line 141
:catch_1f
move-exception v0
.line 142
invoke-virtual {v0}, Ljava/io/UnsupportedEncodingException;->printStackTrace()V
goto :goto_f
.end method
.method public static decrypt(Ljava/lang/String;[B)Ljava/lang/String;
.registers 6
.prologue
.line 156
:try_start_0
const-string v0, "AES/ECB/PKCS5Padding"
invoke-static {v0}, Ljavax/crypto/Cipher;->getInstance(Ljava/lang/String;)Ljavax/crypto/Cipher;
move-result-object v0
.line 157
const/4 v1, 0x2
new-instance v2, Ljavax/crypto/spec/SecretKeySpec;
const-string v3, "AES"
invoke-direct {v2, p1, v3}, Ljavax/crypto/spec/SecretKeySpec;-><init>([BLjava/lang/String;)V
invoke-virtual {v0, v1, v2}, Ljavax/crypto/Cipher;->init(ILjava/security/Key;)V
.line 158
invoke-static {p0}, Lcom/iflytek/cloud/msc/util/AESUtil;->hex2byte(Ljava/lang/String;)[B
move-result-object v1
invoke-virtual {v0, v1}, Ljavax/crypto/Cipher;->doFinal([B)[B
move-result-object v1
.line 159
new-instance v0, Ljava/lang/String;
const-string v2, "UTF-8"
invoke-direct {v0, v1, v2}, Ljava/lang/String;-><init>([BLjava/lang/String;)V
:try_end_20
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_20} :catch_21
.line 163
:goto_20
return-object v0
.line 160
:catch_21
move-exception v0
.line 161
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
.line 163
const/4 v0, 0x0
goto :goto_20
.end method
.method public static decrypt([B[B)[B
.registers 6
.prologue
.line 111
:try_start_0
const-string v0, "AES/ECB/PKCS5Padding"
invoke-static {v0}, Ljavax/crypto/Cipher;->getInstance(Ljava/lang/String;)Ljavax/crypto/Cipher;
move-result-object v0
.line 112
const/4 v1, 0x2
new-instance v2, Ljavax/crypto/spec/SecretKeySpec;
const-string v3, "AES"
invoke-direct {v2, p1, v3}, Ljavax/crypto/spec/SecretKeySpec;-><init>([BLjava/lang/String;)V
invoke-virtual {v0, v1, v2}, Ljavax/crypto/Cipher;->init(ILjava/security/Key;)V
.line 113
invoke-virtual {v0, p0}, Ljavax/crypto/Cipher;->doFinal([B)[B
:try_end_14
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_14} :catch_16
move-result-object v0
.line 118
:goto_15
return-object v0
.line 115
:catch_16
move-exception v0
.line 116
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
.line 118
const/4 v0, 0x0
goto :goto_15
.end method
.method public static encrypt(Ljava/lang/String;Ljava/lang/String;)Ljava/lang/String;
.registers 6
.prologue
.line 91
const/4 v0, 0x0
.line 93
:try_start_1
const-string v1, "UTF-8"
invoke-virtual {p0, v1}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
:try_end_6
.catch Ljava/lang/Exception; {:try_start_1 .. :try_end_6} :catch_1f
move-result-object v0
.line 97
:goto_7
new-instance v1, Ljavax/crypto/spec/SecretKeySpec;
invoke-static {p1}, Lcom/iflytek/cloud/msc/util/AESUtil;->hex2byte(Ljava/lang/String;)[B
move-result-object v2
const-string v3, "AES"
invoke-direct {v1, v2, v3}, Ljavax/crypto/spec/SecretKeySpec;-><init>([BLjava/lang/String;)V
invoke-virtual {v1}, Ljavax/crypto/spec/SecretKeySpec;->getEncoded()[B
move-result-object v1
invoke-static {v0, v1}, Lcom/iflytek/cloud/msc/util/AESUtil;->encrypt([B[B)[B
move-result-object v0
.line 98
invoke-static {v0}, Lcom/iflytek/cloud/msc/util/AESUtil;->byte2hex([B)Ljava/lang/String;
move-result-object v0
.line 99
return-object v0
.line 94
:catch_1f
move-exception v1
.line 95
invoke-virtual {v1}, Ljava/lang/Exception;->printStackTrace()V
goto :goto_7
.end method
.method public static encrypt(Ljava/lang/String;[B)Ljava/lang/String;
.registers 6
.prologue
.line 72
:try_start_0
const-string v0, "AES/ECB/PKCS5Padding"
invoke-static {v0}, Ljavax/crypto/Cipher;->getInstance(Ljava/lang/String;)Ljavax/crypto/Cipher;
move-result-object v0
.line 73
const/4 v1, 0x1
new-instance v2, Ljavax/crypto/spec/SecretKeySpec;
const-string v3, "AES"
invoke-direct {v2, p1, v3}, Ljavax/crypto/spec/SecretKeySpec;-><init>([BLjava/lang/String;)V
invoke-virtual {v0, v1, v2}, Ljavax/crypto/Cipher;->init(ILjava/security/Key;)V
.line 74
const-string v1, "UTF-8"
invoke-virtual {p0, v1}, Ljava/lang/String;->getBytes(Ljava/lang/String;)[B
move-result-object v1
invoke-virtual {v0, v1}, Ljavax/crypto/Cipher;->doFinal([B)[B
move-result-object v0
.line 75
invoke-static {v0}, Lcom/iflytek/cloud/msc/util/AESUtil;->byte2hex([B)Ljava/lang/String;
:try_end_1e
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_1e} :catch_20
move-result-object v0
.line 80
:goto_1f
return-object v0
.line 77
:catch_20
move-exception v0
.line 78
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
.line 80
const/4 v0, 0x0
goto :goto_1f
.end method
.method public static encrypt([B[B)[B
.registers 6
.prologue
.line 53
:try_start_0
const-string v0, "AES/ECB/PKCS5Padding"
invoke-static {v0}, Ljavax/crypto/Cipher;->getInstance(Ljava/lang/String;)Ljavax/crypto/Cipher;
move-result-object v0
.line 54
const/4 v1, 0x1
new-instance v2, Ljavax/crypto/spec/SecretKeySpec;
const-string v3, "AES"
invoke-direct {v2, p1, v3}, Ljavax/crypto/spec/SecretKeySpec;-><init>([BLjava/lang/String;)V
invoke-virtual {v0, v1, v2}, Ljavax/crypto/Cipher;->init(ILjava/security/Key;)V
.line 55
invoke-virtual {v0, p0}, Ljavax/crypto/Cipher;->doFinal([B)[B
:try_end_14
.catch Ljava/lang/Exception; {:try_start_0 .. :try_end_14} :catch_16
move-result-object v0
.line 60
:goto_15
return-object v0
.line 57
:catch_16
move-exception v0
.line 58
invoke-virtual {v0}, Ljava/lang/Exception;->printStackTrace()V
.line 60
const/4 v0, 0x0
goto :goto_15
.end method
.method public static generateKey()Ljavax/crypto/spec/SecretKeySpec;
.registers 3
.prologue
.line 23
:try_start_0
const-string v0, "AES"
invoke-static {v0}, Ljavax/crypto/KeyGenerator;->getInstance(Ljava/lang/String;)Ljavax/crypto/KeyGenerator;
move-result-object v0
.line 24
const/16 v1, 0x80
new-instance v2, Ljava/security/SecureRandom;
invoke-direct {v2}, Ljava/security/SecureRandom;-><init>()V
invoke-virtual {v0, v1, v2}, Ljavax/crypto/KeyGenerator;->init(ILjava/security/SecureRandom;)V
.line 25
invoke-virtual {v0}, Ljavax/crypto/KeyGenerator;->generateKey()Ljavax/crypto/SecretKey;
move-result-object v0
.line 26
invoke-interface {v0}, Ljavax/crypto/SecretKey;->getEncoded()[B
move-result-object v1
.line 27
new-instance v0, Ljavax/crypto/spec/SecretKeySpec;
const-string v2, "AES"
invoke-direct {v0, v1, v2}, Ljavax/crypto/spec/SecretKeySpec;-><init>([BLjava/lang/String;)V
:try_end_1f
.catch Ljava/security/NoSuchAlgorithmException; {:try_start_0 .. :try_end_1f} :catch_20
.line 32
:goto_1f
return-object v0
.line 29
:catch_20
move-exception v0
.line 30
invoke-virtual {v0}, Ljava/security/NoSuchAlgorithmException;->printStackTrace()V
.line 32
const/4 v0, 0x0
goto :goto_1f
.end method
.method public static generateKeyString()Ljava/lang/String;
.registers 1
.prologue
.line 41
invoke-static {}, Lcom/iflytek/cloud/msc/util/AESUtil;->generateKey()Ljavax/crypto/spec/SecretKeySpec;
move-result-object v0
invoke-virtual {v0}, Ljavax/crypto/spec/SecretKeySpec;->getEncoded()[B
move-result-object v0
invoke-static {v0}, Lcom/iflytek/cloud/msc/util/AESUtil;->byte2hex([B)Ljava/lang/String;
move-result-object v0
return-object v0
.end method
.method public static hex2byte(Ljava/lang/String;)[B
.registers 7
.prologue
const/4 v1, 0x0
.line 193
if-eqz p0, :cond_a
invoke-virtual {p0}, Ljava/lang/String;->length()I
move-result v0
const/4 v2, 0x2
if-ge v0, v2, :cond_d
.line 194
:cond_a
new-array v0, v1, [B
.line 203
:cond_c
return-object v0
.line 196
:cond_d
invoke-virtual {p0}, Ljava/lang/String;->toLowerCase()Ljava/lang/String;
move-result-object v2
.line 197
invoke-virtual {v2}, Ljava/lang/String;->length()I
move-result v0
div-int/lit8 v3, v0, 0x2
.line 198
new-array v0, v3, [B
.line 199
:goto_19
if-ge v1, v3, :cond_c
.line 200
mul-int/lit8 v4, v1, 0x2
mul-int/lit8 v5, v1, 0x2
add-int/lit8 v5, v5, 0x2
invoke-virtual {v2, v4, v5}, Ljava/lang/String;->substring(II)Ljava/lang/String;
move-result-object v4
.line 201
const/16 v5, 0x10
invoke-static {v4, v5}, Ljava/lang/Integer;->parseInt(Ljava/lang/String;I)I
move-result v4
and-int/lit16 v4, v4, 0xff
int-to-byte v4, v4
aput-byte v4, v0, v1
.line 199
add-int/lit8 v1, v1, 0x1
goto :goto_19
.end method