how to hide password in command line with **** and

2019-02-04 14:29发布

My .bat file command to get user input from command line is

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

My .sh file command to get user input from bash script is

echo -n "Enter weblogic password: "
read weblogicpassword

Now when we enter some values for password, those values are visible in command line. How we can get the password values from command line which should be invisible to users like **

4条回答
迷人小祖宗
2楼-- · 2019-02-04 15:16

Here is a solution for Windows 32 bit.

@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
查看更多
男人必须洒脱
3楼-- · 2019-02-04 15:17

For bash its read -s.

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

For batch it seems to be more complicated.

Read about it here: Can I mask an input text in a bat file

查看更多
孤傲高冷的网名
4楼-- · 2019-02-04 15:19

I read all answers and I fixed one.

This code asks user for password. You can change password in if "%password%"=="SuperUser".

It checks input and if input is valid (SuperUser), it goes to label 1.

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

Here is the code:

@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
查看更多
beautiful°
5楼-- · 2019-02-04 15:31

By using powershell, we can achieve this in 32 as well as 64 bit.

 @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%

By using this we can get password with *** in command line

In bash script we can achieve this by using below code.

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

The options of the read command are: -p : Prompt string. -r : Don't use backslash as escape character. -s : Silent mode, inputs are not echoed. -n 1 : Number of character to input.

read returns 0 unless \0 is encountered, and the character the user types is placed into the char variable.

The IFS= part clears the IFS variable, which ensures that any space or tab characters that you type are included in the password rather than being parsed out by read.

查看更多
登录 后发表回答