Base64: java.lang.IllegalArgumentException: Illegal character
Ich versuche, das senden einer Bestätigungs-E-Mail nach der Registrierung der Nutzer. Ich bin mit der JavaMail-Bibliothek für diesen Zweck, und die Java-8 Base64-util-Klasse.
Ich bin-Kodierung Benutzer E-Mails in der folgenden Weise:
byte[] encodedEmail = Base64.getUrlEncoder().encode(user.getEmail().getBytes(StandardCharsets.UTF_8));
Multipart multipart = new MimeMultipart();
InternetHeaders headers = new InternetHeaders();
headers.addHeader("Content-type", "text/html; charset=UTF-8");
String confirmLink = "Complete your registration by clicking on following"+ "\n<a href='" + confirmationURL + encodedEmail + "'>link</a>";
MimeBodyPart link = new MimeBodyPart(headers,
confirmLink.getBytes("UTF-8"));
multipart.addBodyPart(link);
wo confirmationURL
ist:
private final static String confirmationURL = "http://localhost:8080/project/controller?command=confirmRegistration&ID=";
Und dann decodieren Sie diese in ConfirmRegistrationCommand so:
String encryptedEmail = request.getParameter("ID");
String decodedEmail = new String(Base64.getUrlDecoder().decode(encryptedEmail), StandardCharsets.UTF_8);
RepositoryFactory repositoryFactory = RepositoryFactory
.getFactoryByName(FactoryType.MYSQL_REPOSITORY_FACTORY);
UserRepository userRepository = repositoryFactory.getUserRepository();
User user = userRepository.find(decodedEmail);
if (user.getEmail().equals(decodedEmail)) {
user.setActiveStatus(true);
return Path.WELCOME_PAGE;
} else {
return Path.ERROR_PAGE;
}
Und wenn ich versuche zu entschlüsseln:
http://localhost:8080/project/controller?command=confirmRegistration&ID=[B@6499375d
Ich bin immer java.lang.IllegalArgumentException: Illegal base64 character 5b
.
Ich habe versucht, die grundlegenden Encode/Decoder (nicht URL sind), ohne Erfolg.
GELÖST:
Das problem war die nächste in der Reihe:
String confirmLink = "Complete your registration by clicking on following"+ "\n<a href='" + confirmationURL + encodedEmail + "'>link</a>";
Ich bin Aufruf von toString auf ein array von bytes, also sollte ich Folgendes tun:
String encodedEmail = new String(Base64.getEncoder().encode(
user.getEmail().getBytes(StandardCharsets.UTF_8)));
Dank Jon Skeet und ByteHamster.
- Aus Neugier, warum
.getBytes(StandardCharsets.UTF_8)
und.getBytes("UTF-8")
in der gleichen Funktion ? Scheint wie eine mangelnde Kohärenz zu mir 😐 - Hinweis: Sie fordern
toString()
auf einebyte[]
. Sie wollen nicht, das zu tun. - ja ! Ich denke, dass es das problem verursacht. Wie sollte ich es ändern ?
- wahrscheinlich sollte ich einfach rufen new String(encodedEmail)
- Oder besser, verwenden Sie eine base64-API, die kodiert einen string, nicht ein byte[]. Die Bibliothek in iharder.net/base64 ist ziemlich gut...
Du musst angemeldet sein, um einen Kommentar abzugeben.
Ihren kodierten text ist
[B@6499375d
. Das ist nicht Base64, ging etwas schief, während Codierung. Sie, dass die Decodierung der code sieht gut aus.Diesen code verwenden, zum konvertieren des byte[] in einen String, bevor Sie ihn auf die URL:
Dass ich auf diese Fehler seit meinem codierten Bildes begann mit
data:image/png;base64,iVBORw0...
.Diese Antwort führte mich zu der Lösung:
Benutzen Sie einfach den untenstehenden code zur Lösung dieses Problems:
Im obigen code
replace('-', '+').replace('_', '/')
hat den job. Weitere details finden Sie in der https://jwt.io/js/jwt.js. Ich Verstand das problem von dem Teil des Codes, bekam von diesem link:Base64.Encoder.encodeToString Methode verwendet automatisch die ISO-8859-1-Zeichensatz.
Für ein Verschlüsselungswerkzeug ich Schreibe, ich nahm den input-string des cipher text, der und Base64 kodiert es für die übertragung, die dann Umgekehrt den Prozess. Relevante Teile nachfolgend dargestellt. HINWEIS: Meine Datei.encoding-Eigenschaft festgelegt ist auf ISO-8859-1 nach dem Aufruf der JVM, so dass möglicherweise auch eine Bedeutung hat.
Die Ausgabe sieht so aus:
Ich habe diesen Fehler bei meinem Linux-Jenkins-slave. Ich habe es behoben durch den Wechsel von der Knoten von der "Bekannten hosts file Verification" - Strategie, die "Nicht überprüfen, Überprüfung Strategie".