Shell Script for logging into a ssh server

The name of the pictureThe name of the pictureThe name of the pictureClash Royale CLAN TAG#URR8PPP











up vote
23
down vote

favorite
11












I tried writing a shell script which can do automatic login into a ssh server using password which is mentioned in the script. I have written the following code:



set timeout 30
/usr/bin/ssh -p 8484 root@172.31.72.103
expect

"root@172.31.72.103's password"

send "passwordr"




This code is not running properly, still it is asking for the password. Can somebody please help me in solving this










share|improve this question



















  • 2




    Related: pass password to su/sudo/ssh
    – Piotr Dobrogost
    Feb 18 '15 at 12:45










  • serverfault.com/questions/241588/…
    – Ciro Santilli 新疆改造中心 六四事件 法轮功
    Nov 30 '15 at 21:23














up vote
23
down vote

favorite
11












I tried writing a shell script which can do automatic login into a ssh server using password which is mentioned in the script. I have written the following code:



set timeout 30
/usr/bin/ssh -p 8484 root@172.31.72.103
expect

"root@172.31.72.103's password"

send "passwordr"




This code is not running properly, still it is asking for the password. Can somebody please help me in solving this










share|improve this question



















  • 2




    Related: pass password to su/sudo/ssh
    – Piotr Dobrogost
    Feb 18 '15 at 12:45










  • serverfault.com/questions/241588/…
    – Ciro Santilli 新疆改造中心 六四事件 法轮功
    Nov 30 '15 at 21:23












up vote
23
down vote

favorite
11









up vote
23
down vote

favorite
11






11





I tried writing a shell script which can do automatic login into a ssh server using password which is mentioned in the script. I have written the following code:



set timeout 30
/usr/bin/ssh -p 8484 root@172.31.72.103
expect

"root@172.31.72.103's password"

send "passwordr"




This code is not running properly, still it is asking for the password. Can somebody please help me in solving this










share|improve this question















I tried writing a shell script which can do automatic login into a ssh server using password which is mentioned in the script. I have written the following code:



set timeout 30
/usr/bin/ssh -p 8484 root@172.31.72.103
expect

"root@172.31.72.103's password"

send "passwordr"




This code is not running properly, still it is asking for the password. Can somebody please help me in solving this







ssh password expect






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Feb 8 '12 at 0:10









Gilles

509k12010071537




509k12010071537










asked Feb 7 '12 at 6:17









pradeepchhetri

6,04573254




6,04573254







  • 2




    Related: pass password to su/sudo/ssh
    – Piotr Dobrogost
    Feb 18 '15 at 12:45










  • serverfault.com/questions/241588/…
    – Ciro Santilli 新疆改造中心 六四事件 法轮功
    Nov 30 '15 at 21:23












  • 2




    Related: pass password to su/sudo/ssh
    – Piotr Dobrogost
    Feb 18 '15 at 12:45










  • serverfault.com/questions/241588/…
    – Ciro Santilli 新疆改造中心 六四事件 法轮功
    Nov 30 '15 at 21:23







2




2




Related: pass password to su/sudo/ssh
– Piotr Dobrogost
Feb 18 '15 at 12:45




Related: pass password to su/sudo/ssh
– Piotr Dobrogost
Feb 18 '15 at 12:45












serverfault.com/questions/241588/…
– Ciro Santilli 新疆改造中心 六四事件 法轮功
Nov 30 '15 at 21:23




serverfault.com/questions/241588/…
– Ciro Santilli 新疆改造中心 六四事件 法轮功
Nov 30 '15 at 21:23










9 Answers
9






active

oldest

votes

















up vote
29
down vote



accepted










I once wrote an expect script to log in to a ssh server (like your case) and my script was something like this:



#!/usr/bin/expect

spawn ssh MyUserName@192.168.20.20
expect "password"
send "MyPasswordr"
interact


I think maybe the interact is missing in your script.






share|improve this answer




















  • this is absolutely working fine for me and i am stuck in this place, the interact provides interactive terminal with prompt, but i am trying to automate further more steps like do cd and ls and read the contents of the file as well. Is it possible to do after interact? Please reply
    – Hansie
    Aug 1 at 14:57










  • @Hansie you can send an ls command after the login. For example after sending password, do an expect with the command prompt text (to make sure you are logged in), then send "lsr". All of these goes before interact.
    – saeedn
    Aug 3 at 0:09










  • the question was slightly incorrect and i am sorry after doing ls and read contents, i am able to print the same. But how to get that out of ssh session into a variable to access from local machine. ref: stackoverflow.com/questions/32341234/expect-script-return-value. But output is not working for me. My question posted: stackoverflow.com/questions/51628465/…. I need file_list after exit to access from local command prompt
    – Hansie
    Aug 3 at 6:02

















up vote
30
down vote













You're going about it the wrong way. What you want to do is generate a passwordless ssh-key pair and then (as long as the server supports RSA key authentication) you can get in without having to type a password for all. This is a security risk if your private key is stored somewhere that it could be stolen.



Follow these steps:



  1. mkdir -p ~/.ssh

  2. cd ~/.ssh

  3. ssh-keygen -type dsa -i mysshkeys

  4. Press Return when prompted for passphrase

  5. Press Return a second time to confirm.

There will now be two files in your ~/.ssh directory, mysshkey.pub and mysshkey. mysshkey.pub is your public key, this one is safe to put on remote servers. mysshkey is your private passwordless key, it is not safe to put on remote servers (or somewhere someone else could get a copy).



On the server you wish to SSH into:



  1. Login to the remote server

  2. mkdir -p ~/.ssh

  3. Copy and paste the contents of mysshkey.pub into ~/.ssh/authorized_keys

  4. Make sure that ~/.ssh/authorized_keys is chmod'd to 600

Now, to put it into action on your local machine you run the following command:



ssh -i ~/.ssh/mysshkey <remote_server_ip>


And you will be logged in without being prompted for a password.



This is a much preferable method of managing automated logins as you don't end up hard-coding your password multiple places that need to be updated if you ever change it.






share|improve this answer


















  • 2




    I would use RSA keys rather than DSA. But other than that, full agree.
    – glglgl
    Feb 7 '12 at 9:03







  • 9




    sometimes you cannot add keys to the remote host, eg network appliances.
    – DarkHeart
    Apr 13 '16 at 5:07






  • 1




    I tried this. ssh is still asking for a password. Do you specifically have to give an IP address? I tried it with both <user>@<domain-name> and just the domain name.
    – Jay Bienvenu
    Jun 20 '17 at 14:39










  • This command said too many arguments? (for step 3)
    – Joseph Astrahan
    Aug 8 '17 at 2:59











  • I had to change to ssh-keygen -t dsa and manually enter file location instead.
    – Joseph Astrahan
    Aug 8 '17 at 3:10

















