1. Context值和bool开关的相关内容

Context值分为2种

系统默认的context值

服务的context值

Context值的作用

主要是防止有未知文件进入目录文件之中(如将病毒拷贝到目录文件下)

 

Bool开关的作用

Bool主要是争对在selinux处于enforcing(强制状态)时,拥有访问端口的口令也是无法登陆的情况时起作用的。

 

然后就是context值和bool开关的相关命令

Chcon –t 更改

Restorecon –v 恢复

Getroubleshoot –a 查看所有的bool开关

 

  1. 配context值

首先查看root的家目录下的文件,比较下面两个图,发现第一个图中的时间变为了第二个,这里我们就看变化中的admin_home_t,也就是context值

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHPContext值和bool开关-LMLPHPContext值和bool开关-LMLPHP

接下来就以文件install.log为例,将文件install.log复制到/tmp下,再次看看context值,发现context值变为了user_tmp_t了,

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

 

接下来就开始演示context值的作用了

首先就以ftp共享文件来测试,安装ftp服务后,就可以在/var下面自动生成ftp/pub这两节目录,然后就可以在目录pub下创建共享文件了,这里创建了一个文件test和复制了一个文件install.log,发现文件test的context值为public_content_t,而文件instal.log的context值也变为了public_content_t

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

接下来通过远程用户以ftp服务登录到主机上,查看pub下的文件,可以查看这两个共享文件

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

然后修改文件install.log的context值为tmp_t,

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

 

然后再次远程登录到主机,查看pub下的文件,发现看不到文件instll.log了,到这就隐隐的明白了什么,那就是是否继承了上一级目录context值的原因

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

 

于是为了验证自己隐约的想法,就来查看pub的context值吧,结果发现确实如推测的那样,pub的context值也是public_content_t,由此可知,刚才将文件install.log的context值认为的改变为tmp_t后,就无法读取了,这个文件确实还是存在的,只不过pub已经不会识别了,因为它的context已经被改变了。

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

 

为了更加确定推测,将文件install.log的context值恢复,再看看

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

 

 

 

 

 

 

 

 

更改后,再次查看,发现文件install.log又出现了,那么现在可以完全的明白了context值的作用了,可以对context值作用进行一个小结了

由于目录pub的context值为public_content_t,所以在pub下的文件的context值也应该为public_content_t,如果人为的将context值改变了,那么pub就不会认这个在它目录下的文件了,即使没有被删,我们也不会看到了

 

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

 

然后在http下再测试一下,安装了http服务后就可以在/var下面生成两节目录www/html了,然后在目录html下创建文件名为index.html文件,在这个文件里写的内容,我们就可以通过浏览器来看到了,这个是对http网页文件的解释,这里还是回到context值吧,我们来看看文件index.html的context值,发现context值是httpd_sys_cotent_t,

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

 

然后用浏览器查看一下,就可以看到内容了

Context值和bool开关-LMLPHP

 

接下来就更改一下文件index.html的context值吧,将其更改为tmp_t

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

 

 

 

 

 

 

 

发现在浏览器里已经看不到网页文件的内容了,原因应该是刚才的那个文件没有被读取到,被目录html忽略了,所以在浏览器中自然看不到了

Context值和bool开关-LMLPHP

 

然后将文件index.html的context值恢复为httpd_sys_content_t

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

 

那么就可以在浏览器中看到hello了

Context值和bool开关-LMLPHP

 

接下来我们将ftp安装后所产生的两节目录ftp/pub删掉,

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

 

然后远程登录ftp后,发现访问失败,这是肯定了,毕竟共享文件已经被删了

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

 

 

 

然后就创建文件ftp/pub这两节目录

Context值和bool开关-LMLPHP

 

然后远程登录,发现登录上了,可是却看不到共享目录pub

Context值和bool开关-LMLPHP

 

这时候我想到的是context值,于是,查看一下pub的context值,发现变为了var_t,看来是继承了/var目录的context值,可是/var是系统默认的context值,与ftp服务的context值是不同的,所以新建的文件仅仅是名字一样罢了,可是却不具备服务的context值,那么就没有意义,因此是没有用的

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

