SELinux限制导致VSFTP匿名用户不能上传文件问题解决方法

本文主要是介绍SELinux限制导致VSFTP匿名用户不能上传文件问题解决方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

确保其它配置正确,还不能上传,就是SELinux的限制;

解决步骤:

getsebool -a | grep ftp                 //列出ftp的相关规则布尔值开启状态
setsebool -P allow_ftpd_anon_write on        //允许匿名用户写入
ll -Z /var/ftp/                         //查看ftp文件夹的具体属性,包括安全上下文
chcon -t public_content_rw_t /var/ftp/目录         //设置的FTP目录可以上传文件



 查询布尔值是否开启:getsebool

getsebool [-a] [布尔条款值]

-a:列出系统上所有布尔条款值设置为开启或关闭值;

 

设置布尔值开启或关闭:setsebool

setsebool [-P]布尔值=[0|1]

-p:直接将设置值写入配置文件,该设置数据将来会生效;

 

 

安全上下文(security context)简单来讲,就认为其实是SELinux内必备的rwx就是了;

主体不能访问目标除了策略指定外,主体目标安全上下文必须一致才能够顺利访问;这个安全上下文类似文件系统的rwx

主体程序必须通过SELinux策略内的规则放行后,才可以与目标资源进行安全上下文比较,比较失败则无法访问资源,成功则开始访问目标;

主体(进程) -->SELinux(分析策略规则) -->安全上下文--

 (no)-->AVC拒绝访问的信息说明;

 (yes)-->目标(object)数据访问;(最终能否访问,还要参考rwx的权限设置)

安全上下文主要分为三个字段:(可以通过ls -Z 查看)

Identifyroletype

身份标识:

root:代表root账号身份;

system_u:系统程序方面的标识;

user_u:一般用户账号相关的身份;

角色:

Object_r:代表文件 目录 等文件资源;

System_r:代表进程 一般用户;

类型:

Type(类型字段)最为重要,基本上,一个主体进程能否读取到这个文件资源与类型字段有关

类型字段在文件与进程的定义不太相同:

type:在文件资源(Object)上称为类型(type)

domain:在主体程序(Subject)中则称为域(domain)

 

 

重设SELinux上下文:chconrestorecon

chcon [-R] [-t type] [-u user] [-r role]文件

 

 

chcon [-R] --reference=范例文件文件

-R:连同目录下的子文件同时修改;

-t:后接安全上下文的类型字段,如 httpd_sys_content_t

-u:后接身份识别,如system_u

-r:后接角色,如system_r

--reference=范例文件:拿某个文件当范例来修改后续的文件类型;

eg:将index.html类型改为httpd_sys_conten_t          chcon -t httpd_sys_content_t /var/www/html/index.html

chcon是通过直接指定的方式来处理安全上下文的类型数据

restorecon [-Rv]文件或目录

-R:连同子目录一起修改;

-v:将过程显示到屏幕;

restorecon以默认的安全上下文改正;

chcon命令相关:http://man.linuxde.net/chcon


这篇关于SELinux限制导致VSFTP匿名用户不能上传文件问题解决方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/849634

相关文章

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见

Windows系统宽带限制如何解除?

《Windows系统宽带限制如何解除?》有不少用户反映电脑网速慢得情况,可能是宽带速度被限制的原因,只需解除限制即可,具体该如何操作呢?本文就跟大家一起来看看Windows系统解除网络限制的操作方法吧... 有不少用户反映电脑网速慢得情况,可能是宽带速度被限制的原因,只需解除限制即可,具体该如何操作呢?本文

CentOS和Ubuntu系统使用shell脚本创建用户和设置密码

《CentOS和Ubuntu系统使用shell脚本创建用户和设置密码》在Linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设置密码,本文写了一个shell... 在linux系统中,你可以使用useradd命令来创建新用户,使用echo和chpasswd命令来设

解决IDEA报错:编码GBK的不可映射字符问题

《解决IDEA报错:编码GBK的不可映射字符问题》:本文主要介绍解决IDEA报错:编码GBK的不可映射字符问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录IDEA报错:编码GBK的不可映射字符终端软件问题描述原因分析解决方案方法1:将命令改为方法2:右下jav

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

MyBatis模糊查询报错:ParserException: not supported.pos 问题解决

《MyBatis模糊查询报错:ParserException:notsupported.pos问题解决》本文主要介绍了MyBatis模糊查询报错:ParserException:notsuppo... 目录问题描述问题根源错误SQL解析逻辑深层原因分析三种解决方案方案一:使用CONCAT函数(推荐)方案二:

判断PyTorch是GPU版还是CPU版的方法小结

《判断PyTorch是GPU版还是CPU版的方法小结》PyTorch作为当前最流行的深度学习框架之一,支持在CPU和GPU(NVIDIACUDA)上运行,所以对于深度学习开发者来说,正确识别PyTor... 目录前言为什么需要区分GPU和CPU版本?性能差异硬件要求如何检查PyTorch版本?方法1:使用命

Qt实现网络数据解析的方法总结

《Qt实现网络数据解析的方法总结》在Qt中解析网络数据通常涉及接收原始字节流,并将其转换为有意义的应用层数据,这篇文章为大家介绍了详细步骤和示例,感兴趣的小伙伴可以了解下... 目录1. 网络数据接收2. 缓冲区管理(处理粘包/拆包)3. 常见数据格式解析3.1 jsON解析3.2 XML解析3.3 自定义

SpringMVC 通过ajax 前后端数据交互的实现方法

《SpringMVC通过ajax前后端数据交互的实现方法》:本文主要介绍SpringMVC通过ajax前后端数据交互的实现方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价... 在前端的开发过程中,经常在html页面通过AJAX进行前后端数据的交互,SpringMVC的controll

Redis 热 key 和大 key 问题小结

《Redis热key和大key问题小结》:本文主要介绍Redis热key和大key问题小结,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、什么是 Redis 热 key?热 key(Hot Key)定义: 热 key 常见表现:热 key 的风险:二、