Próbuję podpisać moją wiadomość do Amazon AWS (w teście JUnit), ale napotkałem problem. Oto kod używam:Generowanie podpisu HmacSHA256 w JUnit
String secretAccessKey = "secret1234678901";
SecretKeySpec keySpec = new SecretKeySpec(secretAccessKey.getBytes(UTF-8), "HmacSHA256");
Mac mac = Mac.getInstance(this.MAC_ALGO);
mac.init(keySpec); // here it breaks
byte[] encoded = mac.doFinal(
request.toString().getBytes(this.CHARSET));
return Base64.encodeBase64URLSafeString(encoded);
W wierszu oznaczonym (mac.init(...)
) java zgłasza wyjątek:
java.lang.ClassCastException: com.sun.crypto.provider.HmacSHA1 cannot be cast to javax.crypto.MacSpi
at javax.crypto.Mac.a(DashoA13*..)
at javax.crypto.Mac.init(DashoA13*..)
Czy wiesz, dlaczego tak się dzieje? Wszystkie kody, które widziałem w sieci wyglądają prawie dokładnie tak, próbowałem również z HmacSHA1, z takimi samymi wynikami.
Ten wyjątek sugeruje, że konfiguracja Java jest bardzo zła. Czy może mieszkasz we własnej wersji jce.jar gdzieś w ścieżce klasowej Java? Nowoczesna Java ma już wbudowane wszystkie biblioteki kryptograficzne. –
Uwaga: opublikowany przez Ciebie kod nie jest kompilowany, a jeśli wprowadzisz zmiany, które pozwolą mu się skompilować, nigdy nie wyświetliłby się ten komunikat o błędzie (określasz "HmacSHA256", ale komunikat o błędzie mówi "HmacSHA1"). Przypuszczam, że błąd konfiguracji, jak powiedział Greg. –