Ubuntu: How to use sshpass?


I need to use sshpass to launch a remote command through SSH from a Java code.

If I manually type in a console:

ssh -p 22 user@ipaddress mplayer '/media/data/myFavouriteSong.mp3'  

works perfectly, but asks for password. So I tried running sshpass:

sshpass -p mypass ssh -p 22 user@ipaddress mplayer '/media/data/myFavouriteSong.mp3'  sshpass -p mypass ssh -l user@ipaddress mplayer '/media/data/myFavouriteSong.mp3'  sshpass -p mypass ssh -t user@ipaddress mplayer '/media/data/myFavouriteSong.mp3'  sshpass -p mypass ssh user@ipaddress echo 'OK'  

and none of them work.


I have a command like this:

sshpass -pfoobar ssh -o StrictHostKeyChecking=no user@host command_to_run  

and it works.

In my case StrictHostKeyChecking=no is necessary because the commands are run on a ton of hosts which are exchanged regularly (network routers).

Out of curiosity, I tried to run it without the command, just to see what was happening. It turns out, sshpass keeps silent (no output on stderr). But the return-code in that case is 6. At the time of this writing, this was revision 50, and the matching constant in the code is RETURN_HOST_KEY_UNKNOWN, which makes sense.

Maybe that's the same issue in your case?

If that's not the case, have you properly quoted the remote command?


sshpass only works if the password prompt ends in assword:.

If your password prompt is different you may have to adjust the sourcecode of sshpass to recognize the prompt you have.

I have seen password prompts like Password for user@host: on some systems, maybe this is your problem.


Did you setup passwordless login?

Password-less logins with OpenSSH http://www.debian-administration.org/articles/152


There is lots of way to do that, here is my suggested solution:

First of all, storing your password in a variable is give you more flexible commands. sshpass has an option for that:

-e: this option allows to read password from $SSHPASS environment variable

You have two way to set this variable:

  1. Set directly in your code:

    export SSHPASS='your_pass'  
  2. Or ask for it:

    readPassword () {    echo Ssh Password:     read -s SSHPASS    eval "export SSHPASS='""$SSHPASS""'"  }    # read password    readPassword  

Than execute your command;

  1. If your command is static, run it directly:

    sshpass -e ssh user@host << EOF  mplayer '/media/data/myFavouriteSong.mp3'  command2 parameter1 parameter2 parameter3 ...  command3 parameter1 parameter2 parameter3 ...  ...  EOF  
  2. If your command will be dynamic use like this:

    DYN_FILE_LOC='/media/data/myFavouriteSong.mp3'    eval 'sshpass -e ssh user@host << EOF  mplayer "$DYN_FILE_LOC"  command2 parameter1 parameter2 parameter3 ...  command3 parameter1 parameter2 parameter3 ...  ...  EOF'  

hope this helps someone.


sshpass uses pseudo terminals and the man page includes apologies for breaking occasionally. You can also try fd0ssh. It works if you do not need to send stdin to a process on the remote machine. That works if you just issue a command and capture the result.


sshpass syntax is

sshpass [-ffilename|-dnum|-ppassword|-e] [options] command arguments  

Note that there is no space between the -p and the password.

Also I've noticed that you have to connect with ssh at least once manually to obtain the RSA key of the machine you are connecting to, to go into the ~/.ssh/known_hosts file before sshpass will allow you to connect.

so after obtaining the entry in the known_hosts file I can run a command such as

sshpass -ffilename_with_password_in_it ssh user@server uname -a  

and it will execute the command uname -a on the remote server and output the results to the standard out on the local machine.


What you need is -f -t -t -t

sshpass -p$PASS ssh -f -t -t -t $USER@$HOST $COMMAND  

Additionally you might have to remove "requiretty" from sudo config (/etc/sudoers) on the remote machine.


  1. make a key

    ssh-keygen -t rsa

  2. make a .ssh folder on the remote server it will ask for a password

    ssh $USER@SEVERNAME mkdir -p .ssh

  3. copy the key to the remote server

    cat .ssh/id_rsa.pub | ssh $USER@SERVER 'cat >> .ssh/authorized_keys'

Check if it asks for a password, if not it should work.

ssh $USER@SEVERNAME 'command'  


@exhuma had an example that lead to it working for me.

The password needs to be in form of -pPassword (without the space)

also quotes may be necessary: sshpass -p'Password&0' user@hostname


I think you want something like:

ssh -p yourpassword ssh user@ipaddress somecommand  

For instance, this works for me:

sshpass -p mypassword ssh username@ touch foo  

Note:If u also have question or solution just comment us below or mail us on toontricks1994@gmail.com
Next Post »