FitPual 2014-05-16 06:32 采纳率: 0%
浏览 3173

用C#解密JAVA的AES加密字符串

附JAVA的加密方法

public static String encrypt(String s, String token) {
try {
byte[] key = Hex.toBytes(token);
return encryptBase64URLSafe(s, key);
} catch (Exception e) {
// e.printStackTrace();
return null;
}
}
public static byte[] toBytes(String s) {
int len = s.length();
byte[] data = new byte[len / 2];
for (int i = 0; i < len; i += 2) {
data[i / 2] = (byte) ((Character.digit(s.charAt(i), 16) << 4)
+ Character.digit(s.charAt(i + 1), 16));
}
return data;
}
private static String encryptBase64URLSafe(String s, byte[] key) {
BaseEncoding b64 = BaseEncoding.base64Url().omitPadding();
byte[] encryptedBytes = encryptBytes(s, key);
return b64.encode(encryptedBytes);
}
private static byte[] encryptBytes(String s, byte[] key) {
if (key == null) {
return null;
}
// 判断Key是否为16位
if (key.length != 16) {
return null;
}
SecretKeySpec skeySpec = new SecretKeySpec(key, "AES");
try {
Cipher cipher = Cipher.getInstance(ALGORITHM);

        cipher.init(Cipher.ENCRYPT_MODE, skeySpec);
        byte[] encrypted = cipher.doFinal(s.getBytes("utf-8"));
        return encrypted;
    } catch (Exception e) {
        return null;
    }
}

这个用C#怎么解密啊,大家帮帮忙,我尝试了很多方法都不行
在Convert.FromBase64String(encryptedText);时就报错

  • 写回答

1条回答 默认 最新

  • oyljerry 2015-01-02 03:06
    关注

    保证加解密算法是对称的
    其实加解密的数据格式都一致

    评论

报告相同问题?

悬赏问题

  • ¥15 如何用stata画出文献中常见的安慰剂检验图
  • ¥15 c语言链表结构体数据插入
  • ¥40 使用MATLAB解答线性代数问题
  • ¥15 COCOS的问题COCOS的问题
  • ¥15 FPGA-SRIO初始化失败
  • ¥15 MapReduce实现倒排索引失败
  • ¥15 ZABBIX6.0L连接数据库报错,如何解决?(操作系统-centos)
  • ¥15 找一位技术过硬的游戏pj程序员
  • ¥15 matlab生成电测深三层曲线模型代码
  • ¥50 随机森林与房贷信用风险模型