网络安全快速入门(十五)(下)手动创建用户及su,sudo命令

15.8 序言

前面我们已经大概了解了创建用户一些相关文件,接下来我们来手动创建用户,话不多说,我们直接开搞!!!

15.9 手动创建用户:

一般来讲,我们创建用户通过useradd和passwd命令来创建,还有一种方法,纯手动创建用户,这里我们来详细了解一下:

15.9.1 手动创建用户完成的操作

大概需要完成的操作如下:

  1. /etc/passwd添加一行
  2. /etc/shadow添加一行
  3. /etc/group添加一行
  4. 创建用户家目录
  5. 创建用户邮件文件

我们通过例子来对手动创建用户进行详细讲解:

例子:

手动创建一个和用户,用户名为ch230,用户uid为2260,gid为2260,组名称与用户名称同名,家目录在/home/ch230,描述为ch226,密码为123456,最少试用三天才能修改,最长使用三十天,到期前五天发送修改密码提示。

15.9.2 具体操作:

1.创建用户基本信息,

我们需要在/etc/passwd下添加一行,具体操作如下:

vi /etc/passwd
在passwd下插入下面行
ch230:x:2260:2260:ch226:/home/ch230:/bin/bash

操作完成后如下图

2.检查用户

我们来通过id命令确认一下有无该用户。

id ch230

看结果:

可以发现用户已存在,说明passwd文件已经生效,接下来我们继续下一步,

3.创建用户密码

在/etc/shadow添加一行,具体操作如下:

首先来创建加密密码,利用下述命令来进行创建:

openssl passwd -1 -salt "随机数字"
之后敲回车输入密码
123456
3.5 使用openssl来生成密码
选项说明:
  • -1 :表示md5加密算法
  • -salt:表示加密的时候插入杂质(提高安全性)、

我们看操作及反馈

我们现在复制上图最后一行字符,并且在/etc/shadow下添加一行,添加如下

ch230:$1$498498$1vCOkczp/mzNhtFj4OU8J1:19879:3:30:5:::

注意:(因为该文件不可读写执行,因此我们需要在末行模式用wq!才可退出此文件!!)
在这一步完成后,我们就可以去登录用户了,登陆后状态如下:

这是因为我们没有做用户家目录,所以导致会出现以下情况,我们将会在配置用户组之后解决这个问题!

4.创建组

接下来我们来配置用户组,与passwd和shadow文件一样,我们同样需要在下面添加一行,添加内容如下

ch230:x:2260:

ok,组就搞完了,接下来我们来做用户家目录

5. 创建用户家目录

我们已经知道,用户家目录模板位于/etc/skel中,接下来我们就需要移动该目录及目录里的文件并修改文件名,及文件的属主属组,

具体操作如下

cp -r /etc/skel /home/ch230
cd /home
chown -R ch230.ch230 ch230/

我们来看一下修改后的权限

我们重新登陆看一下是不是还是刚才一样吗,没有配置环境变量:


ok,这里已经创建完毕了,接下来我们来进行最后一步!

6.创建用户邮件

这里我们只需要在/var/spool/mail下创建用户同名目录即可,具体步骤如下:

cd /var/spool/mail/
touch ch230
chmod 660 ch230
chown ch230.ch230 ch230

我们来看结果:

最后我们登录查看用户状态:

ok,手动创建用户到这里就算完成!!

补充:

        我们在删除用户的时候他不会删除用户的家目录及文件目录,因此我们需要手动删除用户家目录及文件目录才能保证下次创建用户家目录及邮件目录才能不会出错!!!

15.10 su命令及sudo命令

su命令及sudo命令,本质上都是让用户利用root身份去执行命令,从而解决普通用户权限太小,无法去执行命令的问题,接下来我们来一个一个了解

15.10.1 su命令

su命令,简单来说就是切换用户,切换成管理员用户自然就拥有root的身份,使用root的命令也是理所当然的,su命令优缺点如下

优点

  • 使用简单

缺点:

  • root密码容易泄露
  • 普通用户执行操作不可控

格式:

su 用户名

这里我们需要注意的是:我们通过su命令可以进行任何可登录用户的切换,(只要你知道该用户密码),具体操作如下

我们现在是root身份,现在我们切换用户至ch230,格式如下:

su ch230

看结果:

我们已经切换用户为ch230了,因为root用户切换其他用户的时候不需要密码,所以可以直接切换,但普通用户切换root用户和其他用户需要输入密码才可以登录!!

我们直接下一个例子:

ch230切换为root用户

su root

如下图

我们看到,这里需要密码才可进行登录,否则无法登录该用户!!!

输入密码后登陆成功,该指令完成!!

补充:

如果需要退出当前用户的话,输入exit即可退出!!

su命令就先到这里,接下来我们来看sudo命令

15.10.2 sudo命令:

上面我们发现,su命令必须知道密码才可进行操作,这就有很大的安全隐患,而且root密码极容易泄露,因此,为了防止这类事件的发生,我们使用sudo命令来让普通用户使用root的命令。sudo命令与su命令的相同点是,都是通过root身份来执行命令,但也有不同点,具体如下:

作用:给普通用户授权,让普通用户执行特定的操作
优点:
  • 不要切换到root用户(不用知道root密码)
  • 用户可执行预定的操作
  • 可以记录每个用户执行过的命令

缺点:

  • 需要进行权限配置

sudo使用跟一般命令使用也不太相同,具体使用方法如下:

第一步:通过 sudo 配置文件为普通用户授权
第二步:普通用户通过sudo命令执行特殊操作
我们一步一步来看,首先我们需要通过sudo文件对用户进行授权,我们要了解sudo配置文件存放的位置:
/etc/sudoers
注意:这里我们不能直接修改配置文件,我们需要下列命令来修改配置文件
visudo

我们进入后跳转至101行,内容如下:

100行具体表示含义如下:

root   ALL = (ALL)   ALL
用户名 主机=(用户名) 全部命令

如果我们在下面添加一行的话,需要修改所有用户名和全部命令即可,例子如下:

授权ch230能够执行root的全部命令

ch230 localhost=(root ALL
如下图:
ok,现在我们来尝试一下是否成功
利用ch230来执行root权限,查看/etc/shadow文件
第一步:sudo命令
格式如下
sudo 命令

具体操作如下:

sudo cat /etc/shadow

看结果

出现一下字符,说明sudo成功,我们输入ch230密码:123456

输入之后看结果

ok,现在我们成功查看/etc/shadow文件,说明该命令执行成功!!

好了,本大章节内容就到这里了,感谢各位大佬的观看,如果失误,还请各位大佬多多指正!再次感谢各位观看,我们下其内容再见!@.@

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/24591.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python数据分析-心脏衰竭分析与预测

研究背景 人的心脏有四个瓣膜,主动脉银、二尖、肺动脉和三尖源 不管是那一个膜发生了病变,都会导致心脏内的血流受到影响,这就是通常所说的心脏期膜病,很多是需要通过手术的方式进行改善的。随着人口老龄化的加剧,,心…

Java基础_异常

Java基础_异常 异常体系介绍编译时异常和运行时异常异常的作用异常的处理方式JVM默认的处理方式自己处理(捕获异常)try...catch灵魂四问Throwable的成员方法 抛出处理 综合练习自定义异常来源Gitee地址 异常体系介绍 异常是什么? 程序中可能出…

【Java】String类 -- 重要概念!!!

// 源码 public final class Stringimplements java.io.Serializable, Comparable<String>, CharSequence {/** The value is used for character storage. */private final char value[];/** Cache the hash code for the string */private int hash; // Default to 0 /…

RTOS笔记--信号量+互斥量+事件组

信号量的本质 信号量是一个特殊的队列&#xff0c;但并不涉及数据传输&#xff0c;因此不需要读写位置和发送者列表&#xff0c;但是多了一个最大计数值。 个人理解&#xff1a;信号量类似一个加入了保护机制的全局变量&#xff0c;不会因为中断切换的原因而导致数据出错。 信号…

Steam游戏如何选择适合的服务器

在Steam平台上&#xff0c;玩家可以享受到来自世界各地开发者的游戏作品。然而&#xff0c;要获得最佳的游戏体验&#xff0c;选择合适的服务器至关重要。本文将从网络延迟、服务器位置、游戏类型和个人偏好等多个方面&#xff0c;为玩家提供选择Steam游戏服务器的实用指南。 如…

k8s挂载配置文件(通过ConfigMap方式)

一、ConfigMap简介 K8s中的ConfigMap是一种用于存储配置数据的API对象&#xff0c;属于Kubernetes中的核心对象。它用于将应用程序的配置信息与容器镜像分离&#xff0c;以便在不重新构建镜像的情况下进行配置的修改和更新。ConfigMap可以存储键值对、文本文件或者以特定格式组…

PDF编辑与修正 提高工作效率 Enfocus PitStop Pro 2022 中文

Enfocus PitStop Pro 2022是一款专为Mac用户设计的强大PDF编辑和校对工具。它支持添加、删除、合并、分割PDF页面&#xff0c;以及文本和图像的编辑&#xff0c;如文字替换、字体更改、颜色调整等。内置自动修复功能&#xff0c;能快速检测并修复缺失字体、重叠文本等常见问题。…

【Text2SQL 论文】PET-SQL:用 Cross-Consistency 的 prompt 增强的两阶段 Text2SQL 框架

论文&#xff1a;PET-SQL: A Prompt-enhanced Two-stage Text-to-SQL Framework with Cross-consistency ⭐⭐⭐ arXiv:2403.09732&#xff0c;商汤 & 北大 Code&#xff1a;GitHub 一、论文速读 论文一开始提出了以往 prompt-based 的 Text2SQL 方法的一些缺点&#xff1…

使用缓存降低数据库并发读写方案探索

文章目录 前言缓存设计思想缓存划分缓存应用时机 客户端缓存浏览器缓存网关或代理服务器缓存CDNPCDN 服务端缓存本地缓存本地缓存实现Java堆缓存memcached/ecachecaffeineORM框架一级/二级缓存 分布式缓存分布式缓存优缺点分布式缓存实现分布式缓存实施过程可能遇到问题分布式缓…

Socket编程权威指南(二)完美掌握TCP流式协议及Socket编程的recv()和send()

在上一篇文章中&#xff0c;我们学习了Socket编程的基础知识&#xff0c;包括创建Socket、绑定地址、监听连接、接收连接等操作。然而&#xff0c;真正的套接字编程远不止于此。本文将重点介绍TCP 流式协议&#xff0c;什么是粘包问题&#xff1f;如何解决粘包问题 &#xff1f…

利用R包“Phenotype”对表型值进行检查

首先&#xff0c;你需要确保你已经安装了R和RStudio&#xff08;如果你想用RStudio的话&#xff09;。然后&#xff0c;你可以按照以下步骤进行操作&#xff1a; 加载数据&#xff1a;首先&#xff0c;你需要加载你的表型数据。如果你的数据是以CSV、Excel等格式保存的&#x…

地面站Mission planner

官方教程; Mission Planner地面站介绍 | Autopilot (gitbook.io) Mission Planner 功能/屏幕 — Mission Planner 文档 (ardupilot.org) 安卓或者windows软件下载地址&#xff1a; 地面站连接及使用 plane (cuav.net) 在完全装机后再进行各干器件的校准&#xff0c;没有组…

【LeetCode 前缀和 + 哈希表】LC_560_和为K的子数组

文章目录 1. 和为K的子数组&#x1f197; 1. 和为K的子数组&#x1f197; 题目链接&#x1f517; &#x1f427;解题思路&#xff1a; 前缀和 哈希表 &#x1f34e; 设i为数组中的任意位置&#xff0c;⽤ sum[i] 表⽰ [0, i] 区间内所有元素的和。 &#x1f34e; 想知道有…

【设计模式深度剖析】【5】【行为型】【迭代器模式】

&#x1f448;️上一篇:策略模式 设计模式-专栏&#x1f448;️ 文章目录 迭代器模式定义英文原话直译如何理解呢&#xff1f; 迭代器模式的角色1. Iterator&#xff08;迭代器&#xff09;2. ConcreteIterator&#xff08;具体迭代器&#xff09;3. Aggregate&#xff08;聚…

用 DataGridView 控件显示数据

使用DataGridView&#xff0c;可以很方便显示数据。 &#xff08;1&#xff09;Visual Studio版本&#xff1a;Visual Studio 2022 &#xff08;2&#xff09;应用程序类型&#xff1a;windows form &#xff08;3&#xff09;编程语言&#xff1a;C# 一、目标框架 .NET Fra…

K-BAT01,K-CU01和利时卡件

K-BAT01,K-CU01和利时卡件。现场控制站下装与在线调试。9二、组态流程&#xff1a;操作站组态控制站组态新建工程控制站用户组态历史站组态下装现场控制站下装历史站下装操作员站10三、组态详解&#xff1a;1、K-BAT01,K-CU01和利时卡件。新建工程&#xff1a;打开工程总控&…

【Unity】Kafka、Mqtt、Wesocket通信

1 前言 最近研究了下kafka、mqtt、webocket插件在Unity网络通信中的应用&#xff0c;做下小总结吧。&#xff08;不想写笔记&#xff0c;但不写又会忘&#xff0c;痛苦&#xff09; 2 Kafka 先说结果&#xff1a;Kafka实现失败。 我会使用的方法是在VS里安装了Confluent.Kafka…

项目3:从0开始的RPC框架(扩展版)

一. 全局配置加载 1. 需求分析 通常情况下&#xff0c;在RPC框架运行的会涉及到多种配置信息&#xff0c;比如注册中心的地址、序列化方式、网络服务端接口号等。 在简易版框架中&#xff0c;硬编码了这些配置&#xff0c;也就是都写死了&#xff0c;在真实的应用环境中是不…

【启程Golang之旅】让文件操作变得简单

欢迎来到Golang的世界&#xff01;在当今快节奏的软件开发领域&#xff0c;选择一种高效、简洁的编程语言至关重要。而在这方面&#xff0c;Golang&#xff08;又称Go&#xff09;无疑是一个备受瞩目的选择。在本文中&#xff0c;带领您探索Golang的世界&#xff0c;一步步地了…

MySQL 与 PostgreSQL 关键对比二(SQL语法)

目录 1 详细示例 1.1自动增量列 1.2 字符串连接 1.3 JSON 支持 2 总结 MySQL 和 PostgreSQL 是两种流行的开源关系数据库管理系统&#xff08;RDBMS&#xff09;。尽管它们在许多方面相似&#xff0c;但在 SQL 语法和功能上存在一些显著差异。 以下SQL语句的执行如果需要开…