这时候可以用命令restorecon –Rv ftp 将context值恢复

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHPContext值和bool开关-LMLPHP

恢复context值后就可以看到共享文件了

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

下面就是文件继承上一级的事例

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

实验到这里就得说明一下了

Context值分为两种

  1. 系统默认的context值
  2. 服务的context值

也就是说,除了由于服务的原因,比如/var下面,由于安装了ftp服务后,会在/var下面创建ftp这个目录文件,可是查看context值却发现并没有继承/var的context值,却可以在/var下面看到,这个现象可不是为了推翻context值的作用,而是为了说明继承分为两种,一种是以系统默认的context值为基,在此下面创建的目录或文件就继承了其context值,而有一种情况是不受其约束的,那就是安装服务的时侯所自动产生的目录或文件,它们拥有着属于自己的context值,可以当作例外来看,那么一切就可以解释的通了。

 

其实想要context值恢复还有一个方法,

首先需要安装一个软件包,policycoreutils-gui,然后就敲命令system-config-selinux,

Context值和bool开关-LMLPHP

 

就进入了如下的图形化界面,将下次启动时重新标记勾上,然后重启系统,那么再开启系统时,所以被更改的context值就会被重新标记,即context都会恢复为原始值

 

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

 

 

下面显示的是启动系统后重打标记的过程,*代表的就是在重打标记

Context值和bool开关-LMLPHP

 

系统开启后,再次查看pub的context值,发现确实已经恢复了

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

 

做到这,我们是否会想到既然一个勾就将更改的context值改了,那么是否可以让context永久是更改后的值呢,即使重打标记也不变,

其实是有的,可以用命令semanage fconftext –a –t httpd_sys_content_t 'pub(/.*)就可以了

 

 

 

 

 

接下来就开始第二个实验了

做bool开关

首先讲讲bool开关的作用,bool开关的作用就是在selinux变为enforcing状态时,将bool开启后就可以继续访问,在这就先简单的解释一下selinux的三种状态吧

首先disabled态,也就是禁用了selinux的功能

然后就是permissive状态,主要用于判断系统是服务本身的问题还是selinux问题,举个例子吧,当远程访问用户时,如果在知道了远程主机的账户的账号和密码时,验证成功后就可以访问了。

最后就是enforcing状态了,表示的是强制的意思,依旧接着上面的例子,也就是说即使知道了对方账户的账号和密码,验证成功也不能访问,即强制的不允许其登录,这个安全性更高。

 

那么这么一来就有一个问题了,没错当将selinux设置为enforing状态后安全性确实更高了,可是如果不能访问的话,这种安全就没有意义了,那么有什么方法可以让其处于enforcing状态依旧可以访问呢?

这时就需要bool开关了

接下来就开始演示bool开关的作用了

在这儿,首先需要安装setroubleshoot这个安装包,当然selinux也应该设置为enforcing状态,为了使这两个更改生效,就需要重启系统了,重启系统后,就可以查看了,如下两个图,发现selinux确实已经处于enforcing状态了,而在系统工具里看到了selinux故障排除工具,就说明setroubleshoot安装成功了

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

 

Context值和bool开关-LMLPHPContext值和bool开关-LMLPHP

 

 

 

 

然后就可以开始更改bool值了

 

首先我们远程登录主机的普通账户发现登上了,却无法查看用户文件,报了登录失败的错误,这其实是selinux的enforcing起了作用

Context值和bool开关-LMLPHP

然后就查看bool开关的信息,这里可以进行指定搜索,我们访问的是ftp上用户的home下的文件,那么就可以进行如下搜寻,发现其off了,也就是bool处于关闭状态

Context值和bool开关-LMLPHP

那么就需要将其开启,于是就可以敲如下命令,这里的1表示的就是开启,而0代表的就是关闭了

Context值和bool开关-LMLPHP

然后再次访问,就可以看到账户的home下的文件了

Context值和bool开关-LMLPHP

 

 

至此,关于context值和bool开关的实验就结束了!!!

05-06 08:56