前言
在拿到系统后,系统中可能存在连接其他服务器的软件,或浏览器等
这时候就需要去解密像ssh这类的连接软件,所有这里我对软件的密码获取做总结
ssh和ftp链接类
xshell
Xshell 是一个强大的安全终端模拟软件,它支持SSH1, SSH2, 以及Microsoft Windows 平台的TELNET 协议。
先找到xshell保存密码的位置,点打开会话文件夹
data:image/s3,"s3://crabby-images/8202d/8202d822e2da79df25a188f7e154da7a2ccb972a" alt="内网常用工具密码获取1"
其中.xsh里面就是保存的链接信息包括账户密码
data:image/s3,"s3://crabby-images/a1704/a1704036f8efd06e76dbb2ebb93a0053387917be" alt="内网常用工具密码获取1"
前提是登录的时候必须勾选了记住账户和密码
data:image/s3,"s3://crabby-images/5cdd5/5cdd51536c6e313677ce449c2180ef13061cb108" alt="内网常用工具密码获取1"
离线解密工具:https://github.com/HyperSine/how-does-Xmanager-encrypt-passwordpython XShellCryptoHelper.py -d -key 123123 zVi7hm/Nsk6y2BGpTNSvXlPRN+/1P+aQ
123132为主控密码在文件导出的时候设置 后面为.xsh文件中的password字段类容
data:image/s3,"s3://crabby-images/5c7e0/5c7e0c15a8ef58ea764209f4f4ad27e36c5d6dfd" alt="内网常用工具密码获取1"
另一种解法 未设置主控密码需要user和sidwhoami /user 查看user和sid
data:image/s3,"s3://crabby-images/7ef0f/7ef0fa79e0b5e780835c61d865fd77d2f9e7e15f" alt="内网常用工具密码获取1"
python XShellCryptoHelper.py -d -user aaaa -sid S-1-5-21-4217108860-1001 zVi7hm/Nsk6y2BGpTNSvXlPRN+/1P+aQ
data:image/s3,"s3://crabby-images/f25d4/f25d4a6b73e0575fcad50bc14a135af1767f7317" alt="内网常用工具密码获取1"
使用在线工具https://github.com/uknowsec/SharpDecryptPwd
data:image/s3,"s3://crabby-images/73e39/73e3901af3db9b2f9a0b1318eac9953040507f5e" alt="内网常用工具密码获取1"
该工具只支持在线解密的方式,就是必须要将工具放到目标机器上运行。
xftp一样的
SecureCRT
SecureCRT和xshell一样,很多运维人员会将SSH的账号密码保存在上面。
前提时管理员登录时勾选了记住密码
data:image/s3,"s3://crabby-images/9acd5/9acd530c6b03f363b832124689f371cb972e4e05" alt="内网常用工具密码获取1"
SecureCRT密码密码存放位置
C:\Users\oneseven\AppData\Roaming\VanDyke\Config\Sessions
data:image/s3,"s3://crabby-images/dbc5a/dbc5a9cd2bba82557886f4c25892f4e40a2a065b" alt="内网常用工具密码获取1"
打开后 密码是加密的 我们需要对其进行解密
data:image/s3,"s3://crabby-images/90f2d/90f2d6910d6d61571a5702c3329eb41d4f5804ee" alt="内网常用工具密码获取1"
SecureCRT 离线解密工具:
https://github.com/HyperSine/how-does-SecureCRT-encrypt-passwordpython SecureCRTCipher.py dec -v2 <密码>
data:image/s3,"s3://crabby-images/fcf34/fcf34b5c91a3d73e1c98f73a1c895a57d38f5a05" alt="内网常用工具密码获取1"
MobaXterm
MobaXterm是一款远程终端控制软件,集串口,SSH远程登录和FTP传输三合一的工具,便携版操作简单,使用非常方便。
data:image/s3,"s3://crabby-images/f8c58/f8c58ce3e41b304c10024f254e1b0ac5281b0fdf" alt="内网常用工具密码获取1"
连接过后会在当前目录生成一个.ini文件
data:image/s3,"s3://crabby-images/a5f23/a5f23dc0639166ff99a820131fc022f6b99d5fb7" alt="内网常用工具密码获取1"
其中就储存着我们登录的账户密码
data:image/s3,"s3://crabby-images/df0fc/df0fc359fc54170429e3ec1c76f2eddd5f0f8722" alt="内网常用工具密码获取1"
离线工具:https://github.com/HyperSine/how-does-MobaXterm-encrypt-passwordpython MobaXtermCipher.py dec -sp <ini文件中的SessionP> <加密的Passwords>
data:image/s3,"s3://crabby-images/75336/7533690014e75c149d41b1072b23ba897b2b0643" alt="内网常用工具密码获取1"
finalshell
FinalShell是一体化的的服务器,网络管理软件,不仅是ssh客户端,还是功能强大的开发,运维工具,充分满足开发,运维需求
data:image/s3,"s3://crabby-images/b69b3/b69b3a3e484d626448bd18eb89d318165ecb8da9" alt="内网常用工具密码获取1"
连接信息存储在C:\Users\oneseven\AppData\Local\finalshell\conn\ 目录下 有多少条连接就会有多少个xxx_connect_config.json文件
data:image/s3,"s3://crabby-images/aeabe/aeabe3f38cd24ed84ed5ef9162db50c689621cd9" alt="内网常用工具密码获取1"
data:image/s3,"s3://crabby-images/b502e/b502e16dbd620974823eee2ad98115b9037e1d11" alt="内网常用工具密码获取1"
用户登录时必须勾选记住密码,否则不会在xxx_connect_config.json文件中保存密码
data:image/s3,"s3://crabby-images/1f71c/1f71c7f797d3ff835cc5d2b89548580410b0c772" alt="内网常用工具密码获取1"
离线解密:别人已经写好了的java代码
FinalShellDecodePass.java
import java.io.ByteArrayOutputStream;
import java.io.DataOutputStream;
import java.io.IOException;
import java.math.BigInteger;
import java.security.MessageDigest;
import java.security.NoSuchAlgorithmException;
import java.security.SecureRandom;
import java.util.Base64;
import java.util.Random;
import javax.crypto.Cipher;
import javax.crypto.SecretKey;
import javax.crypto.SecretKeyFactory;
import javax.crypto.spec.DESKeySpec;
public class FinalShellDecodePass {
public static void main(String[] args)throws Exception {
System.out.println(decodePass(args[0]));
}
public static byte[] desDecode(byte[] data, byte[] head) throws Exception {
SecureRandom sr = new SecureRandom();
DESKeySpec dks = new DESKeySpec(head);
SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DES");
SecretKey securekey = keyFactory.generateSecret(dks);
Cipher cipher = Cipher.getInstance("DES");
cipher.init(2, securekey, sr);
return cipher.doFinal(data);
}
public static String decodePass(String data) throws Exception {
if (data == null) {
return null;
} else {
String rs = "";
byte[] buf = Base64.getDecoder().decode(data);
byte[] head = new byte[8];
System.arraycopy(buf, 0, head, 0, head.length);
byte[] d = new byte[buf.length - head.length];
System.arraycopy(buf, head.length, d, 0, d.length);
byte[] bt = desDecode(d, ranDomKey(head));
rs = new String(bt);
return rs;
}
}
static byte[] ranDomKey(byte[] head) {
long ks = 3680984568597093857L / (long)(new Random((long)head[5])).nextInt(127);
Random random = new Random(ks);
int t = head[0];
for(int i = 0; i < t; ++i) {
random.nextLong();
}
long n = random.nextLong();
Random r2 = new Random(n);
long[] ld = new long[]{
(long)head[4], r2.nextLong(), (long)head[7], (long)head[3], r2.nextLong(), (long)head[1], random.nextLong(), (long)head[2]};
ByteArrayOutputStream bos = new ByteArrayOutputStream();
DataOutputStream dos = new DataOutputStream(bos);
long[] var15 = ld;
int var14 = ld.length;
for(int var13 = 0; var13 < var14; ++var13) {
long l = var15[var13];
try {
dos.writeLong(l);
} catch (IOException var18) {
var18.printStackTrace();
}
}
try {
dos.close();
} catch (IOException var17) {
var17.printStackTrace();
}
byte[] keyData = bos.toByteArray();
keyData = md5(keyData);
return keyData;
}
public static byte[] md5(byte[] data) {
String ret = null;
byte[] res=null;
try {
MessageDigest m;
m = MessageDigest.getInstance("MD5");
m.update(data, 0, data.length);
res=m.digest();
ret = new BigInteger(1, res).toString(16);
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return res;
}
}
先进行编译javac FinalShellDecodePass.java,在运行java FinalShellDecodePass <password>
其中password就是xxx_connect_config.json文件中的password字段类容
data:image/s3,"s3://crabby-images/0fce4/0fce4d214db647f63f86579faba05fec631c0721" alt="内网常用工具密码获取1"
Winscp
一个 Windows 环境下使用的 SSH 的开源图形化 SFTP 客户端
data:image/s3,"s3://crabby-images/f995e/f995e043acfc7c565c6508af25a336b1b3650822" alt="内网常用工具密码获取1"
解密:
密码是保存在注册表中reg query "HKEY_CURRENT_USER\Software\Martin Prikryl\WinSCP 2\Sessions”
data:image/s3,"s3://crabby-images/4b648/4b6484a4fefb02f2a635dee0d16d6255a731dd89" alt="内网常用工具密码获取1"
可以看到链接名称,但需要建站点时保存密码
data:image/s3,"s3://crabby-images/fe704/fe704bf0472160ebd26ad77713efa86bd53775b3" alt="内网常用工具密码获取1"
离线工具https://github.com/anoopengineer/winscppasswdwinscppasswd.exe <主机> <用户名> <加密密码>
data:image/s3,"s3://crabby-images/d34d4/d34d45889dda221a72dfb5ca92f067c1d2c43eec" alt="内网常用工具密码获取1"
使用在线工具SharpDecryptPwd可直接获取密码
data:image/s3,"s3://crabby-images/c7074/c707462ca77d142c350320eeb519a99fa2367604" alt="内网常用工具密码获取1"
FileZilla
一款FTP操作类的软件
data:image/s3,"s3://crabby-images/94817/94817f5533a94232e34e3774ad39e7819b15d61f" alt="内网常用工具密码获取1"
首先导出记录
data:image/s3,"s3://crabby-images/d0f8b/d0f8b7051c1dda0e83452297f3a7dbe1c54ee8e0" alt="内网常用工具密码获取1"
导出后是一个xml文件 打开后base64就是密码 直接解密就行
data:image/s3,"s3://crabby-images/849f8/849f8d941341317e3ead283877e6b97e46382a8f" alt="内网常用工具密码获取1"
使用在线工具SharpDecryptPwd