Patrząc tutaj, jak również ogólnie w Internecie, znalazłem Bouncy Castle. Chcę użyć Bouncy Castle (lub jakiegoś innego ogólnodostępnego narzędzia) do wygenerowania SHA-256 Hash String w Javie. Patrząc na ich dokumentację, nie mogę znaleźć dobrych przykładów tego, co chcę zrobić. Czy ktoś może mi pomóc?Hash String przez SHA-256 w Javie
Odpowiedz
hash ciąg, użyj wbudowanej MessageDigest klasy:
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.nio.charset.StandardCharsets;
import java.math.BigInteger;
public class CryptoHash {
public static void main(String[] args) throws NoSuchAlgorithmException {
MessageDigest md = MessageDigest.getInstance("SHA-256");
String text = "Text to hash, cryptographically.";
// Change this to UTF-16 if needed
md.update(text.getBytes(StandardCharsets.UTF_8));
byte[] digest = md.digest();
String hex = String.format("%064x", new BigInteger(1, digest));
System.out.println(hex);
}
}
W powyższym fragmencie, digest
zawiera zaszyfrowany ciąg i hex
zawiera szesnastkowy ciąg ASCII z lewej wypełnianie zerami.
Podczas korzystania hashcodes z dowolnego dostawcy JCE najpierw spróbować uzyskać wystąpienie algorytmu, następnie zaktualizować go z danymi chcesz być mieszany i po zakończeniu nazywasz strawienia, aby uzyskać wartość hash.
MessageDigest sha = MessageDigest.getInstance("SHA-256");
sha.update(in.getBytes());
byte[] digest = sha.digest();
można użyć likwidacji, aby uzyskać wersji base64 lub hex kodowane zgodnie ze swoimi potrzebami
Z ciekawości, możesz przejść od razu do 'digest()' z tablicą bajtów wejściowych, pomijając 'update()'? – ladenedge
Jedną z rzeczy, którą zauważyłem jest to, że działa to z "SHA-256", podczas gdy "SHA256" generuje wyjątek NoSuchAlgorithmException. Bez wielkiej wagi. – KPthunder
Zgodnie z moim komentarzem do Brandona, ** nie używaj 'String.getBytes()' bez określenia kodowania. Obecnie ten kod może dawać różne wyniki na różnych platformach - co jest wadliwym zachowaniem dla dobrze zdefiniowanego skrótu. –
ten jest już realizowany w libs uruchomieniowych.
public static String calc(InputStream is) {
String output;
int read;
byte[] buffer = new byte[8192];
try {
MessageDigest digest = MessageDigest.getInstance("SHA-256");
while ((read = is.read(buffer)) > 0) {
digest.update(buffer, 0, read);
}
byte[] hash = digest.digest();
BigInteger bigInt = new BigInteger(1, hash);
output = bigInt.toString(16);
while (output.length() < 32) {
output = "0"+output;
}
}
catch (Exception e) {
e.printStackTrace(System.err);
return null;
}
return output;
}
W środowisku JEE6 + można również wykorzystać JAXB DataTypeConverter:
import javax.xml.bind.DatatypeConverter;
String hash = DatatypeConverter.printHexBinary(
MessageDigest.getInstance("MD5").digest("SOMESTRING".getBytes("UTF-8")));
ta wersja ma błąd (przynajmniej od dzisiaj i z java8 @ win7). spróbuj hasza "1234". wynik musi zaczynać się od "03ac67 ...", ale tak naprawdę zaczyna się od "3ac67 ..." – Chris
@Chris dzięki, naprawiłem to tutaj, ale znalazłem lepsze rozwiązanie moje ulubione na tym jest obecnie: http: // stackoverflow .pl/pytania/415953/how-can-i-generate-an-md5-hash/23273249 # 23273249 – stacker
Dla nowych czytelników tego starego wątku: ulubiony (skrót MD5), do którego odnosi się @stacker, jest obecnie uważany za niezabezpieczony (http://en.wikipedia.org/wiki/MD5). – mortensi
return new String(Hex.encode(digest));
Bez informacji o pakiecie/dostawcy klasa "Hex" nie jest bardzo pomocna. A jeśli to jest Hex z Codec Apache Commons, użyłbym 'return Hex.encodeHexString (digest)'. – eckes
Przypuszczam używasz stosunkowo stare Java wersja bez SHA-256. Musisz więc dodać dostawcę BouncyCastle do już dostarczonych "dostawców zabezpieczeń" w swojej wersji java.
// NEEDED if you are using a Java version without SHA-256
Security.addProvider(new BouncyCastleProvider());
// then go as usual
MessageDigest md = MessageDigest.getInstance("SHA-256");
String text = "my string...";
md.update(text.getBytes("UTF-8")); // or UTF-16 if needed
byte[] digest = md.digest();
+1 za wzmiankę o BouncyCastle, która dodaje całkiem sporo nowych MessageDigestów w porównaniu do stosunkowo marnej selekcji dostępnej w JDK. – mjuarez
To będzie pracować z "org.bouncycastle.util.encoders.Hex" po opakowaniu
return new String(Hex.encode(digest));
ITS w BouncyCastle słoika.
Nie potrzebujesz biblioteki BouncyCastle. Poniższy kod pokazuje, jak to zrobić za pomocą funkcji Integer.toHexString
public static String sha256(String base) {
try{
MessageDigest digest = MessageDigest.getInstance("SHA-256");
byte[] hash = digest.digest(base.getBytes("UTF-8"));
StringBuffer hexString = new StringBuffer();
for (int i = 0; i < hash.length; i++) {
String hex = Integer.toHexString(0xff & hash[i]);
if(hex.length() == 1) hexString.append('0');
hexString.append(hex);
}
return hexString.toString();
} catch(Exception ex){
throw new RuntimeException(ex);
}
}
Specjalne podziękowania dla user1452273 z tego postu: How to hash some string with sha256 in Java?
Bądź dobrej pracy!
Java 8: Base64 dostępny:
MessageDigest md = MessageDigest.getInstance("SHA-512");
md.update(inbytes);
byte[] aMessageDigest = md.digest();
String outEncoded = Base64.getEncoder().encodeToString(aMessageDigest);
return(outEncoded);
- 1. SHA256 hash String w C# nie zgadza się z hash na stronie
- 2. Dekodowanie hash szyfrowanie sha256, znając sól
- 3. Dlaczego base64 jest hash sha1/sha256?
- 4. W Javie, sortowanie hash mapie jego key.length()
- 5. String w Javie
- 6. Parametr String ... w Javie
- 7. String inicjalizacji tablicy w Javie
- 8. + operator dla String w Javie
- 9. NodeJS - SHA256 Szyfrowanie hasła
- 10. Oblicz RFC 2104 zgodnych HMAC z algorytmem SHA256 hash w Ruby
- 11. W Angular2 skrót SHA256 wygenerowanego pliku nie pasuje do SHA256 z innych witryn.
- 12. Java vs Python HMAC-SHA256 Niezgodność
- 13. dlaczego hash_hmac PHP („sha256”) daje inny wynik niż Java sha256_HMAC
- 14. Jak przekonwertować obiekt String na obiekt Hash?
- 15. Jak korzystać z sha256 w php5.3.0
- 16. Co kryje się za metodą hashCode() dla String w Javie?
- 17. Jak wygenerować SHA256 i CRC32 w ios
- 18. SHA256 w Go i PHP daje różne wyniki
- 19. Jak przekazać hash przez odniesienie w perlu
- 20. Konwersja String do koloru w Javie
- 21. String wzorzec dopasowania problemu w Javie
- 22. jak przekonwertować BigInteger do String w Javie
- 23. przekonwertować plik [], aby String [] w Javie
- 24. Deszyfruj z SHA256
- 25. Jak korzystać z funkcji SHA256 OpenSSL
- 26. SHA256 w Objective-C dla iPhone
- 27. Dlaczego wszystkie warianty SHA256 są wyświetlane jako SHA256Managed?
- 28. czy istnieje wbudowana funkcja javascript string hash w najnowszych przeglądarkach?
- 29. Jak mogę przechodzić przez wyliczenie w Javie?
- 30. Jak hash SHA w kakao/iOS
Z tego samego tekstu jawnego, czy hash przypuszczać, aby być inna za każdym razem? Ponieważ tak się ze mną dzieje –
@Harry Pham, hash powinien zawsze być taki sam, ale bez większej ilości informacji trudno byłoby powiedzieć, dlaczego dostajesz inne. Powinieneś prawdopodobnie otworzyć nowe pytanie. –
@Harry Pham: Po wywołaniu 'digest' stan wewnętrzny jest resetowany; więc jeśli wywołasz go ponownie bez wcześniejszej aktualizacji, otrzymasz skrót z pustego łańcucha. – Debilski