AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / unix / Perguntas / 483585
Accepted
Mandingo
Mandingo
Asked: 2018-11-23 20:21:24 +0800 CST2018-11-23 20:21:24 +0800 CST 2018-11-23 20:21:24 +0800 CST

Quais permissões devem ser definidas em um diretório para permitir que alguém anexe dados a um arquivo nesse diretório, mas não para remover esse arquivo?

  • 772

"Quais permissões devem ser definidas em um diretório para permitir que se anexe dados a um arquivo nesse diretório, mas não para remover esse arquivo?"

Do meu entendimento, você precisa da permissão de gravação 'w' para anexar dados a um arquivo, mas isso também lhe dará a capacidade de remover o arquivo, mas a pergunta está pedindo as permissões que devem ser definidas para que seja possível anexar dados para um arquivo, mas não removê-lo.

linux
  • 2 2 respostas
  • 2085 Views

2 respostas

  • Voted
  1. Best Answer
    Haxiel
    2018-11-23T20:47:04+08:002018-11-23T20:47:04+08:00

    Anexar dados a um arquivo requer permissão de gravação no próprio arquivo. A remoção de um arquivo requer permissão de gravação no diretório que contém um arquivo.

    Por exemplo, tenho um diretório chamado testdir, para o qual removi as permissões de gravação:

    [haxiel@testvm1 ~]$ ls -ld testdir/
    dr-xr-xr-x. 2 haxiel haxiel 26 Nov 23 10:09 testdir/
    

    Dentro do diretório, criei um arquivo chamado testfile.txt (isso foi feito antes de remover a permissão de gravação no diretório).

    [haxiel@testvm1 testdir]$ ls -l testfile.txt
    -rw-rw-r--. 1 haxiel haxiel 12 Nov 23 10:11 testfile.txt
    

    Agora, posso anexar dados ao arquivo, pois tenho permissão de gravação nele:

    [haxiel@testvm1 testdir]$ echo "Line1" >> testfile.txt
    [haxiel@testvm1 testdir]$ echo "Line2" >> testfile.txt
    [haxiel@testvm1 testdir]$ cat testfile.txt
    Line1
    Line2
    

    Mas não consigo remover o arquivo, pois não tenho permissões de gravação em seu diretório pai.

    [haxiel@testvm1 testdir]$ rm testfile.txt
    rm: cannot remove ‘testfile.txt’: Permission denied
    

    Você pode olhar para esta pergunta para obter mais detalhes sobre permissões de diretório: Execute vs Read bit. Como funcionam as permissões de diretório no Linux?

    • 3
  2. Michael Prokopec
    2018-11-23T21:06:24+08:002018-11-23T21:06:24+08:00

    O diretório não tem nada a ver com as permissões dos arquivos. O arquivo, se também puder ser escrito, também poderá ser excluído. Você pode tentar ACLs, como aqui: Como dar permissões para ler, escrever, mas não excluir o arquivo , mas isso é facilmente servido.

    Aqui está uma explicação das permissões de arquivo:

    (rwx------)  This area is for owner.
    (---rwx---)  This area is for group owner.
    (------rwx)  This area is for others.
    (-rwx------) The preceding - indicates a directory.
    
           Value       | Meaning
                       |
    ==========================================================================================================================================================================================================
                       |
    777    (rwxrwxrwx) | No restrictions on permissions. Anybody may do anything. Generally not a desirable setting.
    
    755    (rwxr-xr-x) | The file's owner may read, write, and execute the file. All others may read and execute the file. This setting is common for programs that are used by all users.
    
    700    (rwx------) | The file's owner may read, write, and execute the file. Nobody else has any rights. This setting is useful for programs that only the owner may use and must be kept private from others.
    
    666    (rw-rw-rw-) | All users may read and write the file.
    
    644    (rw-r--r--) | The owner may read and write a file, while all others may only read the file. A common setting for data files that everybody may read, but only the owner may change.
    
    600    (rw-------) | The owner may read and write a file. All others have no rights. A common setting for data files that the owner wants to keep private.
    
    • 1

relate perguntas

  • Existe uma maneira de fazer ls mostrar arquivos ocultos apenas para determinados diretórios?

  • Inicie/pare o serviço systemd usando o atalho de teclado [fechado]

  • Necessidade de algumas chamadas de sistema

  • astyle não altera a formatação do arquivo de origem

  • Passe o sistema de arquivos raiz por rótulo para o kernel do Linux

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Como exportar uma chave privada GPG e uma chave pública para um arquivo

    • 4 respostas
  • Marko Smith

    ssh Não é possível negociar: "nenhuma cifra correspondente encontrada", está rejeitando o cbc

    • 4 respostas
  • Marko Smith

    Como podemos executar um comando armazenado em uma variável?

    • 5 respostas
  • Marko Smith

    Como configurar o systemd-resolved e o systemd-networkd para usar o servidor DNS local para resolver domínios locais e o servidor DNS remoto para domínios remotos?

    • 3 respostas
  • Marko Smith

    Como descarregar o módulo do kernel 'nvidia-drm'?

    • 13 respostas
  • Marko Smith

    apt-get update error no Kali Linux após a atualização do dist [duplicado]

    • 2 respostas
  • Marko Smith

    Como ver as últimas linhas x do log de serviço systemctl

    • 5 respostas
  • Marko Smith

    Nano - pule para o final do arquivo

    • 8 respostas
  • Marko Smith

    erro grub: você precisa carregar o kernel primeiro

    • 4 respostas
  • Marko Smith

    Como baixar o pacote não instalá-lo com o comando apt-get?

    • 7 respostas
  • Martin Hope
    rocky Como exportar uma chave privada GPG e uma chave pública para um arquivo 2018-11-16 05:36:15 +0800 CST
  • Martin Hope
    Wong Jia Hau ssh-add retorna com: "Erro ao conectar ao agente: nenhum arquivo ou diretório" 2018-08-24 23:28:13 +0800 CST
  • Martin Hope
    Evan Carroll status systemctl mostra: "Estado: degradado" 2018-06-03 18:48:17 +0800 CST
  • Martin Hope
    Tim Como podemos executar um comando armazenado em uma variável? 2018-05-21 04:46:29 +0800 CST
  • Martin Hope
    Ankur S Por que /dev/null é um arquivo? Por que sua função não é implementada como um programa simples? 2018-04-17 07:28:04 +0800 CST
  • Martin Hope
    user3191334 Como ver as últimas linhas x do log de serviço systemctl 2018-02-07 00:14:16 +0800 CST
  • Martin Hope
    Marko Pacak Nano - pule para o final do arquivo 2018-02-01 01:53:03 +0800 CST
  • Martin Hope
    Kidburla Por que verdadeiro e falso são tão grandes? 2018-01-26 12:14:47 +0800 CST
  • Martin Hope
    Christos Baziotis Substitua a string em um arquivo de texto enorme (70 GB), uma linha 2017-12-30 06:58:33 +0800 CST
  • Martin Hope
    Bagas Sanjaya Por que o Linux usa LF como caractere de nova linha? 2017-12-20 05:48:21 +0800 CST

Hot tag

linux bash debian shell-script text-processing ubuntu centos shell awk ssh

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve