22
33SSH, Secure SHell, is an encrypted network protocol used to remotely interact with an Operating System at a command line
44level. SSH is available on most every system, including Windows, but is mainly used by * nix administrators. This module
5- attempts to login to SSH with username and password combinations. For public/private SSH keys, please use
6- ` auxiliary/scanner/ssh/ssh_login_pubkey ` . It should be noted that some modern Operating Systems have default
5+ attempts to login to SSH with username and password combinations. It should be noted that some modern Operating Systems have default
76configurations to not allow the ` root ` user to remotely login via SSH, or to only allow ` root ` to login with an SSH key
87login.
98
10- ## Verification Steps
9+ ## Verification Steps - Password Login
1110
12111 . Install SSH and start it.
13122 . Start msfconsole
@@ -21,6 +20,31 @@ login.
2120[+] SSH - Success: 'msfadmin:msfadmin' 'uid=1000(msfadmin) gid=1000(msfadmin) groups=4(adm),20(dialout),24(cdrom),25(floppy),29(audio),30(dip),44(video),46(plugdev),107(fuse),111(lpadmin),112(admin),119(sambashare),1000(msfadmin) Linux metasploitable 2.6.24-16-server #1 SMP Thu Apr 10 13:58:00 UTC 2008 i686 GNU/Linux '
2221```
2322
23+ ### Key Generation
24+
25+ On most modern * nix Operating System, the ` ssh-keygen ` command can be utilized to create an SSH key. Metasploit
26+ expects the key to be unencrypted, so no password should be set during ` ssh-keygen ` . After following the prompts to
27+ create the SSH key pair, the ` pub ` key needs to be added to the authorized_keys list. To do so simply run: `cat
28+ ~ /.ssh/id_rsa.pub >> ~ /.ssh/authorized_keys`
29+
30+ ## Verification Steps - SSH key login
31+
32+ 1 . Install SSH and start it.
33+ 2 . Create an SSH keypair and add the public key to the ` authorized_keys ` file
34+ 3 . Start msfconsole
35+ 4 . Do: ` use auxiliary/scanner/ssh/ssh_login_pubkey `
36+ 5 . Do: ` set rhosts `
37+ 6 . Do: set usernames with one of the available options
38+ 7 . Do: set private keys with one or both of the available options
39+ 1 . Do: ` set KEY_PATH ` to either a file or path
40+ 2 . Do: ` set PRIVATE_KEY ` to ` file:PRIVATE_KEY_PATH `
41+ 8 . Do: ` run `
42+ 9 . You will hopefully see something similar to the following:
43+
44+ ```
45+ [+] SSH - Success: 'ubuntu:-----BEGIN RSA PRIVATE KEY-----
46+ ```
47+
2448### Session Capabilities
2549
2650Like Meterpreter sessions, this newly established session can be used to pivot connections as defined by Metasploit's
@@ -67,6 +91,17 @@ Boolean value on if an additional login attempt should be attempted with the pas
6791
6892A file containing a username on every line.
6993
94+ ### KEY_PATH
95+
96+ A string to the private key to attempt, or a folder containing private keys to attempt. Any file name starting with a
97+ period (` . ` ) or ending in ` .pub ` will be ignored. An SSH key is typically kept in a user's home directory under
98+ ` .ssh/id_rsa ` . The file contents, when not encrypted with a password will start with ` -----BEGIN RSA PRIVATE KEY----- `
99+
100+ ### PRIVATE_KEY
101+
102+ A string of the private key to attempt. For MSFConsole users the option should be set to ` file:PRIVATE_KEY_PATH ` and it
103+ will read in the string value of the private key. Currently OpenSSH, RSA, DSA, and ECDSA private keys are supported.
104+
70105### VERBOSE
71106
72107Show a failed login attempt. This can get rather verbose when large ` USER_FILE ` s or ` PASS_FILE ` s are used. A failed
@@ -83,7 +118,7 @@ could be set in `PASSWORD`, be part of either `PASS_FILE` or `USERPASS_FILE`, be
83118` BLANK_PASSWORDS ` . This module makes a combination of all of the above when attempting logins. So if a password is set
84119in ` PASSWORD ` , and a ` PASS_FILE ` is listed, passwords will be generated from BOTH of these.
85120
86- ## Scenarios
121+ ## Scenarios - Password Login
87122
88123Example run against:
89124
@@ -216,3 +251,163 @@ msf auxiliary(ssh_login) > exploit
216251[*] Scanned 1 of 1 hosts (100% complete)
217252[*] Auxiliary module execution completed
218253```
254+
255+ ## Scenarios - SSH key login
256+
257+ Example run with a FOLDER set for ` KEY_PATH ` against:
258+
259+ * Ubuntu 14.04 Server
260+
261+ While the two SSH key are nearly identical, one character has been modified in one of the keys to prevent a successful
262+ login.
263+
264+ ```
265+ msf > use auxiliary/scanner/ssh/ssh_login_pubkey
266+ msf auxiliary(ssh_login_pubkey) > set rhosts 192.168.2.156
267+ rhosts => 192.168.2.156
268+ msf auxiliary(ssh_login_pubkey) > set username ubuntu
269+ username => ubuntu
270+ msf auxiliary(ssh_login_pubkey) > set key_path /root/sshkeys/
271+ key_path => /root/sshkeys/
272+ msf auxiliary(ssh_login_pubkey) > run
273+
274+ [*] 192.168.2.156:22 SSH - Testing Cleartext Keys
275+ [*] SSH - Testing 2 keys from /root/sshkeys
276+ [-] SSH - Failed: 'ubuntu:-----BEGIN RSA PRIVATE KEY-----
277+ MIIEpQIBAAKCAQEAtwJrqowPyjWONHUCMqU/Fh3yRn42+X9hahtTv/6plYpb4WrA
278+ NxDaYIrBGAO//u2SkGcIhnAdzYVmovWahKEwcxZ2XJo/nj4gjh1CbI1xVCFeE/oX
279+ oWpIN+4q8JQ0Iq1dm+c+WPQIEzlVpMRaKeuMxdGPNMTYWxolSEIMPPYmyWXG6gz8
280+ fYYZDo8+w8G78w7oUV6hSIwCDzw09A5yGyt51ZETeSZiZ24bHlBQSyk7yFq/eo58
281+ xhlc79jpZrSdX8kx8HrCZKND7O6E4YSktfSHOvd81QUCSyoi5Y+9RXsLjUEba0+Y
282+ aAz8mZPLdxbRu75eeD/mZTv5gALewXeb65IkPQIDAQABAoIBACvi5LbNR6wSE7v4
283+ o0JJ5ksDe2n0MnK6XT34t6i/BSPbPhVcaCPMYtHr9Eox/ATCK/d8/cpfcIYsi2Rg
284+ yWEs1lWC+XdTdhYYh+4MjjVB5f9q0QixXKFUv2TKNHnk0GvQbzZHyefC/Xy+rw8I
285+ FyceWW/GxTS+T7PpHS+qxwyHat24ph7Xz/cE/0UyrVu+NAzFXaHq60M2/RRh3uXE
286+ 1vqiZVlapczO/DxsnPwQrE2EOm0lzrQVmZbX5BYK1yiCd5eTgLhOb+ms2p/8pb2I
287+ jrK5FzLnUZu0H0ZHtihOVkx4l8NZqB36jinaRs0wWN7It4/C5+NkyoMvuceIn1Wx
288+ tstYD3ECgYEA7sOb0CdGxXw0IVrJF+3C8m1UG3CfQfzms+rJb9w3OJVl2BTlYdPr
289+ JgXI/YoV9FQPvXmTWrRP9e6x0kuSVHO1ejMpyLHGmMcJDZhpVKMROOosIWfROxwk
290+ bkPU2jdUXIrHgu8NnmnyytjUnJgeerQZLhCtjKmBKCZisS4WPBdun3MCgYEAxDh1
291+ fjFJttWhgeg6pcvvmDUWO1W0lJ9ZjjQll1UmbPmKDGwwsjPZEkZfLkvI77st81AT
292+ eW/p7tMKE3fCkXkn2KWMQ6ZGN5yflwvjJOMAVZz8ir8Cu1npa6f6HIrxpHSKethY
293+ dG4ssCpQctfoRfN4wg6fOHBOpGd3BH1GdOwR4Y8CgYEAq3h7e//ZCZbrcVDbvn2Y
294+ VbZCgvpcxW002d0yEU2bst1IKOjI23rwE3xwHfV/UtrT+wVG2AtKqZpkxlxTmKcI
295+ m9wGlAVoVOwMCmF8s7XwdmlmjA8c6lCJsU6xnI3D3jokklnP9AauwRL7jgKJUSHq
296+ O3TqzmwlP4phslEg0sMZRRUCgYEAwkS3prG7rqYBmjFG52FqnIJquWIYQFEoBE+C
297+ rDqkqZ3B3Jy89aG5l4tOrvJfRWJHky7DqSZxMH+G6VFXtFmEZs04er3DpUmPA6fE
298+ Qn/wk9KygdetJ7pUDL8pNFsn9M9hT1Ck+tkdq2ipb5ptn9v2wgJiBynB4qmBP1Oc
299+ jyQua+cCgYEAl77hJQK97tdJ5TuOXSsdpW8IMvbiaWTgvZtKVJev31lWgJ+knpCf
300+ AaZna5YokhaNvfGGbO5N8YoYShIpGdvWI+dIT8xYvPkJmYdnTz7/dmBUcwLtNVx/
301+ 7PI/l5XrFMRsnu/CYuBPuWB+RCTLjIr1D1RluNbIb7xr+kDHuzgInvA=
302+ -----END RSA PRIVATE KEY-----
303+
304+ '
305+ [!] No active DB -- Credential data will not be saved!
306+ [+] SSH - Success: 'ubuntu:-----BEGIN RSA PRIVATE KEY-----
307+ MIIEpQIBAAKCAQEAtwJrqowPyjWONHUCMqU/Fh3yRn42+X9hahtTv/6plYpb4WrA
308+ NxDaYIrBGAO//u2SkGcIhnAdzYVmovWahKEwcxZ2XJo/nj4gjh1CbI1xVCFeE/oX
309+ oWpIN+4q8JQ0Iq1dm+c+WPQIEzlVpMRaKeuMxdGPNMTYWxolSEIMPPYmyWXG6gz8
310+ fYYZDo8+w8G78w7oUV6hSIwCDzw09A5yGyt51ZETeSZiZ24bHlBQSyk7yFq/eo58
311+ xhlc79jpZrSdX8kx8HrCZKND7O6E4YSktfSHOvd81QUCSyoi5Y+9RXsLjUEba0+Y
312+ 0Az8mZPLdxbRu75eeD/mZTv5gALewXeb65IkPQIDAQABAoIBACvi5LbNR6wSE7v4
313+ o0JJ5ksDe2n0MnK6XT34t6i/BSPbPhVcaCPMYtHr9Eox/ATCK/d8/cpfcIYsi2Rg
314+ yWEs1lWC+XdTdhYYh+4MjjVB5f9q0QixXKFUv2TKNHnk0GvQbzZHyefC/Xy+rw8I
315+ FyceWW/GxTS+T7PpHS+qxwyHat24ph7Xz/cE/0UyrVu+NAzFXaHq60M2/RRh3uXE
316+ 1vqiZVlapczO/DxsnPwQrE2EOm0lzrQVmZbX5BYK1yiCd5eTgLhOb+ms2p/8pb2I
317+ jrK5FzLnUZu0H0ZHtihOVkx4l8NZqB36jinaRs0wWN7It4/C5+NkyoMvuceIn1Wx
318+ tstYD3ECgYEA7sOb0CdGxXw0IVrJF+3C8m1UG3CfQfzms+rJb9w3OJVl2BTlYdPr
319+ JgXI/YoV9FQPvXmTWrRP9e6x0kuSVHO1ejMpyLHGmMcJDZhpVKMROOosIWfROxwk
320+ bkPU2jdUXIrHgu8NnmnyytjUnJgeerQZLhCtjKmBKCZisS4WPBdun3MCgYEAxDh1
321+ fjFJttWhgeg6pcvvmDUWO1W0lJ9ZjjQll1UmbPmKDGwwsjPZEkZfLkvI77st81AT
322+ eW/p7tMKE3fCkXkn2KWMQ6ZGN5yflwvjJOMAVZz8ir8Cu1npa6f6HIrxpHSKethY
323+ dG4ssCpQctfoRfN4wg6fOHBOpGd3BH1GdOwR4Y8CgYEAq3h7e//ZCZbrcVDbvn2Y
324+ VbZCgvpcxW002d0yEU2bst1IKOjI23rwE3xwHfV/UtrT+wVG2AtKqZpkxlxTmKcI
325+ m9wGlAVoVOwMCmF8s7XwdmlmjA8c6lCJsU6xnI3D3jokklnP9AauwRL7jgKJUSHq
326+ O3TqzmwlP4phslEg0sMZRRUCgYEAwkS3prG7rqYBmjFG52FqnIJquWIYQFEoBE+C
327+ rDqkqZ3B3Jy89aG5l4tOrvJfRWJHky7DqSZxMH+G6VFXtFmEZs04er3DpUmPA6fE
328+ Qn/wk9KygdetJ7pUDL8pNFsn9M9hT1Ck+tkdq2ipb5ptn9v2wgJiBynB4qmBP1Oc
329+ jyQua+cCgYEAl77hJQK97tdJ5TuOXSsdpW8IMvbiaWTgvZtKVJev31lWgJ+knpCf
330+ AaZna5YokhaNvfGGbO5N8YoYShIpGdvWI+dIT8xYvPkJmYdnTz7/dmBUcwLtNVx/
331+ 7PI/l5XrFMRsnu/CYuBPuWB+RCTLjIr1D1RluNbIb7xr+kDHuzgInvA=
332+ -----END RSA PRIVATE KEY-----
333+
334+ ' 'uid=1000(ubuntu) gid=1000(ubuntu) groups=1000(ubuntu),4(adm),24(cdrom),27(sudo),30(dip),46(plugdev),110(lpadmin),111(sambashare) Linux Ubuntu14 4.2.0-27-generic #32~14.04.1-Ubuntu SMP Fri Jan 22 15:32:26 UTC 2016 x86_64 x86_64 x86_64 GNU/Linux '
335+ [*] Command shell session 1 opened (192.168.2.117:44179 -> 192.168.2.156:22) at 2017-02-22 22:08:11 -0500
336+ [*] Scanned 1 of 1 hosts (100% complete)
337+ [*] Auxiliary module execution completed
338+ ```
339+
340+ Similar example but run with a KEY FILE set for ` PRIVATE_KEY ` :
341+
342+ ```
343+ msf > use auxiliary/scanner/ssh/ssh_login_pubkey
344+ msf auxiliary(ssh_login_pubkey) > set rhosts 192.168.2.156
345+ rhosts => 192.168.2.156
346+ msf auxiliary(ssh_login_pubkey) > set username ubuntu
347+ username => ubuntu
348+ msf auxiliary(ssh_login_pubkey) > set private_key file:/root/sshkeys/id_rsa
349+ private_key => -----BEGIN RSA PRIVATE KEY-----
350+ MIIEpQIBAAKCAQEAtwJrqowPyjWONHUCMqU/Fh3yRn42+X9hahtTv/6plYpb4WrA
351+ NxDaYIrBGAO//u2SkGcIhnAdzYVmovWahKEwcxZ2XJo/nj4gjh1CbI1xVCFeE/oX
352+ oWpIN+4q8JQ0Iq1dm+c+WPQIEzlVpMRaKeuMxdGPNMTYWxolSEIMPPYmyWXG6gz8
353+ fYYZDo8+w8G78w7oUV6hSIwCDzw09A5yGyt51ZETeSZiZ24bHlBQSyk7yFq/eo58
354+ xhlc79jpZrSdX8kx8HrCZKND7O6E4YSktfSHOvd81QUCSyoi5Y+9RXsLjUEba0+Y
355+ 0Az8mZPLdxbRu75eeD/mZTv5gALewXeb65IkPQIDAQABAoIBACvi5LbNR6wSE7v4
356+ o0JJ5ksDe2n0MnK6XT34t6i/BSPbPhVcaCPMYtHr9Eox/ATCK/d8/cpfcIYsi2Rg
357+ yWEs1lWC+XdTdhYYh+4MjjVB5f9q0QixXKFUv2TKNHnk0GvQbzZHyefC/Xy+rw8I
358+ FyceWW/GxTS+T7PpHS+qxwyHat24ph7Xz/cE/0UyrVu+NAzFXaHq60M2/RRh3uXE
359+ 1vqiZVlapczO/DxsnPwQrE2EOm0lzrQVmZbX5BYK1yiCd5eTgLhOb+ms2p/8pb2I
360+ jrK5FzLnUZu0H0ZHtihOVkx4l8NZqB36jinaRs0wWN7It4/C5+NkyoMvuceIn1Wx
361+ tstYD3ECgYEA7sOb0CdGxXw0IVrJF+3C8m1UG3CfQfzms+rJb9w3OJVl2BTlYdPr
362+ JgXI/YoV9FQPvXmTWrRP9e6x0kuSVHO1ejMpyLHGmMcJDZhpVKMROOosIWfROxwk
363+ bkPU2jdUXIrHgu8NnmnyytjUnJgeerQZLhCtjKmBKCZisS4WPBdun3MCgYEAxDh1
364+ fjFJttWhgeg6pcvvmDUWO1W0lJ9ZjjQll1UmbPmKDGwwsjPZEkZfLkvI77st81AT
365+ eW/p7tMKE3fCkXkn2KWMQ6ZGN5yflwvjJOMAVZz8ir8Cu1npa6f6HIrxpHSKethY
366+ dG4ssCpQctfoRfN4wg6fOHBOpGd3BH1GdOwR4Y8CgYEAq3h7e//ZCZbrcVDbvn2Y
367+ VbZCgvpcxW002d0yEU2bst1IKOjI23rwE3xwHfV/UtrT+wVG2AtKqZpkxlxTmKcI
368+ m9wGlAVoVOwMCmF8s7XwdmlmjA8c6lCJsU6xnI3D3jokklnP9AauwRL7jgKJUSHq
369+ O3TqzmwlP4phslEg0sMZRRUCgYEAwkS3prG7rqYBmjFG52FqnIJquWIYQFEoBE+C
370+ rDqkqZ3B3Jy89aG5l4tOrvJfRWJHky7DqSZxMH+G6VFXtFmEZs04er3DpUmPA6fE
371+ Qn/wk9KygdetJ7pUDL8pNFsn9M9hT1Ck+tkdq2ipb5ptn9v2wgJiBynB4qmBP1Oc
372+ jyQua+cCgYEAl77hJQK97tdJ5TuOXSsdpW8IMvbiaWTgvZtKVJev31lWgJ+knpCf
373+ AaZna5YokhaNvfGGbO5N8YoYShIpGdvWI+dIT8xYvPkJmYdnTz7/dmBUcwLtNVx/
374+ 7PI/l5XrFMRsnu/CYuBPuWB+RCTLjIr1D1RluNbIb7xr+kDHuzgInvA=
375+ -----END RSA PRIVATE KEY-----
376+ msf auxiliary(ssh_login_pubkey) > run
377+
378+ [*] 192.168.2.156:22 SSH - Testing Cleartext Keys
379+ [*] SSH - Testing 1 keys from
380+ [+] SSH - Success: 'ubuntu:-----BEGIN RSA PRIVATE KEY-----
381+ MIIEpQIBAAKCAQEAtwJrqowPyjWONHUCMqU/Fh3yRn42+X9hahtTv/6plYpb4WrA
382+ NxDaYIrBGAO//u2SkGcIhnAdzYVmovWahKEwcxZ2XJo/nj4gjh1CbI1xVCFeE/oX
383+ oWpIN+4q8JQ0Iq1dm+c+WPQIEzlVpMRaKeuMxdGPNMTYWxolSEIMPPYmyWXG6gz8
384+ fYYZDo8+w8G78w7oUV6hSIwCDzw09A5yGyt51ZETeSZiZ24bHlBQSyk7yFq/eo58
385+ xhlc79jpZrSdX8kx8HrCZKND7O6E4YSktfSHOvd81QUCSyoi5Y+9RXsLjUEba0+Y
386+ 0Az8mZPLdxbRu75eeD/mZTv5gALewXeb65IkPQIDAQABAoIBACvi5LbNR6wSE7v4
387+ o0JJ5ksDe2n0MnK6XT34t6i/BSPbPhVcaCPMYtHr9Eox/ATCK/d8/cpfcIYsi2Rg
388+ yWEs1lWC+XdTdhYYh+4MjjVB5f9q0QixXKFUv2TKNHnk0GvQbzZHyefC/Xy+rw8I
389+ FyceWW/GxTS+T7PpHS+qxwyHat24ph7Xz/cE/0UyrVu+NAzFXaHq60M2/RRh3uXE
390+ 1vqiZVlapczO/DxsnPwQrE2EOm0lzrQVmZbX5BYK1yiCd5eTgLhOb+ms2p/8pb2I
391+ jrK5FzLnUZu0H0ZHtihOVkx4l8NZqB36jinaRs0wWN7It4/C5+NkyoMvuceIn1Wx
392+ tstYD3ECgYEA7sOb0CdGxXw0IVrJF+3C8m1UG3CfQfzms+rJb9w3OJVl2BTlYdPr
393+ JgXI/YoV9FQPvXmTWrRP9e6x0kuSVHO1ejMpyLHGmMcJDZhpVKMROOosIWfROxwk
394+ bkPU2jdUXIrHgu8NnmnyytjUnJgeerQZLhCtjKmBKCZisS4WPBdun3MCgYEAxDh1
395+ fjFJttWhgeg6pcvvmDUWO1W0lJ9ZjjQll1UmbPmKDGwwsjPZEkZfLkvI77st81AT
396+ eW/p7tMKE3fCkXkn2KWMQ6ZGN5yflwvjJOMAVZz8ir8Cu1npa6f6HIrxpHSKethY
397+ dG4ssCpQctfoRfN4wg6fOHBOpGd3BH1GdOwR4Y8CgYEAq3h7e//ZCZbrcVDbvn2Y
398+ VbZCgvpcxW002d0yEU2bst1IKOjI23rwE3xwHfV/UtrT+wVG2AtKqZpkxlxTmKcI
399+ m9wGlAVoVOwMCmF8s7XwdmlmjA8c6lCJsU6xnI3D3jokklnP9AauwRL7jgKJUSHq
400+ O3TqzmwlP4phslEg0sMZRRUCgYEAwkS3prG7rqYBmjFG52FqnIJquWIYQFEoBE+C
401+ rDqkqZ3B3Jy89aG5l4tOrvJfRWJHky7DqSZxMH+G6VFXtFmEZs04er3DpUmPA6fE
402+ Qn/wk9KygdetJ7pUDL8pNFsn9M9hT1Ck+tkdq2ipb5ptn9v2wgJiBynB4qmBP1Oc
403+ jyQua+cCgYEAl77hJQK97tdJ5TuOXSsdpW8IMvbiaWTgvZtKVJev31lWgJ+knpCf
404+ AaZna5YokhaNvfGGbO5N8YoYShIpGdvWI+dIT8xYvPkJmYdnTz7/dmBUcwLtNVx/
405+ 7PI/l5XrFMRsnu/CYuBPuWB+RCTLjIr1D1RluNbIb7xr+kDHuzgInvA=
406+ -----END RSA PRIVATE KEY-----
407+
408+ ' 'uid=1000(ubuntu) gid=1000(ubuntu) groups=1000(ubuntu),4(adm),24(cdrom),27(sudo),30(dip),46(plugdev),110(lpadmin),111(sambashare) Linux Ubuntu14 4.2.0-27-generic #32~14.04.1-Ubuntu SMP Fri Jan 22 15:32:26 UTC 2016 x86_64 x86_64 x86_64 GNU/Linux '
409+ [*] Command shell session 1 opened (192.168.2.117:44179 -> 192.168.2.156:22) at 2017-02-22 22:08:11 -0500
410+ [*] Scanned 1 of 1 hosts (100% complete)
411+ [*] Auxiliary module execution completed
412+ ```
413+
0 commit comments