diff --git a/src/java.base/share/classes/sun/security/provider/certpath/OCSP.java b/src/java.base/share/classes/sun/security/provider/certpath/OCSP.java
index 4fdb6694c3b..2b07e69dcfd 100644
--- a/src/java.base/share/classes/sun/security/provider/certpath/OCSP.java
+++ b/src/java.base/share/classes/sun/security/provider/certpath/OCSP.java
@@ -55,6 +55,8 @@ import sun.security.x509.PKIXExtensions;
import sun.security.x509.URIName;
import sun.security.x509.X509CertImpl;
+import static java.nio.charset.StandardCharsets.UTF_8;
+
/**
* This is a class that checks the revocation status of a certificate(s) using
* OCSP. It is not a PKIXCertPathChecker and therefore can be used outside of
@@ -176,7 +178,7 @@ public final class OCSP {
try {
String encodedGetReq = responderURI.toString() + "/" +
URLEncoder.encode(Base64.getEncoder().encodeToString(bytes),
- "UTF-8");
+ UTF_8);
if (encodedGetReq.length() <= 255) {
url = new URL(encodedGetReq);
diff --git a/src/java.management/share/classes/com/sun/jmx/remote/security/HashedPasswordManager.java b/src/java.management/share/classes/com/sun/jmx/remote/security/HashedPasswordManager.java
index ba05ada5b0f..63b68db88f4 100644
--- a/src/java.management/share/classes/com/sun/jmx/remote/security/HashedPasswordManager.java
+++ b/src/java.management/share/classes/com/sun/jmx/remote/security/HashedPasswordManager.java
@@ -30,8 +30,6 @@ import java.io.*;
import java.nio.ByteBuffer;
import java.nio.CharBuffer;
import java.nio.channels.FileLock;
-import java.nio.charset.Charset;
-import java.nio.charset.StandardCharsets;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
@@ -41,6 +39,8 @@ import java.util.HashMap;
import java.util.Map;
import java.util.concurrent.atomic.AtomicBoolean;
+import static java.nio.charset.StandardCharsets.UTF_8;
+
/**
* HashedPasswordManager loads passwords from the password file and optionally
* hashes them.
@@ -139,7 +139,7 @@ final public class HashedPasswordManager {
MessageDigest digest = MessageDigest.getInstance(algorithm);
digest.reset();
digest.update(salt);
- byte[] hash = digest.digest(password.getBytes(StandardCharsets.UTF_8));
+ byte[] hash = digest.digest(password.getBytes(UTF_8));
String saltStr = Base64.getEncoder().encodeToString(salt);
String hashStr = Base64.getEncoder().encodeToString(hash);
@@ -167,7 +167,7 @@ final public class HashedPasswordManager {
}
lock.release();
}
- String str = new String(data, StandardCharsets.UTF_8);
+ String str = new String(data, UTF_8);
return str.split("\\r?\\n");
}
}
@@ -175,7 +175,7 @@ final public class HashedPasswordManager {
private void writePasswordFile(String input) throws IOException {
synchronized (HashedPasswordManager.class) {
try (FileOutputStream fout = new FileOutputStream(passwordFile);
- OutputStreamWriter out = new OutputStreamWriter(fout, StandardCharsets.UTF_8);
+ OutputStreamWriter out = new OutputStreamWriter(fout, UTF_8);
FileLock lock = fout.getChannel().lock()) {
out.write(input);
lock.release();
@@ -199,7 +199,7 @@ final public class HashedPasswordManager {
MessageDigest digest = MessageDigest.getInstance(us.hashAlgorithm);
digest.reset();
digest.update(salt);
- ByteBuffer byteBuffer = Charset.forName("UTF-8").encode(CharBuffer.wrap(inputPassword));
+ ByteBuffer byteBuffer = UTF_8.encode(CharBuffer.wrap(inputPassword));
byte[] passwordBytes = new byte[byteBuffer.limit()];
byteBuffer.get(passwordBytes);
byte[] hash = digest.digest(passwordBytes);
diff --git a/src/java.management/share/classes/javax/management/loading/MLetParser.java b/src/java.management/share/classes/javax/management/loading/MLetParser.java
index a067a281403..3380a77b650 100644
--- a/src/java.management/share/classes/javax/management/loading/MLetParser.java
+++ b/src/java.management/share/classes/javax/management/loading/MLetParser.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 1999, 2017, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
@@ -26,6 +26,7 @@
package javax.management.loading;
import static com.sun.jmx.defaults.JmxProperties.MLET_LOGGER;
+import static java.nio.charset.StandardCharsets.UTF_8;
import java.io.BufferedReader;
import java.io.File;
@@ -164,7 +165,7 @@ class MLetParser {
conn = url.openConnection();
Reader in = new BufferedReader(new InputStreamReader(conn.getInputStream(),
- "UTF-8"));
+ UTF_8));
// The original URL may have been redirected - this
// sets it to whatever URL/codebase we ended up getting
diff --git a/src/java.management/share/classes/sun/management/counter/perf/PerfDataEntry.java b/src/java.management/share/classes/sun/management/counter/perf/PerfDataEntry.java
index 3f69b0dd992..a3a06d23020 100644
--- a/src/java.management/share/classes/sun/management/counter/perf/PerfDataEntry.java
+++ b/src/java.management/share/classes/sun/management/counter/perf/PerfDataEntry.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2003, 2011, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2003, 2021, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
@@ -27,7 +27,8 @@ package sun.management.counter.perf;
import sun.management.counter.*;
import java.nio.*;
-import java.io.UnsupportedEncodingException;
+
+import static java.nio.charset.StandardCharsets.UTF_8;
class PerfDataEntry {
private class EntryFieldOffset {
@@ -127,14 +128,7 @@ class PerfDataEntry {
}
// convert name into a String
- try {
- name = new String(symbolBytes, "UTF-8");
- }
- catch (UnsupportedEncodingException e) {
- // should not reach here
- // "UTF-8" is always a known encoding
- throw new InternalError(e.getMessage(), e);
- }
+ name = new String(symbolBytes, UTF_8);
if (variability == Variability.INVALID) {
throw new InstrumentationException("Invalid variability attribute:" +
diff --git a/src/java.management/share/classes/sun/management/counter/perf/PerfDataType.java b/src/java.management/share/classes/sun/management/counter/perf/PerfDataType.java
index 8b8d61cb950..731ff40179e 100644
--- a/src/java.management/share/classes/sun/management/counter/perf/PerfDataType.java
+++ b/src/java.management/share/classes/sun/management/counter/perf/PerfDataType.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2003, 2013, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2003, 2021, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
@@ -25,7 +25,7 @@
package sun.management.counter.perf;
-import java.io.UnsupportedEncodingException;
+import static java.nio.charset.StandardCharsets.UTF_8;
/**
* A typesafe enumeration for the data types supported for
@@ -88,12 +88,7 @@ class PerfDataType {
private PerfDataType(String name, String c, int size) {
this.name = name;
this.size = size;
- try {
- byte[] b = c.getBytes("UTF-8");
- this.value = b[0];
- } catch (UnsupportedEncodingException e) {
- // ignore, "UTF-8" is always a known encoding
- throw new InternalError("Unknown encoding", e);
- }
+ byte[] b = c.getBytes(UTF_8);
+ this.value = b[0];
}
}
diff --git a/src/java.naming/share/classes/com/sun/jndi/ldap/Ber.java b/src/java.naming/share/classes/com/sun/jndi/ldap/Ber.java
index 1e8600f9ffe..e3598e49e68 100644
--- a/src/java.naming/share/classes/com/sun/jndi/ldap/Ber.java
+++ b/src/java.naming/share/classes/com/sun/jndi/ldap/Ber.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 1999, 2011, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
@@ -31,6 +31,8 @@ import java.io.ByteArrayInputStream;
import sun.security.util.HexDumpEncoder;
+import static java.nio.charset.StandardCharsets.UTF_8;
+
/**
* Base class that defines common fields, constants, and debug method.
*
@@ -50,7 +52,7 @@ public abstract class Ber {
try {
outStream.write('\n');
- outStream.write(tag.getBytes("UTF8"));
+ outStream.write(tag.getBytes(UTF_8));
new HexDumpEncoder().encodeBuffer(
new ByteArrayInputStream(bytes, from, to),
@@ -60,7 +62,7 @@ public abstract class Ber {
} catch (IOException e) {
try {
outStream.write(
- "Ber.dumpBER(): error encountered\n".getBytes("UTF8"));
+ "Ber.dumpBER(): error encountered\n".getBytes(UTF_8));
} catch (IOException e2) {
// ignore
}
diff --git a/src/java.naming/share/classes/com/sun/jndi/ldap/BerDecoder.java b/src/java.naming/share/classes/com/sun/jndi/ldap/BerDecoder.java
index 9ebc18fcac4..35b8bc1b567 100644
--- a/src/java.naming/share/classes/com/sun/jndi/ldap/BerDecoder.java
+++ b/src/java.naming/share/classes/com/sun/jndi/ldap/BerDecoder.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
@@ -25,7 +25,8 @@
package com.sun.jndi.ldap;
-import java.io.UnsupportedEncodingException;
+import static java.nio.charset.StandardCharsets.ISO_8859_1;
+import static java.nio.charset.StandardCharsets.UTF_8;
/**
* A BER decoder. Contains methods to parse a BER buffer.
@@ -266,17 +267,9 @@ public final class BerDecoder extends Ber {
System.arraycopy(buf, offset, buf2, 0, len);
if (decodeUTF8) {
- try {
- retstr = new String(buf2, "UTF8");
- } catch (UnsupportedEncodingException e) {
- throw new DecodeException("UTF8 not available on platform");
- }
+ retstr = new String(buf2, UTF_8);
} else {
- try {
- retstr = new String(buf2, "8859_1");
- } catch (UnsupportedEncodingException e) {
- throw new DecodeException("8859_1 not available on platform");
- }
+ retstr = new String(buf2, ISO_8859_1);
}
offset += len;
}
diff --git a/src/java.naming/share/classes/com/sun/jndi/ldap/BerEncoder.java b/src/java.naming/share/classes/com/sun/jndi/ldap/BerEncoder.java
index aa19de72419..ec95d2880e9 100644
--- a/src/java.naming/share/classes/com/sun/jndi/ldap/BerEncoder.java
+++ b/src/java.naming/share/classes/com/sun/jndi/ldap/BerEncoder.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
@@ -25,7 +25,8 @@
package com.sun.jndi.ldap;
-import java.io.UnsupportedEncodingException;
+import static java.nio.charset.StandardCharsets.ISO_8859_1;
+import static java.nio.charset.StandardCharsets.UTF_8;
/**
* A BER encoder.
@@ -316,19 +317,11 @@ public final class BerEncoder extends Ber {
if (str == null) {
count = 0;
} else if (encodeUTF8) {
- try {
- bytes = str.getBytes("UTF8");
- count = bytes.length;
- } catch (UnsupportedEncodingException e) {
- throw new EncodeException("UTF8 not available on platform");
- }
+ bytes = str.getBytes(UTF_8);
+ count = bytes.length;
} else {
- try {
- bytes = str.getBytes("8859_1");
- count = bytes.length;
- } catch (UnsupportedEncodingException e) {
- throw new EncodeException("8859_1 not available on platform");
- }
+ bytes = str.getBytes(ISO_8859_1);
+ count = bytes.length;
}
encodeLength(count);
diff --git a/src/java.naming/share/classes/com/sun/jndi/ldap/Filter.java b/src/java.naming/share/classes/com/sun/jndi/ldap/Filter.java
index c4cd4db38b4..ab43fa7aa9c 100644
--- a/src/java.naming/share/classes/com/sun/jndi/ldap/Filter.java
+++ b/src/java.naming/share/classes/com/sun/jndi/ldap/Filter.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 1999, 2020, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
@@ -30,6 +30,9 @@ import javax.naming.directory.InvalidSearchFilterException;
import java.io.IOException;
+import static java.nio.charset.StandardCharsets.ISO_8859_1;
+import static java.nio.charset.StandardCharsets.UTF_8;
+
/**
* LDAP (RFC-1960) and LDAPv3 (RFC-2254) search filters.
*
@@ -59,9 +62,9 @@ final class Filter {
byte[] filter;
int filterLen;
if (isLdapv3) {
- filter = filterStr.getBytes("UTF8");
+ filter = filterStr.getBytes(UTF_8);
} else {
- filter = filterStr.getBytes("8859_1");
+ filter = filterStr.getBytes(ISO_8859_1);
}
filterLen = filter.length;
if (dbg) {
diff --git a/src/java.naming/share/classes/com/sun/jndi/ldap/LdapClient.java b/src/java.naming/share/classes/com/sun/jndi/ldap/LdapClient.java
index a2490480967..3e916a5d7f8 100644
--- a/src/java.naming/share/classes/com/sun/jndi/ldap/LdapClient.java
+++ b/src/java.naming/share/classes/com/sun/jndi/ldap/LdapClient.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 1999, 2020, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
@@ -39,6 +39,9 @@ import com.sun.jndi.ldap.pool.PoolCallback;
import com.sun.jndi.ldap.sasl.LdapSasl;
import com.sun.jndi.ldap.sasl.SaslInputStream;
+import static java.nio.charset.StandardCharsets.ISO_8859_1;
+import static java.nio.charset.StandardCharsets.UTF_8;
+
/**
* LDAP (RFC-1777) and LDAPv3 (RFC-2251) compliant client
*
@@ -421,9 +424,9 @@ public final class LdapClient implements PooledConnection {
if (pw instanceof String) {
if (v3) {
- return ((String)pw).getBytes("UTF8");
+ return ((String)pw).getBytes(UTF_8);
} else {
- return ((String)pw).getBytes("8859_1");
+ return ((String)pw).getBytes(ISO_8859_1);
}
} else {
return (byte[])pw;
@@ -1153,7 +1156,7 @@ public final class LdapClient implements PooledConnection {
// replace any escaped characters in the value
byte[] val = isLdapv3 ?
- value.getBytes("UTF8") : value.getBytes("8859_1");
+ value.getBytes(UTF_8) : value.getBytes(ISO_8859_1);
ber.encodeOctetString(
Filter.unescapeFilterValue(val, 0, val.length),
Ber.ASN_OCTET_STR);
diff --git a/src/java.naming/share/classes/com/sun/jndi/ldap/LdapName.java b/src/java.naming/share/classes/com/sun/jndi/ldap/LdapName.java
index 9e310b3bd92..70b420f7274 100644
--- a/src/java.naming/share/classes/com/sun/jndi/ldap/LdapName.java
+++ b/src/java.naming/share/classes/com/sun/jndi/ldap/LdapName.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 1999, 2013, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
@@ -35,6 +35,7 @@ import javax.naming.directory.Attributes;
import javax.naming.directory.Attribute;
import javax.naming.directory.BasicAttributes;
+import static java.nio.charset.StandardCharsets.UTF_8;
/**
* LdapName implements compound names for LDAP v3 as
@@ -900,11 +901,7 @@ public final class LdapName implements Name {
// Convert hex-encoded UTF-8 to 16-bit chars.
byte[] utf8 = getUtf8Octets(chars, i, end);
if (utf8.length > 0) {
- try {
- buf.append(new String(utf8, "UTF8"));
- } catch (java.io.UnsupportedEncodingException e) {
- // shouldn't happen
- }
+ buf.append(new String(utf8, UTF_8));
i += utf8.length * 3 - 1;
} else {
throw new IllegalArgumentException(
diff --git a/src/java.naming/share/classes/com/sun/jndi/ldap/sasl/DefaultCallbackHandler.java b/src/java.naming/share/classes/com/sun/jndi/ldap/sasl/DefaultCallbackHandler.java
index e5e04a12ee2..2a782c0e9cc 100644
--- a/src/java.naming/share/classes/com/sun/jndi/ldap/sasl/DefaultCallbackHandler.java
+++ b/src/java.naming/share/classes/com/sun/jndi/ldap/sasl/DefaultCallbackHandler.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 1999, 2017, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 1999, 2021, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
@@ -30,6 +30,8 @@ import javax.security.sasl.RealmCallback;
import javax.security.sasl.RealmChoiceCallback;
import java.io.IOException;
+import static java.nio.charset.StandardCharsets.UTF_8;
+
/**
* DefaultCallbackHandler for satisfying NameCallback and
* PasswordCallback for an LDAP client.
@@ -60,7 +62,7 @@ final class DefaultCallbackHandler implements CallbackHandler {
passwd = ((char[])cred).clone();
} else if (cred != null) {
// assume UTF-8 encoding
- String orig = new String((byte[])cred, "UTF8");
+ String orig = new String((byte[])cred, UTF_8);
passwd = orig.toCharArray();
}
}
diff --git a/src/java.naming/share/classes/javax/naming/ldap/Rdn.java b/src/java.naming/share/classes/javax/naming/ldap/Rdn.java
index a24bd14b683..6d2caedc4ba 100644
--- a/src/java.naming/share/classes/javax/naming/ldap/Rdn.java
+++ b/src/java.naming/share/classes/javax/naming/ldap/Rdn.java
@@ -1,5 +1,5 @@
/*
- * Copyright (c) 2003, 2020, Oracle and/or its affiliates. All rights reserved.
+ * Copyright (c) 2003, 2021, Oracle and/or its affiliates. All rights reserved.
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
*
* This code is free software; you can redistribute it and/or modify it
@@ -43,6 +43,8 @@ import java.io.ObjectOutputStream;
import java.io.ObjectInputStream;
import java.io.IOException;
+import static java.nio.charset.StandardCharsets.UTF_8;
+
/**
* This class represents a relative distinguished name, or RDN, which is a
* component of a distinguished name as specified by
@@ -643,11 +645,7 @@ public class Rdn implements Serializable, Comparable