Это все причины, поэтому нужно выбрать массив char [] вместо String для пароля.
1. Поскольку строки являются неизменяемыми в Java, если вы сохраните пароль в виде простого текста, он будет доступен в памяти, пока сборщик мусора не очистит его, и поскольку String используется в пуле строк для повторного использования существует довольно высокая вероятность того, что он останется в памяти на длительный срок, что создает угрозу безопасности.
Поскольку любой, кто имеет доступ к дампу памяти, может найти пароль в виде открытого текста, это еще одна причина, по которой вы всегда должны использовать зашифрованный пароль, а не простой текст. Поскольку строки являются неизменяемыми, содержимое строк не может быть изменено, потому что любое изменение приведет к созданию новой строки, в то время как если вы используете char [], вы все равно можете установить все элементы как пустые или нулевые. Таким образом, хранение пароля в массиве символов явно снижает риск кражи пароля.
2. Сама Java рекомендует использовать метод getPassword () из JPasswordField, который возвращает char [], вместо устаревшего метода getText (), который возвращает пароли в виде открытого текста с указанием соображений безопасности. Хорошо следовать советам команды Java и придерживаться стандартов, а не идти против них.
3. При использовании String всегда существует риск печати простого текста в файле журнала или консоли, но если вы используете массив, вы не будете печатать содержимое массива, а вместо этого получит место в памяти распечатаны. Хотя это и не реальная причина, это все же имеет смысл.
String strPassword="Unknown";
char[] charPassword= new char[]{'U','n','k','w','o','n'};
System.out.println("String password: " + strPassword);
System.out.println("Character password: " + charPassword);
String password: Unknown
Character password: [C@110b053
Ссылка от этого блога .
Надеюсь, это поможет.