Reading a password from std::cin
Solution 1:
@wrang-wrang answer was really good, but did not fulfill my needs, this is what my final code (which was based on this) look like:
#ifdef WIN32
#include <windows.h>
#else
#include <termios.h>
#include <unistd.h>
#endif
void SetStdinEcho(bool enable = true)
{
#ifdef WIN32
HANDLE hStdin = GetStdHandle(STD_INPUT_HANDLE);
DWORD mode;
GetConsoleMode(hStdin, &mode);
if( !enable )
mode &= ~ENABLE_ECHO_INPUT;
else
mode |= ENABLE_ECHO_INPUT;
SetConsoleMode(hStdin, mode );
#else
struct termios tty;
tcgetattr(STDIN_FILENO, &tty);
if( !enable )
tty.c_lflag &= ~ECHO;
else
tty.c_lflag |= ECHO;
(void) tcsetattr(STDIN_FILENO, TCSANOW, &tty);
#endif
}
Sample usage:
#include <iostream>
#include <string>
int main()
{
SetStdinEcho(false);
std::string password;
std::cin >> password;
SetStdinEcho(true);
std::cout << password << std::endl;
return 0;
}
Solution 2:
There's nothing in the standard for this.
In unix, you could write some magic bytes depending on the terminal type.
Use getpasswd if it's available.
You can system() /usr/bin/stty -echo
to disable echo, and /usr/bin/stty echo
to enable it (again, on unix).
This guy explains how to do it without using "stty"; I didn't try it myself.
Solution 3:
If you don't care about portability, you can use _getch()
in VC
.
#include <iostream>
#include <string>
#include <conio.h>
int main()
{
std::string password;
char ch;
const char ENTER = 13;
std::cout << "enter the password: ";
while((ch = _getch()) != ENTER)
{
password += ch;
std::cout << '*';
}
}
There is also getwch()
for wide characters
. My advice is that you use NCurse
which is available in *nix
systems also.
Solution 4:
Only idea what i have, you could read password char by char, and after it just print backspace ("\b") and maybe '*'.