我以超级用户身份登录我的数据库postgres
。
postgres=# SELECT * FROM pg_user;
+----------+----------+-------------+----------+---------+--------------+----------+----------+-----------+
| usename | usesysid | usecreatedb | usesuper | userepl | usebypassrls | passwd | valuntil | useconfig |
+----------+----------+-------------+----------+---------+--------------+----------+----------+-----------+
| postgres | 10 | t | t | t | t | ******** | (null;) | (null;) |
| test | 24763 | f | f | f | f | ******** | (null;) | (null;) |
+----------+----------+-------------+----------+---------+--------------+----------+----------+-----------+
(2 rows)
我已经列出了数据库中的所有用户。如何获取普通用户的密码test
?
密码根据文档加密:
因此,您将无法获得普通用户的原始密码。系统中存储的是原始密码的加密(例如MD5)。如果您已经知道密码,则其加密值将匹配。但是您无法获取生成加密值的密码。这就是加密密码的重点。
作为管理员,您可以更改用户的密码,但无法从加密版本中获取密码。
- 更新 -
要获取用户密码的加密值
test
,您可以执行以下操作:例如:
生成:
资源