postgresql客户端命令之口令文件

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了postgresql客户端命令之口令文件相关的知识,希望对你有一定的参考价值。

postgresql客户端命令之口令文件:

在给出其它PostgreSQL客户端命令之前,我们需要先介绍一下PostgreSQL中的口令文件。之所以在这里提前说明该文件,是因为我们在后面的示例代码中会大量应用该文件,从而保证我们的脚本能够自动化完成。换句话说,如果在客户端命令执行时没有提供该文件,PostgreSQL的所有客户端命令均会被口令输入提示中断。

    在当前用户的HOME目录下,我们需要手工创建文件名为 .pgpass的口令文件,这样就可以在我们连接PostgreSQL服务器时,客户端命令自动读取该文件已获得登录时所需要的口令信息。该文件的格式如下:

    hostname:port:database:username:password

    以上数据是用冒号作为分隔符,总共分为五个字段,分别表示服务器主机名(IP)、服务器监听的端口号、登录访问的数据库名、登录用户名和密码,其中前四个字段都可以使用星号(*)来表示匹配任意值。见如下示例:

    /> cat > .pgpass

    *:5432:postgres:postgres:123456

    CTRL+D

    #.pgpass文件的权限必须为0600,从而防止任何全局或者同组的用户访问,否则这个文件将被忽略。

    /> chmod 0600 .pgpass

    在学习后面的客户端命令之前,我们需要根据自己的应用环境手工创建该文件,以便后面所有的示例代码都会用到该口令文件,这样它们就都可以以批处理的方式自动完成。

[[email protected] ~]$ cat .pgpass 

127.0.0.1:3685:testdb2:testwjw:123456

[[email protected] ~]$ chmod 0600 .pgpass

[[email protected] ~]$ egrep "testdb2|testwjw" /data/postgresql/data/pg_hba.conf 

host    testdb2         testwjw         127.0.0.1/32                md5


[[email protected] ~]$ pg_ctl reload -D /data/postgresql/data -l /data/postgresql/log/postgres.log

server signaled


[[email protected] ~]$ psql -Utestwjw -d testdb2 -h 127.0.0.1 -p 3685 (这样登陆是不需要密码的)

psql.bin (9.5.9)

Type "help" for help.


testdb2=>


一旦注释掉.pgpass  这个文件的内容

[[email protected] ~]$ cat .pgpass 

##127.0.0.1:3685:testdb2:testwjw:123456

[[email protected] ~]$ pg_ctl reload -D /data/postgresql/data -l /data/postgresql/log/postgres.log

server signaled


[[email protected] ~]$ psql -Utestwjw -d testdb2 -h 127.0.0.1 -p 36985

Password for user testwjw:       ####此处提示要输入密码123456

psql.bin (9.5.9)

Type "help" for help.

testdb2=>

本文出自 “10931853” 博客,请务必保留此出处http://wujianwei.blog.51cto.com/10931853/1970731

以上是关于postgresql客户端命令之口令文件的主要内容,如果未能解决你的问题,请参考以下文章

Python与Hack之Zip文件口令破解

Veeam Backup & Replication 之 数据加密

ssh免口令密码登录及兼容性处理

SSH 之远程登录

MsSQLServer是如何加密口令的

计算机网络之应用层_part -3