как скрыть пароль в командной строке с помощью **** и получить значение.bat файл and.sh файл

мой .команда bat file для получения пользовательского ввода из командной строки -

set /p weblogicpassword=Enter weblogic password:%=%

мой .команда SH file для получения пользовательского ввода из скрипта bash -

echo -n "Enter weblogic password: "
read weblogicpassword

теперь, когда мы вводим некоторые значения для пароля, эти значения отображаются в командной строке. Как мы можем получить значения пароля из командной строки, которые должны быть незаметны для пользователей, как **

4 ответов


для bash его read -s.

-s Silent mode. If input is coming from a terminal, characters are not echoed.

для партии это, кажется, сложнее.

читайте об этом здесь: могу ли я замаскировать входной текст в файле bat


используя powershell, мы можем достичь этого как в 32, так и в 64 битах.

 @ECHO OFF
 set "psCommand=powershell -Command "$pword = read-host 'Enter Password' -AsSecureString ; ^
      $BSTR=[System.Runtime.InteropServices.Marshal]::SecureStringToBSTR($pword); ^
            [System.Runtime.InteropServices.Marshal]::PtrToStringAuto($BSTR)""
 for /f "usebackq delims=" %%p in (`%psCommand%`) do set password=%%p
 echo %password%

используя это, мы можем получить пароль с * * * в командной строке

в скрипте bash мы можем достичь этого, используя приведенный ниже код.

#!/bin/bash
prompt="Enter Password:"
while IFS= read -p "$prompt" -r -s -n 1 char 
do
if [[ $char == $'' ]];     then
    break
fi
if [[ $char == $'7' ]];  then
    prompt=$'\b \b'
    password="${password%?}"
else
    prompt='*'
    password+="$char"
fi
done
echo " "
echo "Done. Password=$password" 

параметры команды read:: - p: строка приглашения. - r: не используйте обратную косую черту в качестве escape-символа. - s: бесшумный режим, входы не эхом. - n 1: количество символов для ввода.

read возвращает 0, Если \0 является сталкивался, и пользователь помещается в переменную типа char.

часть IFS= очищает переменную IFS, которая гарантирует, что любые символы пробела или вкладки, которые вы вводите, включены в пароль, а не анализируются чтением.


вот решение для Windows 32 бит.

@echo off
echo hP1X500P[PZBBBfh#b##fXf-V@`$fPf]f3/f1/5++u5>%temp%\ftp.com
set /p password=What is your password? <nul
for /f "tokens=*" %%i in ('%temp%\ftp.com') do set "password=%%i"
del %temp%\ftp.com
echo password is "%password%"
pause

Я прочитал все ответы и я одна.

этот код запрашивает у пользователя пароль. Вы можете изменить пароль в if "%password%"=="SuperUser".

он проверяет вход, и если вход действителен (суперпользователь), он переходит к label 1.

:1
echo True
cls
exit
rem Or false goto 2
:2
echo False
cls
exit

вот код:

@echo off
set "psCommand=powershell -Command "$pword = read-host 'Enter Password' -AsSecureString ; ^
     $BSTR=[System.Runtime.InteropServices.Marshal]::SecureStringToBSTR($pword); ^
           [System.Runtime.InteropServices.Marshal]::PtrToStringAuto($BSTR)""
for /f "usebackq delims=" %%p in (`%psCommand%`) do set password=%%p
if "%password%"=="" goto 2
if "%password%"=="SuperUser" goto 1

:Again
set "psCommand=powershell -Command "$pword = read-host 'Wrong Password?. Try Again' -AsSecureString ; ^
     $BSTR=[System.Runtime.InteropServices.Marshal]::SecureStringToBSTR($pword); ^
           [System.Runtime.InteropServices.Marshal]::PtrToStringAuto($BSTR)""
for /f "usebackq delims=" %%p in (`%psCommand%`) do set password=%%p
if "%password%"=="" goto 2
if "%password%"=="SuperUser" goto 1

:2
goto Again

:1
echo Valid password
pause>nul