up vote
16
down vote













On Debian-based distributions, the sshpass package provides an easier way of doing what you want. The package is available for many other popular distributions. You need to set it up first:



echo 'YourPassword' > passwordFile.txt
chmod 600 passwordFile.txt


Then invoke the SSH command from a script like this:



sshpass -f /path/to/passwordFile.txt /usr/bin/ssh -p 8484 root@172.31.72.103


This provides more flexibility, such as if you're using a different locale or need to change the password, than solutions using expect.






share|improve this answer





























    up vote
    5
    down vote













    First install the sshPass sudo apt-get install sshpass



    Then create an alias in .bashrc file as



    alias sshLogin='sshpass -p <your ssh password> ssh username@remote_host'


    Now reload your changed .bashrc file by source ~/.bashrc



    You are now done.



    Now you can run the ssh using the above created alias sshLogin in terminal.






    share|improve this answer





























      up vote
      4
      down vote













      you can use this:



      sshpass -p 'yourpassword' ssh user@ip





      share|improve this answer





























        up vote
        1
        down vote













        SSH Passwordless Login Using SSH Keygen in 5 Easy Steps:



        Environment setup:
        enter image description here



        Step 1: Authentication SSH-Kegen Keys on – (192.168.0.12)

        First login into server 192.168.0.12 with a user and generate a pair of public keys using following command.



        enter image description here



        Step 2: Create .ssh Directory on – 192.168.0.11

        Use SSH from server 192.168.0.12 to connect server 192.168.0.11 to create .ssh directory under it, using following command.



        enter image description here



        Step 3: Upload Generated Public Keys to – 192.168.0.11

        Use SSH from server 192.168.0.12 and upload new generated public key (id_rsa.pub) on server 192.168.0.11 under user's .ssh directory as a file name authorized_keys.



        enter image description here



        Step 4: Set Permissions on – 192.168.0.11

        Due to different SSH versions on servers, we need to set permissions on .ssh directory and authorized_keys file.



        enter image description here



        Step 5: Login from 192.168.0.12 to 192.168.0.11 Server without Password

        From now onwards we can log into 192.168.0.11 as sheena user from server 192.168.0.12 as tecmint user without password.



        enter image description here






        share|improve this answer




















        • Thanks... this worked for me, except at step 4 I got a dramatic "warning": "UNPROTECTED PRIVATE KEY FILE! ... .../.ssh/id_rsa' are too open. ... private key will be ignored... bad permissions". I did chmod 700 id_rsa in directory .ssh in the local (client, i.e. 192.168.0.12 in your example) server: problem solved
          – mike rodent
          Apr 21 at 8:14






        • 2




          Please don't post pictures of text.
          – roaima
          Jun 16 at 22:39

















        up vote
        1
        down vote













        As already described in other answers, I also use sshpass but I combine it with the read command to store my password in an temporary environment variable. This way my password is never written anywhere in clear. Here is the one line command I use:



        read -s PASS; sshpass -p $PASS ssh <user>@<host adress>


        After that you have to enter your password (nothing appears on the screen) and then pressing enter will open the connection.






        share|improve this answer



























          up vote
          1
          down vote













          All what you need it to create a hashed key and save it on your PC



          Just type



          ssh-keygen -t rsa -b 4096 # just press Enter till the end


          then enter



          ssh-copy-id <user>@<server>


          then login normally using



          ssh <user>@<server>


          Now you don't need a password




          Note: Saving your password in a plain text is dangerous



          This method is creating a hashed value of your password using RSA with public key of length 4096 which is very secure.







          share|improve this answer


















          • 1




            This appears to be a repeat of this answer.
            – roaima
            Jun 16 at 22:40


















          up vote
          0
          down vote













          I recently did this, this may help you:



          sshpass -p 'password' username@ipaddress


          if this doesn't work then you'll have to generate keys in the other machine you want to connect with



          ssh-keygen


          it will generate private and public keys and ask you for a location, leave at empty it will save the keys in .ssh folder by default
          it will ask you for passphrase, you can also leave it empty
          the go in .ssh folder and change the public key name to 'authorized_keys'



          cd .ssh/
          mv id_rsa.pub authorized_keys
          useradd -d /home/username username


          this will add user to list
          now go to home directory and give permission and restart sshd services



          chmod 700 /home/username/.ssh
          chmod 644 /home/username/.ssh/authorized_keys
          chown root:root /home/dozee
          sudo service sshd restart


          now you will have to move the private key to the system at that location from where you are going to run the ssh command, then you can connect with



          sshpass -p 'password' ssh -i id_rsa username@ip


          if even that doesn't work then go in /etc/ssh open sshd_config with vim editor
          check if the pubkeyAuthenticatoin is turned to yes or not, if not change it to yes , restart the sshd services and then try it, it will definitely work.






          share|improve this answer




















            Your Answer







            StackExchange.ready(function()
            var channelOptions =
            tags: "".split(" "),
            id: "106"
            ;
            initTagRenderer("".split(" "), "".split(" "), channelOptions);

            StackExchange.using("externalEditor", function()
            // Have to fire editor after snippets, if snippets enabled
            if (StackExchange.settings.snippets.snippetsEnabled)
            StackExchange.using("snippets", function()
            createEditor();
            );

            else
            createEditor();

            );

            function createEditor()
            StackExchange.prepareEditor(
            heartbeatType: 'answer',
            convertImagesToLinks: false,
            noModals: false,
            showLowRepImageUploadWarning: true,
            reputationToPostImages: null,
            bindNavPrevention: true,
            postfix: "",
            onDemand: true,
            discardSelector: ".discard-answer"
            ,immediatelyShowMarkdownHelp:true
            );



            );













             

            draft saved


            draft discarded


















            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f31071%2fshell-script-for-logging-into-a-ssh-server%23new-answer', 'question_page');

            );

            Post as a guest






























            9 Answers
            9






            active

            oldest

            votes








            9 Answers
            9






            active

            oldest

            votes









            active

            oldest

            votes






            active

            oldest

            votes








            up vote
            29
            down vote



            accepted










            I once wrote an expect script to log in to a ssh server (like your case) and my script was something like this:



            #!/usr/bin/expect

            spawn ssh MyUserName@192.168.20.20
            expect "password"
            send "MyPasswordr"
            interact


            I think maybe the interact is missing in your script.






            share|improve this answer




















            • this is absolutely working fine for me and i am stuck in this place, the interact provides interactive terminal with prompt, but i am trying to automate further more steps like do cd and ls and read the contents of the file as well. Is it possible to do after interact? Please reply
              – Hansie
              Aug 1 at 14:57










            • @Hansie you can send an ls command after the login. For example after sending password, do an expect with the command prompt text (to make sure you are logged in), then send "lsr". All of these goes before interact.
              – saeedn
              Aug 3 at 0:09










            • the question was slightly incorrect and i am sorry after doing ls and read contents, i am able to print the same. But how to get that out of ssh session into a variable to access from local machine. ref: stackoverflow.com/questions/32341234/expect-script-return-value. But output is not working for me. My question posted: stackoverflow.com/questions/51628465/…. I need file_list after exit to access from local command prompt
              – Hansie
              Aug 3 at 6:02














            up vote
            29
            down vote



            accepted










            I once wrote an expect script to log in to a ssh server (like your case) and my script was something like this:



            #!/usr/bin/expect

            spawn ssh MyUserName@192.168.20.20
            expect "password"
            send "MyPasswordr"
            interact


            I think maybe the interact is missing in your script.






            share|improve this answer




















            • this is absolutely working fine for me and i am stuck in this place, the interact provides interactive terminal with prompt, but i am trying to automate further more steps like do cd and ls and read the contents of the file as well. Is it possible to do after interact? Please reply
              – Hansie
              Aug 1 at 14:57










            • @Hansie you can send an ls command after the login. For example after sending password, do an expect with the command prompt text (to make sure you are logged in), then send "lsr". All of these goes before interact.
              – saeedn
              Aug 3 at 0:09










            • the question was slightly incorrect and i am sorry after doing ls and read contents, i am able to print the same. But how to get that out of ssh session into a variable to access from local machine. ref: stackoverflow.com/questions/32341234/expect-script-return-value. But output is not working for me. My question posted: stackoverflow.com/questions/51628465/…. I need file_list after exit to access from local command prompt
              – Hansie
              Aug 3 at 6:02












            up vote
            29
            down vote



            accepted







            up vote
            29
            down vote



            accepted






            I once wrote an expect script to log in to a ssh server (like your case) and my script was something like this:



            #!/usr/bin/expect

            spawn ssh MyUserName@192.168.20.20
            expect "password"
            send "MyPasswordr"
            interact


            I think maybe the interact is missing in your script.






            share|improve this answer












            I once wrote an expect script to log in to a ssh server (like your case) and my script was something like this:



            #!/usr/bin/expect

            spawn ssh MyUserName@192.168.20.20
            expect "password"
            send "MyPasswordr"
            interact


            I think maybe the interact is missing in your script.







            share|improve this answer












            share|improve this answer



            share|improve this answer










            answered Feb 7 '12 at 9:43









            saeedn

            1,60411215




            1,60411215











            • this is absolutely working fine for me and i am stuck in this place, the interact provides interactive terminal with prompt, but i am trying to automate further more steps like do cd and ls and read the contents of the file as well. Is it possible to do after interact? Please reply
              – Hansie
              Aug 1 at 14:57










            • @Hansie you can send an ls command after the login. For example after sending password, do an expect with the command prompt text (to make sure you are logged in), then send "lsr". All of these goes before interact.
              – saeedn
              Aug 3 at 0:09










            • the question was slightly incorrect and i am sorry after doing ls and read contents, i am able to print the same. But how to get that out of ssh session into a variable to access from local machine. ref: stackoverflow.com/questions/32341234/expect-script-return-value. But output is not working for me. My question posted: stackoverflow.com/questions/51628465/…. I need file_list after exit to access from local command prompt
              – Hansie
              Aug 3 at 6:02
















            • this is absolutely working fine for me and i am stuck in this place, the interact provides interactive terminal with prompt, but i am trying to automate further more steps like do cd and ls and read the contents of the file as well. Is it possible to do after interact? Please reply
              – Hansie
              Aug 1 at 14:57










            • @Hansie you can send an ls command after the login. For example after sending password, do an expect with the command prompt text (to make sure you are logged in), then send "lsr". All of these goes before interact.
              – saeedn
              Aug 3 at 0:09










            • the question was slightly incorrect and i am sorry after doing ls and read contents, i am able to print the same. But how to get that out of ssh session into a variable to access from local machine. ref: stackoverflow.com/questions/32341234/expect-script-return-value. But output is not working for me. My question posted: stackoverflow.com/questions/51628465/…. I need file_list after exit to access from local command prompt
              – Hansie
              Aug 3 at 6:02















            this is absolutely working fine for me and i am stuck in this place, the interact provides interactive terminal with prompt, but i am trying to automate further more steps like do cd and ls and read the contents of the file as well. Is it possible to do after interact? Please reply
            – Hansie
            Aug 1 at 14:57




            this is absolutely working fine for me and i am stuck in this place, the interact provides interactive terminal with prompt, but i am trying to automate further more steps like do cd and ls and read the contents of the file as well. Is it possible to do after interact? Please reply
            – Hansie
            Aug 1 at 14:57












            @Hansie you can send an ls command after the login. For example after sending password, do an expect with the command prompt text (to make sure you are logged in), then send "lsr". All of these goes before interact.
            – saeedn
            Aug 3 at 0:09




            @Hansie you can send an ls command after the login. For example after sending password, do an expect with the command prompt text (to make sure you are logged in), then send "lsr". All of these goes before interact.
            – saeedn
            Aug 3 at 0:09












            the question was slightly incorrect and i am sorry after doing ls and read contents, i am able to print the same. But how to get that out of ssh session into a variable to access from local machine. ref: stackoverflow.com/questions/32341234/expect-script-return-value. But output is not working for me. My question posted: stackoverflow.com/questions/51628465/…. I need file_list after exit to access from local command prompt
            – Hansie
            Aug 3 at 6:02




            the question was slightly incorrect and i am sorry after doing ls and read contents, i am able to print the same. But how to get that out of ssh session into a variable to access from local machine. ref: stackoverflow.com/questions/32341234/expect-script-return-value. But output is not working for me. My question posted: stackoverflow.com/questions/51628465/…. I need file_list after exit to access from local command prompt
            – Hansie
            Aug 3 at 6:02












            up vote
            30
            down vote













            You're going about it the wrong way. What you want to do is generate a passwordless ssh-key pair and then (as long as the server supports RSA key authentication) you can get in without having to type a password for all. This is a security risk if your private key is stored somewhere that it could be stolen.



            Follow these steps:



            1. mkdir -p ~/.ssh

            2. cd ~/.ssh

            3. ssh-keygen -type dsa -i mysshkeys

            4. Press Return when prompted for passphrase

            5. Press Return a second time to confirm.

            There will now be two files in your ~/.ssh directory, mysshkey.pub and mysshkey. mysshkey.pub is your public key, this one is safe to put on remote servers. mysshkey is your private passwordless key, it is not safe to put on remote servers (or somewhere someone else could get a copy).



            On the server you wish to SSH into:



            1. Login to the remote server

            2. mkdir -p ~/.ssh

            3. Copy and paste the contents of mysshkey.pub into ~/.ssh/authorized_keys

            4. Make sure that ~/.ssh/authorized_keys is chmod'd to 600

            Now, to put it into action on your local machine you run the following command:



            ssh -i ~/.ssh/mysshkey <remote_server_ip>


            And you will be logged in without being prompted for a password.



            This is a much preferable method of managing automated logins as you don't end up hard-coding your password multiple places that need to be updated if you ever change it.






            share|improve this answer


















            • 2




              I would use RSA keys rather than DSA. But other than that, full agree.
              – glglgl
              Feb 7 '12 at 9:03







            • 9




              sometimes you cannot add keys to the remote host, eg network appliances.
              – DarkHeart
              Apr 13 '16 at 5:07






            • 1




              I tried this. ssh is still asking for a password. Do you specifically have to give an IP address? I tried it with both <user>@<domain-name> and just the domain name.
              – Jay Bienvenu
              Jun 20 '17 at 14:39










            • This command said too many arguments? (for step 3)
              – Joseph Astrahan
              Aug 8 '17 at 2:59











            • I had to change to ssh-keygen -t dsa and manually enter file location instead.
              – Joseph Astrahan
              Aug 8 '17 at 3:10














            up vote
            30
            down vote













            You're going about it the wrong way. What you want to do is generate a passwordless ssh-key pair and then (as long as the server supports RSA key authentication) you can get in without having to type a password for all. This is a security risk if your private key is stored somewhere that it could be stolen.



            Follow these steps:



            1. mkdir -p ~/.ssh

            2. cd ~/.ssh

            3. ssh-keygen -type dsa -i mysshkeys

            4. Press Return when prompted for passphrase

            5. Press Return a second time to confirm.

            There will now be two files in your ~/.ssh directory, mysshkey.pub and mysshkey. mysshkey.pub is your public key, this one is safe to put on remote servers. mysshkey is your private passwordless key, it is not safe to put on remote servers (or somewhere someone else could get a copy).



            On the server you wish to SSH into:



            1. Login to the remote server

            2. mkdir -p ~/.ssh

            3. Copy and paste the contents of mysshkey.pub into ~/.ssh/authorized_keys

            4. Make sure that ~/.ssh/authorized_keys is chmod'd to 600

            Now, to put it into action on your local machine you run the following command:



            ssh -i ~/.ssh/mysshkey <remote_server_ip>


            And you will be logged in without being prompted for a password.



            This is a much preferable method of managing automated logins as you don't end up hard-coding your password multiple places that need to be updated if you ever change it.






            share|improve this answer


















            • 2




              I would use RSA keys rather than DSA. But other than that, full agree.
              – glglgl
              Feb 7 '12 at 9:03







            • 9




              sometimes you cannot add keys to the remote host, eg network appliances.
              – DarkHeart
              Apr 13 '16 at 5:07






            • 1




              I tried this. ssh is still asking for a password. Do you specifically have to give an IP address? I tried it with both <user>@<domain-name> and just the domain name.
              – Jay Bienvenu
              Jun 20 '17 at 14:39










            • This command said too many arguments? (for step 3)
              – Joseph Astrahan
              Aug 8 '17 at 2:59











            • I had to change to ssh-keygen -t dsa and manually enter file location instead.
              – Joseph Astrahan
              Aug 8 '17 at 3:10












            up vote
            30
            down vote










            up vote
            30
            down vote









            You're going about it the wrong way. What you want to do is generate a passwordless ssh-key pair and then (as long as the server supports RSA key authentication) you can get in without having to type a password for all. This is a security risk if your private key is stored somewhere that it could be stolen.



            Follow these steps:



            1. mkdir -p ~/.ssh

            2. cd ~/.ssh

            3. ssh-keygen -type dsa -i mysshkeys

            4. Press Return when prompted for passphrase

            5. Press Return a second time to confirm.

            There will now be two files in your ~/.ssh directory, mysshkey.pub and mysshkey. mysshkey.pub is your public key, this one is safe to put on remote servers. mysshkey is your private passwordless key, it is not safe to put on remote servers (or somewhere someone else could get a copy).



            On the server you wish to SSH into:



            1. Login to the remote server

            2. mkdir -p ~/.ssh

            3. Copy and paste the contents of mysshkey.pub into ~/.ssh/authorized_keys

            4. Make sure that ~/.ssh/authorized_keys is chmod'd to 600

            Now, to put it into action on your local machine you run the following command:



            ssh -i ~/.ssh/mysshkey <remote_server_ip>


            And you will be logged in without being prompted for a password.



            This is a much preferable method of managing automated logins as you don't end up hard-coding your password multiple places that need to be updated if you ever change it.






            share|improve this answer














            You're going about it the wrong way. What you want to do is generate a passwordless ssh-key pair and then (as long as the server supports RSA key authentication) you can get in without having to type a password for all. This is a security risk if your private key is stored somewhere that it could be stolen.



            Follow these steps:



            1. mkdir -p ~/.ssh

            2. cd ~/.ssh

            3. ssh-keygen -type dsa -i mysshkeys

            4. Press Return when prompted for passphrase

            5. Press Return a second time to confirm.

            There will now be two files in your ~/.ssh directory, mysshkey.pub and mysshkey. mysshkey.pub is your public key, this one is safe to put on remote servers. mysshkey is your private passwordless key, it is not safe to put on remote servers (or somewhere someone else could get a copy).



            On the server you wish to SSH into:



            1. Login to the remote server

            2. mkdir -p ~/.ssh

            3. Copy and paste the contents of mysshkey.pub into ~/.ssh/authorized_keys

            4. Make sure that ~/.ssh/authorized_keys is chmod'd to 600

            Now, to put it into action on your local machine you run the following command:



            ssh -i ~/.ssh/mysshkey <remote_server_ip>


            And you will be logged in without being prompted for a password.



            This is a much preferable method of managing automated logins as you don't end up hard-coding your password multiple places that need to be updated if you ever change it.







            share|improve this answer














            share|improve this answer



            share|improve this answer








            edited Nov 11 '15 at 14:30









            Steven Linn

            1033




            1033










            answered Feb 7 '12 at 7:38









            synthesizerpatel

            489613




            489613







            • 2




              I would use RSA keys rather than DSA. But other than that, full agree.
              – glglgl
              Feb 7 '12 at 9:03







            • 9




              sometimes you cannot add keys to the remote host, eg network appliances.
              – DarkHeart
              Apr 13 '16 at 5:07






            • 1




              I tried this. ssh is still asking for a password. Do you specifically have to give an IP address? I tried it with both <user>@<domain-name> and just the domain name.
              – Jay Bienvenu
              Jun 20 '17 at 14:39










            • This command said too many arguments? (for step 3)
              – Joseph Astrahan
              Aug 8 '17 at 2:59











            • I had to change to ssh-keygen -t dsa and manually enter file location instead.
              – Joseph Astrahan
              Aug 8 '17 at 3:10












            • 2




              I would use RSA keys rather than DSA. But other than that, full agree.
              – glglgl
              Feb 7 '12 at 9:03







            • 9




              sometimes you cannot add keys to the remote host, eg network appliances.
              – DarkHeart
              Apr 13 '16 at 5:07






            • 1




              I tried this. ssh is still asking for a password. Do you specifically have to give an IP address? I tried it with both <user>@<domain-name> and just the domain name.
              – Jay Bienvenu
              Jun 20 '17 at 14:39










            • This command said too many arguments? (for step 3)
              – Joseph Astrahan
              Aug 8 '17 at 2:59











            • I had to change to ssh-keygen -t dsa and manually enter file location instead.
              – Joseph Astrahan
              Aug 8 '17 at 3:10







            2




            2




            I would use RSA keys rather than DSA. But other than that, full agree.
            – glglgl
            Feb 7 '12 at 9:03





            I would use RSA keys rather than DSA. But other than that, full agree.
            – glglgl
            Feb 7 '12 at 9:03





            9




            9




            sometimes you cannot add keys to the remote host, eg network appliances.
            – DarkHeart
            Apr 13 '16 at 5:07




            sometimes you cannot add keys to the remote host, eg network appliances.
            – DarkHeart
            Apr 13 '16 at 5:07




            1




            1




            I tried this. ssh is still asking for a password. Do you specifically have to give an IP address? I tried it with both <user>@<domain-name> and just the domain name.
            – Jay Bienvenu
            Jun 20 '17 at 14:39




            I tried this. ssh is still asking for a password. Do you specifically have to give an IP address? I tried it with both <user>@<domain-name> and just the domain name.
            – Jay Bienvenu
            Jun 20 '17 at 14:39












            This command said too many arguments? (for step 3)
            – Joseph Astrahan
            Aug 8 '17 at 2:59





            This command said too many arguments? (for step 3)
            – Joseph Astrahan
            Aug 8 '17 at 2:59













            I had to change to ssh-keygen -t dsa and manually enter file location instead.
            – Joseph Astrahan
            Aug 8 '17 at 3:10




            I had to change to ssh-keygen -t dsa and manually enter file location instead.
            – Joseph Astrahan
            Aug 8 '17 at 3:10










            up vote
            16
            down vote













            On Debian-based distributions, the sshpass package provides an easier way of doing what you want. The package is available for many other popular distributions. You need to set it up first:



            echo 'YourPassword' > passwordFile.txt
            chmod 600 passwordFile.txt


            Then invoke the SSH command from a script like this:



            sshpass -f /path/to/passwordFile.txt /usr/bin/ssh -p 8484 root@172.31.72.103


            This provides more flexibility, such as if you're using a different locale or need to change the password, than solutions using expect.






            share|improve this answer


























              up vote
              16
              down vote













              On Debian-based distributions, the sshpass package provides an easier way of doing what you want. The package is available for many other popular distributions. You need to set it up first:



              echo 'YourPassword' > passwordFile.txt
              chmod 600 passwordFile.txt


              Then invoke the SSH command from a script like this:



              sshpass -f /path/to/passwordFile.txt /usr/bin/ssh -p 8484 root@172.31.72.103


              This provides more flexibility, such as if you're using a different locale or need to change the password, than solutions using expect.






              share|improve this answer
























                up vote
                16
                down vote










                up vote
                16
                down vote









                On Debian-based distributions, the sshpass package provides an easier way of doing what you want. The package is available for many other popular distributions. You need to set it up first:



                echo 'YourPassword' > passwordFile.txt
                chmod 600 passwordFile.txt


                Then invoke the SSH command from a script like this:



                sshpass -f /path/to/passwordFile.txt /usr/bin/ssh -p 8484 root@172.31.72.103


                This provides more flexibility, such as if you're using a different locale or need to change the password, than solutions using expect.






                share|improve this answer














                On Debian-based distributions, the sshpass package provides an easier way of doing what you want. The package is available for many other popular distributions. You need to set it up first:



                echo 'YourPassword' > passwordFile.txt
                chmod 600 passwordFile.txt


                Then invoke the SSH command from a script like this:



                sshpass -f /path/to/passwordFile.txt /usr/bin/ssh -p 8484 root@172.31.72.103


                This provides more flexibility, such as if you're using a different locale or need to change the password, than solutions using expect.







                share|improve this answer














                share|improve this answer



                share|improve this answer








                edited Jun 11 '15 at 0:53









                terdon♦

                123k28232405




                123k28232405










                answered Dec 28 '12 at 2:02









                likeitlikeit

                1,471186




                1,471186




















                    up vote
                    5
                    down vote













                    First install the sshPass sudo apt-get install sshpass



                    Then create an alias in .bashrc file as



                    alias sshLogin='sshpass -p <your ssh password> ssh username@remote_host'


                    Now reload your changed .bashrc file by source ~/.bashrc



                    You are now done.



                    Now you can run the ssh using the above created alias sshLogin in terminal.






                    share|improve this answer


























                      up vote
                      5
                      down vote













                      First install the sshPass sudo apt-get install sshpass



                      Then create an alias in .bashrc file as



                      alias sshLogin='sshpass -p <your ssh password> ssh username@remote_host'


                      Now reload your changed .bashrc file by source ~/.bashrc



                      You are now done.



                      Now you can run the ssh using the above created alias sshLogin in terminal.






                      share|improve this answer
























                        up vote
                        5
                        down vote










                        up vote
                        5
                        down vote









                        First install the sshPass sudo apt-get install sshpass



                        Then create an alias in .bashrc file as



                        alias sshLogin='sshpass -p <your ssh password> ssh username@remote_host'


                        Now reload your changed .bashrc file by source ~/.bashrc



                        You are now done.



                        Now you can run the ssh using the above created alias sshLogin in terminal.






                        share|improve this answer














                        First install the sshPass sudo apt-get install sshpass



                        Then create an alias in .bashrc file as



                        alias sshLogin='sshpass -p <your ssh password> ssh username@remote_host'


                        Now reload your changed .bashrc file by source ~/.bashrc



                        You are now done.



                        Now you can run the ssh using the above created alias sshLogin in terminal.







                        share|improve this answer














                        share|improve this answer



                        share|improve this answer








                        edited Aug 17 at 12:57









                        Anthony Giorgio

                        1034




                        1034










                        answered Nov 28 '16 at 8:42









                        bpathak

                        5111




                        5111




















                            up vote
                            4
                            down vote













                            you can use this:



                            sshpass -p 'yourpassword' ssh user@ip





                            share|improve this answer


























                              up vote
                              4
                              down vote













                              you can use this:



                              sshpass -p 'yourpassword' ssh user@ip





                              share|improve this answer
























                                up vote
                                4
                                down vote










                                up vote
                                4
                                down vote









                                you can use this:



                                sshpass -p 'yourpassword' ssh user@ip





                                share|improve this answer














                                you can use this:



                                sshpass -p 'yourpassword' ssh user@ip






                                share|improve this answer














                                share|improve this answer



                                share|improve this answer








                                edited Jan 29 at 19:10









                                terdon♦

                                123k28232405




                                123k28232405










                                answered Nov 23 '16 at 12:08









                                Behrooz Mohamadi nasab

                                553




                                553




















                                    up vote
                                    1
                                    down vote













                                    SSH Passwordless Login Using SSH Keygen in 5 Easy Steps:



                                    Environment setup:
                                    enter image description here



                                    Step 1: Authentication SSH-Kegen Keys on – (192.168.0.12)

                                    First login into server 192.168.0.12 with a user and generate a pair of public keys using following command.



                                    enter image description here



                                    Step 2: Create .ssh Directory on – 192.168.0.11

                                    Use SSH from server 192.168.0.12 to connect server 192.168.0.11 to create .ssh directory under it, using following command.



                                    enter image description here



                                    Step 3: Upload Generated Public Keys to – 192.168.0.11

                                    Use SSH from server 192.168.0.12 and upload new generated public key (id_rsa.pub) on server 192.168.0.11 under user's .ssh directory as a file name authorized_keys.



                                    enter image description here



                                    Step 4: Set Permissions on – 192.168.0.11

                                    Due to different SSH versions on servers, we need to set permissions on .ssh directory and authorized_keys file.



                                    enter image description here



                                    Step 5: Login from 192.168.0.12 to 192.168.0.11 Server without Password

                                    From now onwards we can log into 192.168.0.11 as sheena user from server 192.168.0.12 as tecmint user without password.



                                    enter image description here






                                    share|improve this answer




















                                    • Thanks... this worked for me, except at step 4 I got a dramatic "warning": "UNPROTECTED PRIVATE KEY FILE! ... .../.ssh/id_rsa' are too open. ... private key will be ignored... bad permissions". I did chmod 700 id_rsa in directory .ssh in the local (client, i.e. 192.168.0.12 in your example) server: problem solved
                                      – mike rodent
                                      Apr 21 at 8:14






                                    • 2




                                      Please don't post pictures of text.
                                      – roaima
                                      Jun 16 at 22:39














                                    up vote
                                    1
                                    down vote













                                    SSH Passwordless Login Using SSH Keygen in 5 Easy Steps:



                                    Environment setup:
                                    enter image description here



                                    Step 1: Authentication SSH-Kegen Keys on – (192.168.0.12)

                                    First login into server 192.168.0.12 with a user and generate a pair of public keys using following command.



                                    enter image description here



                                    Step 2: Create .ssh Directory on – 192.168.0.11

                                    Use SSH from server 192.168.0.12 to connect server 192.168.0.11 to create .ssh directory under it, using following command.



                                    enter image description here



                                    Step 3: Upload Generated Public Keys to – 192.168.0.11

                                    Use SSH from server 192.168.0.12 and upload new generated public key (id_rsa.pub) on server 192.168.0.11 under user's .ssh directory as a file name authorized_keys.



                                    enter image description here



                                    Step 4: Set Permissions on – 192.168.0.11

                                    Due to different SSH versions on servers, we need to set permissions on .ssh directory and authorized_keys file.



                                    enter image description here



                                    Step 5: Login from 192.168.0.12 to 192.168.0.11 Server without Password

                                    From now onwards we can log into 192.168.0.11 as sheena user from server 192.168.0.12 as tecmint user without password.



                                    enter image description here






                                    share|improve this answer




















                                    • Thanks... this worked for me, except at step 4 I got a dramatic "warning": "UNPROTECTED PRIVATE KEY FILE! ... .../.ssh/id_rsa' are too open. ... private key will be ignored... bad permissions". I did chmod 700 id_rsa in directory .ssh in the local (client, i.e. 192.168.0.12 in your example) server: problem solved
                                      – mike rodent
                                      Apr 21 at 8:14






                                    • 2




                                      Please don't post pictures of text.
                                      – roaima
                                      Jun 16 at 22:39












                                    up vote
                                    1
                                    down vote










                                    up vote
                                    1
                                    down vote









                                    SSH Passwordless Login Using SSH Keygen in 5 Easy Steps:



                                    Environment setup:
                                    enter image description here



                                    Step 1: Authentication SSH-Kegen Keys on – (192.168.0.12)

                                    First login into server 192.168.0.12 with a user and generate a pair of public keys using following command.



                                    enter image description here



                                    Step 2: Create .ssh Directory on – 192.168.0.11

                                    Use SSH from server 192.168.0.12 to connect server 192.168.0.11 to create .ssh directory under it, using following command.



                                    enter image description here



                                    Step 3: Upload Generated Public Keys to – 192.168.0.11

                                    Use SSH from server 192.168.0.12 and upload new generated public key (id_rsa.pub) on server 192.168.0.11 under user's .ssh directory as a file name authorized_keys.



                                    enter image description here



                                    Step 4: Set Permissions on – 192.168.0.11

                                    Due to different SSH versions on servers, we need to set permissions on .ssh directory and authorized_keys file.



                                    enter image description here



                                    Step 5: Login from 192.168.0.12 to 192.168.0.11 Server without Password

                                    From now onwards we can log into 192.168.0.11 as sheena user from server 192.168.0.12 as tecmint user without password.



                                    enter image description here






                                    share|improve this answer












                                    SSH Passwordless Login Using SSH Keygen in 5 Easy Steps:



                                    Environment setup:
                                    enter image description here



                                    Step 1: Authentication SSH-Kegen Keys on – (192.168.0.12)

                                    First login into server 192.168.0.12 with a user and generate a pair of public keys using following command.



                                    enter image description here



                                    Step 2: Create .ssh Directory on – 192.168.0.11

                                    Use SSH from server 192.168.0.12 to connect server 192.168.0.11 to create .ssh directory under it, using following command.



                                    enter image description here



                                    Step 3: Upload Generated Public Keys to – 192.168.0.11

                                    Use SSH from server 192.168.0.12 and upload new generated public key (id_rsa.pub) on server 192.168.0.11 under user's .ssh directory as a file name authorized_keys.



                                    enter image description here



                                    Step 4: Set Permissions on – 192.168.0.11

                                    Due to different SSH versions on servers, we need to set permissions on .ssh directory and authorized_keys file.



                                    enter image description here



                                    Step 5: Login from 192.168.0.12 to 192.168.0.11 Server without Password

                                    From now onwards we can log into 192.168.0.11 as sheena user from server 192.168.0.12 as tecmint user without password.



                                    enter image description here







                                    share|improve this answer












                                    share|improve this answer



                                    share|improve this answer










                                    answered Sep 15 '17 at 0:47









                                    Premraj

                                    9621817




                                    9621817











                                    • Thanks... this worked for me, except at step 4 I got a dramatic "warning": "UNPROTECTED PRIVATE KEY FILE! ... .../.ssh/id_rsa' are too open. ... private key will be ignored... bad permissions". I did chmod 700 id_rsa in directory .ssh in the local (client, i.e. 192.168.0.12 in your example) server: problem solved
                                      – mike rodent
                                      Apr 21 at 8:14






                                    • 2




                                      Please don't post pictures of text.
                                      – roaima
                                      Jun 16 at 22:39
















                                    • Thanks... this worked for me, except at step 4 I got a dramatic "warning": "UNPROTECTED PRIVATE KEY FILE! ... .../.ssh/id_rsa' are too open. ... private key will be ignored... bad permissions". I did chmod 700 id_rsa in directory .ssh in the local (client, i.e. 192.168.0.12 in your example) server: problem solved
                                      – mike rodent
                                      Apr 21 at 8:14






                                    • 2




                                      Please don't post pictures of text.
                                      – roaima
                                      Jun 16 at 22:39















                                    Thanks... this worked for me, except at step 4 I got a dramatic "warning": "UNPROTECTED PRIVATE KEY FILE! ... .../.ssh/id_rsa' are too open. ... private key will be ignored... bad permissions". I did chmod 700 id_rsa in directory .ssh in the local (client, i.e. 192.168.0.12 in your example) server: problem solved
                                    – mike rodent
                                    Apr 21 at 8:14




                                    Thanks... this worked for me, except at step 4 I got a dramatic "warning": "UNPROTECTED PRIVATE KEY FILE! ... .../.ssh/id_rsa' are too open. ... private key will be ignored... bad permissions". I did chmod 700 id_rsa in directory .ssh in the local (client, i.e. 192.168.0.12 in your example) server: problem solved
                                    – mike rodent
                                    Apr 21 at 8:14




                                    2




                                    2




                                    Please don't post pictures of text.
                                    – roaima
                                    Jun 16 at 22:39




                                    Please don't post pictures of text.
                                    – roaima
                                    Jun 16 at 22:39










                                    up vote
                                    1
                                    down vote













                                    As already described in other answers, I also use sshpass but I combine it with the read command to store my password in an temporary environment variable. This way my password is never written anywhere in clear. Here is the one line command I use:



                                    read -s PASS; sshpass -p $PASS ssh <user>@<host adress>


                                    After that you have to enter your password (nothing appears on the screen) and then pressing enter will open the connection.






                                    share|improve this answer
























                                      up vote
                                      1
                                      down vote













                                      As already described in other answers, I also use sshpass but I combine it with the read command to store my password in an temporary environment variable. This way my password is never written anywhere in clear. Here is the one line command I use:



                                      read -s PASS; sshpass -p $PASS ssh <user>@<host adress>


                                      After that you have to enter your password (nothing appears on the screen) and then pressing enter will open the connection.






                                      share|improve this answer






















                                        up vote
                                        1
                                        down vote










                                        up vote
                                        1
                                        down vote









                                        As already described in other answers, I also use sshpass but I combine it with the read command to store my password in an temporary environment variable. This way my password is never written anywhere in clear. Here is the one line command I use:



                                        read -s PASS; sshpass -p $PASS ssh <user>@<host adress>


                                        After that you have to enter your password (nothing appears on the screen) and then pressing enter will open the connection.






                                        share|improve this answer












                                        As already described in other answers, I also use sshpass but I combine it with the read command to store my password in an temporary environment variable. This way my password is never written anywhere in clear. Here is the one line command I use:



                                        read -s PASS; sshpass -p $PASS ssh <user>@<host adress>


                                        After that you have to enter your password (nothing appears on the screen) and then pressing enter will open the connection.







                                        share|improve this answer












                                        share|improve this answer



                                        share|improve this answer










                                        answered May 31 at 19:48









                                        StormRider

                                        211




                                        211




















                                            up vote
                                            1
                                            down vote













                                            All what you need it to create a hashed key and save it on your PC



                                            Just type



                                            ssh-keygen -t rsa -b 4096 # just press Enter till the end


                                            then enter



                                            ssh-copy-id <user>@<server>


                                            then login normally using



                                            ssh <user>@<server>


                                            Now you don't need a password




                                            Note: Saving your password in a plain text is dangerous



                                            This method is creating a hashed value of your password using RSA with public key of length 4096 which is very secure.







                                            share|improve this answer


















                                            • 1




                                              This appears to be a repeat of this answer.
                                              – roaima
                                              Jun 16 at 22:40















                                            up vote
                                            1
                                            down vote













                                            All what you need it to create a hashed key and save it on your PC



                                            Just type



                                            ssh-keygen -t rsa -b 4096 # just press Enter till the end


                                            then enter



                                            ssh-copy-id <user>@<server>


                                            then login normally using



                                            ssh <user>@<server>


                                            Now you don't need a password




                                            Note: Saving your password in a plain text is dangerous



                                            This method is creating a hashed value of your password using RSA with public key of length 4096 which is very secure.







                                            share|improve this answer


















                                            • 1




                                              This appears to be a repeat of this answer.
                                              – roaima
                                              Jun 16 at 22:40













                                            up vote
                                            1
                                            down vote










                                            up vote
                                            1
                                            down vote









                                            All what you need it to create a hashed key and save it on your PC



                                            Just type



                                            ssh-keygen -t rsa -b 4096 # just press Enter till the end


                                            then enter



                                            ssh-copy-id <user>@<server>


                                            then login normally using



                                            ssh <user>@<server>


                                            Now you don't need a password




                                            Note: Saving your password in a plain text is dangerous



                                            This method is creating a hashed value of your password using RSA with public key of length 4096 which is very secure.







                                            share|improve this answer














                                            All what you need it to create a hashed key and save it on your PC



                                            Just type



                                            ssh-keygen -t rsa -b 4096 # just press Enter till the end


                                            then enter



                                            ssh-copy-id <user>@<server>


                                            then login normally using



                                            ssh <user>@<server>


                                            Now you don't need a password




                                            Note: Saving your password in a plain text is dangerous



                                            This method is creating a hashed value of your password using RSA with public key of length 4096 which is very secure.








                                            share|improve this answer














                                            share|improve this answer



                                            share|improve this answer








                                            edited Jun 17 at 2:17









                                            slm♦

                                            238k65493663




                                            238k65493663










                                            answered Jun 16 at 22:24









                                            Mohammad Hizzani

                                            113




                                            113







                                            • 1




                                              This appears to be a repeat of this answer.
                                              – roaima
                                              Jun 16 at 22:40













                                            • 1




                                              This appears to be a repeat of this answer.
                                              – roaima
                                              Jun 16 at 22:40








                                            1




                                            1




                                            This appears to be a repeat of this answer.
                                            – roaima
                                            Jun 16 at 22:40





                                            This appears to be a repeat of this answer.
                                            – roaima
                                            Jun 16 at 22:40











                                            up vote
                                            0
                                            down vote













                                            I recently did this, this may help you:



                                            sshpass -p 'password' username@ipaddress


                                            if this doesn't work then you'll have to generate keys in the other machine you want to connect with



                                            ssh-keygen


                                            it will generate private and public keys and ask you for a location, leave at empty it will save the keys in .ssh folder by default
                                            it will ask you for passphrase, you can also leave it empty
                                            the go in .ssh folder and change the public key name to 'authorized_keys'



                                            cd .ssh/
                                            mv id_rsa.pub authorized_keys
                                            useradd -d /home/username username


                                            this will add user to list
                                            now go to home directory and give permission and restart sshd services



                                            chmod 700 /home/username/.ssh
                                            chmod 644 /home/username/.ssh/authorized_keys
                                            chown root:root /home/dozee
                                            sudo service sshd restart


                                            now you will have to move the private key to the system at that location from where you are going to run the ssh command, then you can connect with



                                            sshpass -p 'password' ssh -i id_rsa username@ip


                                            if even that doesn't work then go in /etc/ssh open sshd_config with vim editor
                                            check if the pubkeyAuthenticatoin is turned to yes or not, if not change it to yes , restart the sshd services and then try it, it will definitely work.






                                            share|improve this answer
























                                              up vote
                                              0
                                              down vote













                                              I recently did this, this may help you:



                                              sshpass -p 'password' username@ipaddress


                                              if this doesn't work then you'll have to generate keys in the other machine you want to connect with



                                              ssh-keygen


                                              it will generate private and public keys and ask you for a location, leave at empty it will save the keys in .ssh folder by default
                                              it will ask you for passphrase, you can also leave it empty
                                              the go in .ssh folder and change the public key name to 'authorized_keys'



                                              cd .ssh/
                                              mv id_rsa.pub authorized_keys
                                              useradd -d /home/username username


                                              this will add user to list
                                              now go to home directory and give permission and restart sshd services



                                              chmod 700 /home/username/.ssh
                                              chmod 644 /home/username/.ssh/authorized_keys
                                              chown root:root /home/dozee
                                              sudo service sshd restart


                                              now you will have to move the private key to the system at that location from where you are going to run the ssh command, then you can connect with



                                              sshpass -p 'password' ssh -i id_rsa username@ip


                                              if even that doesn't work then go in /etc/ssh open sshd_config with vim editor
                                              check if the pubkeyAuthenticatoin is turned to yes or not, if not change it to yes , restart the sshd services and then try it, it will definitely work.






                                              share|improve this answer






















                                                up vote
                                                0
                                                down vote










                                                up vote
                                                0
                                                down vote









                                                I recently did this, this may help you:



                                                sshpass -p 'password' username@ipaddress


                                                if this doesn't work then you'll have to generate keys in the other machine you want to connect with



                                                ssh-keygen


                                                it will generate private and public keys and ask you for a location, leave at empty it will save the keys in .ssh folder by default
                                                it will ask you for passphrase, you can also leave it empty
                                                the go in .ssh folder and change the public key name to 'authorized_keys'



                                                cd .ssh/
                                                mv id_rsa.pub authorized_keys
                                                useradd -d /home/username username


                                                this will add user to list
                                                now go to home directory and give permission and restart sshd services



                                                chmod 700 /home/username/.ssh
                                                chmod 644 /home/username/.ssh/authorized_keys
                                                chown root:root /home/dozee
                                                sudo service sshd restart


                                                now you will have to move the private key to the system at that location from where you are going to run the ssh command, then you can connect with



                                                sshpass -p 'password' ssh -i id_rsa username@ip


                                                if even that doesn't work then go in /etc/ssh open sshd_config with vim editor
                                                check if the pubkeyAuthenticatoin is turned to yes or not, if not change it to yes , restart the sshd services and then try it, it will definitely work.






                                                share|improve this answer












                                                I recently did this, this may help you:



                                                sshpass -p 'password' username@ipaddress


                                                if this doesn't work then you'll have to generate keys in the other machine you want to connect with



                                                ssh-keygen


                                                it will generate private and public keys and ask you for a location, leave at empty it will save the keys in .ssh folder by default
                                                it will ask you for passphrase, you can also leave it empty
                                                the go in .ssh folder and change the public key name to 'authorized_keys'



                                                cd .ssh/
                                                mv id_rsa.pub authorized_keys
                                                useradd -d /home/username username


                                                this will add user to list
                                                now go to home directory and give permission and restart sshd services



                                                chmod 700 /home/username/.ssh
                                                chmod 644 /home/username/.ssh/authorized_keys
                                                chown root:root /home/dozee
                                                sudo service sshd restart


                                                now you will have to move the private key to the system at that location from where you are going to run the ssh command, then you can connect with



                                                sshpass -p 'password' ssh -i id_rsa username@ip


                                                if even that doesn't work then go in /etc/ssh open sshd_config with vim editor
                                                check if the pubkeyAuthenticatoin is turned to yes or not, if not change it to yes , restart the sshd services and then try it, it will definitely work.







                                                share|improve this answer












                                                share|improve this answer



                                                share|improve this answer










                                                answered May 30 at 18:37









                                                Utkarsh Gupta

                                                1




                                                1



























                                                     

                                                    draft saved


                                                    draft discarded















































                                                     


                                                    draft saved


                                                    draft discarded














                                                    StackExchange.ready(
                                                    function ()
                                                    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f31071%2fshell-script-for-logging-into-a-ssh-server%23new-answer', 'question_page');

                                                    );

                                                    Post as a guest













































































                                                    Popular posts from this blog

                                                    How to check contact read email or not when send email to Individual?

                                                    Displaying single band from multi-band raster using QGIS

                                                    How many registers does an x86_64 CPU actually have?