怎样将一个BigIntger转化为Key类型(java.security.Key)?

假定A和B需要加密通信,A生成对称密钥作为会话密钥,并用B的公钥加密发送给给B,然后B用自己的私钥解密,得到会话密钥,之后A、B就可以进行加密会话。但是B用自己的私钥解密A发送的密文,所得到的明文(即会话密钥)是BigIntger类型,而会话密钥需要Key类型(java.security.Key),请问怎样将BigIntger转化为Key呢?或者有其他的解决方法。
就相当于用RSA的公钥将一个对称密钥Key加密,然后再用私钥解密,希望得到之前的Key,但是解密后得到的是一个BigIntger。问题是怎样将这个BigIntger转化为Key。(Key为java.security.Key)。

[code="java"] BigInteger bi = ...
byte[] keyData = bi.toByteArray();
DESedeKeySpec dks = new DESedeKeySpec(keyData);

    // 创建一个密匙工厂,然后用它把DESKeySpec对象转换成
    // 一个SecretKey对象
    SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DESede");
    SecretKey key = keyFactory.generateSecret(dks);

    // Cipher对象实际完成解密操作
    Cipher cipher = Cipher.getInstance("DESede/ECB/PKCS5Padding");
    //加密模式或者解密模式
    cipher.init(mode, key);

[/code]

要构造密钥,首先要得到byte[],然后就可以构建密钥了,以上代码示例是3DES的方法,也可以有DESKeySpec的,就可以生成DES的密钥了,由于是对应密钥,可以加密解密都是同一个Cipher,唯一不一样的,就是初始化的时候,调用的模式不一样。

类似于以下代码片段,可以很方便地从一个BigInteger里面得到公钥,其实得到私钥也类似.

[code="java"] RSAPublicKeySpec spec = new RSAPublicKeySpec(
new BigInteger("927321219108191188192454569763745602147214015229557936097354256005974097464099944041666463372411387482328205814612927555494004002976236328694380670117007523840161137245287537169073992881854806711105661235339513837968681937188076986711955020950458557207058206667509795039363187844689446814329102216798122222277649"),
new BigInteger("65537"));

        PublicKey key = KeyFactory.getInstance("RSA").generatePublic(spec);

        Cipher cipher = Cipher.getInstance("RSA");
        cipher.init(Cipher.DECRYPT_MODE, key);
        byte[] encryt = cipher.doFinal(data);[/code]