如何用自己的代码来更改linux的登录密码

本文展示了如何在C语言中使用crypt库对密码进行加密,并通过系统调用将加密后的密码插入到Linux的/etc/shadow文件中,附带了一个简单的Makefile用于编译。

二话不说,直接看代码吧!

#include <stdio.h>

#include <unistd.h>

#include <crypt.h>



int main(int argc, char *argv[]) 

{

	char password[10] ="nE7n$8q%5m";

	char salt[] = "$1$Co1BNCRZ";

	char buffer[100]={0};

	if( argc == 2 ) 	sprintf(password,"%s",argv[1]);



	printf("password:%s\n",password);



	char* encryptedPassword = crypt(password, salt);



	printf("Encrypted Password: %s\n" , encryptedPassword);

	sprintf(buffer,"root:%s:19807:0:99999:7:1::",encryptedPassword);

	printf("Encrypted Password: %s\n" , buffer);



	char cmd[100]={0};

	sprintf(cmd,"sed -i '1s/.*/%s/' /etc/shadow",buffer);



	printf("command: %s\n" , cmd);

	system(cmd);

	return 0;

}

编译的makefile:

all:
	$(CC) -o crypt crypt.c -lcrypt -ggdb

clean:
	rm crypt

Linux 系统中登录 PostgreSQL shell 并更改用户密码的过程可以通过以下方式实现。以下是具体的操作流程及相关注意事项: ### 修改 PostgreSQL 数据库用户的密码 #### 方法一:通过调整认证模式临时允许无密码访问 1. **打开配置文件** 进入 PostgreSQL 的安装目录,找到 `postgresql.conf` 和 `pg_hba.conf` 文件。编辑 `pg_hba.conf` 文件,将本地连接的认证方式从 `md5` 改为 `trust`,如下所示: ```plaintext local all postgres trust ``` 2. **重启服务** 保存修改后的 `pg_hba.conf` 文件,并重启 PostgreSQL 服务以使更改生效。 ```bash sudo systemctl restart postgresql ``` 3. **切换到 PostgreSQL 用户并进入 shell** 切换到 `postgres` 系统用户(默认情况下,PostgreSQL 安装时会创建此用户),然后启动 PostgreSQL 命令行工具 `psql`。 ```bash sudo su - postgres psql ``` 4. **重置目标用户的密码** 在 PostgreSQL shell 中运行以下 SQL 命令来更改指定用户的密码: ```sql ALTER USER username WITH PASSWORD 'new_password'; ``` 将 `username` 替换为目标用户名,`new_password` 替换为新密码。 5. **恢复原始认证模式** 编辑 `pg_hba.conf` 文件,将之前改为 `trust` 的部分还原为 `md5` 或其他安全认证方式: ```plaintext local all postgres md5 ``` 再次重启 PostgreSQL 服务以应用更改。 #### 方法二:直接提供密码登录后修改 如果知道现有用户的密码,可以直接使用带 `-U` 参数的方式登录 PostgreSQL shell,无需修改认证模式。 ```bash psql -U postgres -d your_database_name ``` 输入正确的密码后即可进入交互式 shell,在其中执行 `ALTER USER` 命令完成密码变更操作[^1]。 #### 注意事项 - 如果尝试直接登录却收到类似 “FATAL: password authentication failed for user ‘postgres’” 的错误消息,则表明当前使用的密码不正确或存在权限问题[^2]。 - 不建议长期保持 `trust` 认证模式,因为它降低了系统的安全性。仅应在必要时短暂启用用于紧急维护工作完成后立即恢复更严格的设置。 --- ### 示例代码展示 假设要改变名为 `test_user` 的账户密码为 `securepassword123!`,整个过程可以用下面几条指令概括表示: ```bash # 步骤A - 修改 pg_hba.conf 后重启服务省略... sudo su - postgres psql ALTER USER test_user WITH PASSWORD 'securepassword123!'; \q exit # 步骤B - 恢复 pg_hba.conf 设置后再重启服务省略... ``` ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值