Java - Gerar um sal aleatório não é aleatório

Estou tentando gerar um salt em Java para usar com um algoritmo de hash para armazenamento seguro de senhas. Estou usando o seguinte código para criar o sal aleatório:

private static String getSalt() throws NoSuchAlgorithmException {
    SecureRandom sr = SecureRandom.getInstance("SHA1PRNG");
    byte[] salt = new byte[16];
    sr.nextBytes(salt);
    System.out.println(salt.toString());
    return salt.toString();
}

O que deve gerar um sal completamente seguro e gerado aleatoriamente para usar no meu algoritmo de hash. Porém, quando executo o código, ele continua produzindo o mesmo sal todas as vezes ... Indicando que o sal que está sendo gerado não é aleatório.

Por motivos óbvios de segurança, cada usuário precisa de um sal exclusivo. No entanto, se eu usar esse código sempre que uma nova conta for criada, cada usuário terá o mesmo sal, derrotando o objetivo de tê-lo em primeiro lugar.

Minha pergunta é a seguinte: por que isso continua me dando o mesmo sal e o que posso fazer para garantir que o sal gerado seja completamente aleatório toda vez que o código for executado?

EDITAR:

Pensei em incluir o código fonte de todo o programa de hash que foi corrigido e funciona corretamente. Este é um protótipo simples para simular a geração do hash na criação da conta e a verificação da senha ao efetuar login no sistema.

package hashingwstest;

import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import java.util.Random;
import java.util.Scanner;


public class HashingWSTest {

    public static void main(String[] args) throws NoSuchAlgorithmException {
        Scanner sc = new Scanner(System.in);
        System.out.print("Enter Password: ");
        String passwordToHash = sc.nextLine();

        byte[] bytes = getBytes();
        String salt = new String(bytes);

        String securePassword = hash256(passwordToHash, salt);
        System.out.println("Hash successfully generated");

        System.out.print("Enter your password again: ");
        String checkPassword = sc.nextLine();
        String checkHash = hash256(checkPassword,salt);
        if (checkHash.equals(securePassword)) {
            System.out.println("MATCH");
        }
        else {
            System.out.println("NO MATCH");
        }
    }

    private static String hash256(String passwordToHash, String salt) {
        String generatedPassword = null;
        try {
            MessageDigest md = MessageDigest.getInstance("SHA-256");
            md.update(salt.getBytes());
            byte[] bytes = md.digest(passwordToHash.getBytes());
            StringBuilder sb = new StringBuilder();

            for (int i=0; i<bytes.length; i++) {
                sb.append(Integer.toString((bytes[i] & 0xff) + 0x100, 16).substring(1));
            }
            generatedPassword = sb.toString();
        }
        catch (NoSuchAlgorithmException e) {
            e.printStackTrace();
        }
        return generatedPassword;
    }

    private static byte[] getBytes() throws NoSuchAlgorithmException {
        SecureRandom sr = SecureRandom.getInstance("SHA1PRNG");
        byte[] bytes = new byte[16];
        sr.nextBytes(bytes);
        return bytes;
    }
}

questionAnswers(4)

yourAnswerToTheQuestion