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 gwas 分析-数据质控之过滤稀有突变中出现的问题
  • ¥15 没有注册类 (异常来自 HRESULT: 0x80040154 (REGDB_E_CLASSNOTREG))
  • ¥15 知识蒸馏实战博客问题
  • ¥15 用PLC设计纸袋糊底机送料系统
  • ¥15 simulink仿真中dtc控制永磁同步电机如何控制开关频率
  • ¥15 用C语言输入方程怎么
  • ¥15 网站显示不安全连接问题
  • ¥15 51单片机显示器问题
  • ¥20 关于#qt#的问题:Qt代码的移植问题
  • ¥50 求图像处理的matlab方案