在amazon中运行jar后,我遇到了这个特殊的错误。它在我的OsX上运行得很好。我在这两台机器上都使用相同的公钥和私钥。唯一的区别是java版本,它是
我制作、测试和编译脚本的机器:
Java(TM) SE运行时环境(build 1.6.0_65-b14-462-11M4609)
Amazon服务器:
OpenJDK运行时环境(amzn-2.4.7.1.40.amzn1-x86_64 u55-b13)
这是脚本中导致错误的部分:
public PublicKey getPublicKey(String _file)
throws
NoSuchAlgorithmException,
NoSuchProviderException,
InvalidKeySpecException,
IOException
{
X509EncodedKeySpec _spec = new X509EncodedKeySpec(_getFileContents(_file));
KeyFactory _keyFactory = KeyFactory.getInstance(this._keyFactoryAlgo, this._provider);
this._publicKey = _keyFactory.generatePublic(_spec);
return this._publicKey;
}GetFileContents:
private byte[] _getFileContents(String _fileName) throws IOException
{
File _file = new File(_fileName);
FileInputStream _fileStream = new FileInputStream(_file);
byte[] _contents = new byte[(int) _file.length()];
_fileStream.read(_contents);
if(_fileStream != null)
{
_fileStream.close();
_fileStream = null;
}
return _contents;
}以下是完整的错误消息:
java.security.spec.InvalidKeySpecException: encoded key spec not recognised
at org.bouncycastle.jcajce.provider.asymmetric.util.BaseKeyFactorySpi.engineGeneratePublic(Unknown Source)
at org.bouncycastle.jcajce.provider.asymmetric.rsa.KeyFactorySpi.engineGeneratePublic(Unknown Source)
at java.security.KeyFactory.generatePublic(KeyFactory.java:328)
at xxx.CryptKey.getPublicKey(CryptKey.java:167)
at xxx.CryptSession.encryptWithPublicKey(CryptSession.java:316)
at xxx.Crypt.encrypt(Crypt.java:57)
at snippet.Snippet.main(Snippet.java:201)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:57)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:606)
at org.eclipse.jdt.internal.jarinjarloader.JarRsrcLoader.main(JarRsrcLoader.java:58)发布于 2014-05-16 04:42:27
您确实读错了文件。您忽略了InputStream.read()的返回值。您应该在循环中调用此方法,因为单个调用不能保证读取整个字节数组。
您可以手动阅读:
int offset = 0;
int read = _fileStream.read(_contents, 0, contents.length);
while (read > 0) {
offset += read;
read = _fileStream.read(_contents, offset , contents.length - offset );
}或者,您可以将底层输入流封装到DataInputStream中,只需使用DataInputStream.readFully()方法。
https://stackoverflow.com/questions/23691995
复制相似问题