Я пытаюсь использовать шифрование SHA1 UTF-8, а затем кодировку base64 и значение строки пароля . Однако мне нужно было сначала сделать шифрование, а затем кодирование, но я сделал наоборот.
Вот код:
# Create Input Data
$enc = [system.Text.Encoding]::UTF8
$string1 = "This is a string to hash"
$data1 = $enc.GetBytes($string1)
# Create a New SHA1 Crypto Provider
$sha = New-Object System.Security.Cryptography.SHA1CryptoServiceProvider
$# Now hash and display results
$result1 = $sha.ComputeHash($data1)
Итак, когда я приступил к хешированию, я понял, что мне нужен байт [] из строки, и я не уверен, как это сделать. Я думаю, что есть простой способ из библиотек .Net, но не нашел примера.
Итак, если у меня есть строка, например:
$string = "password"
Как мне преобразовать ее в байтовый массив, который я могу использовать в :: ComputeHash ($ string)?
В итоге я должен получить зашифрованный пароль UTF-8 с кодировкой SHA-1 и base 64, что и делает приведенный выше код, но он возвращается иначе, чем когда я закодировал то же самое в java, где я сначала зашифровал его, а затем преобразовал этот результат в кодировку base 64.
Я исхожу из предположения, что, хотя шифрование строки напрямую не поддерживается в api, может существовать обходной путь, который позволит вам это сделать. Это то, что я пытаюсь сделать.
Итак, я предполагаю, что моя проблема с кодом заключается в том, что мне пришлось сначала его зашифровать, а затем закодировать, чтобы получить правильное значение. Верно, или я что-то здесь упустил?
Вот подходящий код Java, который действительно работает:
//First method call uses a swing component to get the user entered password.
String password = getPassword();
//This line is where the work starts with the second and third methods below.
String hashed = byteToBase64(getHash(password));
//The second method call here gets the encryption.
public static byte[] getHash(String password) {
MessageDigest digest = null;
byte[] input = null;
try {
digest = MessageDigest.getInstance("SHA-1");
} catch (NoSuchAlgorithmException e1) {
e1.printStackTrace();
}
digest.reset();
try {
input = digest.digest(password.getBytes("UTF-8"));
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
}
return input;
}
//Then the third method call here gets the encoding, FROM THE ENCRYPTED STRING.
public static String byteToBase64(byte[] data){
return new String(Base64.encodeBase64(data));
Когда я запускаю код Java со строкой пароля «пароль», я получаю
{{ 1}}[91, -86, 97, -28, -55, -71, 63, 63, 6, -126, 37, 11, 108, -8, 51, 27, 126, -26, -113, -40] , который является шифрованием.
Затем при кодировании в java я получаю следующее: W6ph5Mm5Pz8GgiULbPgzG37mj9g =
, но когда я запускаю его в PowerShell, я получаю это, потому что сначала он кодируется для UTF8:
91 170 97 228 201 185 63 63 6130 37 11 108 248 51 27 126 230 143 216
Затем, когда я запускаю эту строку кода для ее преобразования, я получаю сообщение об ошибке:
$base64 = [System.Convert]::FromBase64String($result)
Исключение, вызывающее «FromBase64String» с аргументом (ами) «1»: "Недопустимая длина массива символов Base-64." В строке: 1 символ: 45
Однако, если я запустил новую строку кода, чтобы сделать ее шестнадцатеричной, я получу:
$hexResult = [String]::Join("", ($result | % { "{0:X2}" -f $_}))
PS C:\Program Files (x86)\PowerGUI> Write-Host $hexResult
5BAA61E4C9B93F3F0682250B6CF8331B7EE68FD8
но мне нужно закончить с этим значение:
W6ph5Mm5Pz8GgiULbPgzG37mj9g =
Опять же, это может быть даже невозможно, но я пытаюсь найти обходной путь.