Directory permissions for web serverPermissions for FTP directory: Inherit directory ownerHow to properly...

Compressed gas thruster for an orbital launch vehicle?

Moving millions of files to a different directory with specfic name patterns

Users forgetting to regenerate PDF before sending it

Is it possible to complete a PhD in CS in 3 years?

Did the Ottoman empire suppress the printing press?

Write a function

My previous employer committed a severe violation of the law and is also being sued by me. How do I explain the situation to future employers?

Quoridor rules when faced the opponent

Is it stylistically sound to use onomatopoeic words?

Do injective, yet not bijective, functions have an inverse?

No Torah = Revert to Nothingness?

What could cause the sea level to massively decrease?

When do flights get cancelled due to fog?

Password Hashing Security Using Scrypt & Argon2

A sequence that changes sign finally at infinity?

How to properly translate the key phrase of Erdoğan's 2016 letter to Putin, "kusura bakmasınlar," to Russian

Can Jimmy hang on his rope?

What exactly is a "murder hobo"?

Publishing papers seem natural to many, while I find it really hard to think novel stuff to pursue till publication. How to cope up with this?

What are the effects of abstaining from eating a certain flavor?

Writing an ace/aro character?

Can a landlord force all residents to use the landlord's in-house debit card accounts?

What would +1/+2/+3 items be called in game?

What kind of Chinook helicopter/airplane hybrid is this?



Directory permissions for web server


Permissions for FTP directory: Inherit directory ownerHow to properly setup user/groups/permissions for a web server?Permissions under a 700 (rwx------) directoryWhy, by design, are group permissions ignored for the owner of a file?Ubuntu and web server permissionsUbuntu server 16.04 - Get full FTP access to /var/www/Force new files to inherit specified ownership and permissionsFTP Permissions in Linux (vsftpd)Multiple users to access with read/write permissions to the /var/www directory with vsftpd?Mounting squashfs with correct permissions






.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty{ margin-bottom:0;
}







1















I'm experiencing a problem having to do with permissions to a directory on my server. The file permissions initially read drwx--S--- and I was able to connect with an FTP client signed in as the directory owner and manage the directory, but when I tryed to view them from a browser I get the "Forbidden" message saying I don't have permission to view the files. I noticed if I use sudo chmod -R 644 my_directory which changes the directory's permissions to drw-r-Sr-- and then use sudo chmod g+x my_directory to change the directory's permissions to drw-r-sr--, I can read the files from any browser, but can no longer transfer or view files via FTP to that directory.










share|improve this question
















bumped to the homepage by Community 1 hour ago


This question has answers that may be good or bad; the system has marked it active so that they can be reviewed.






















    1















    I'm experiencing a problem having to do with permissions to a directory on my server. The file permissions initially read drwx--S--- and I was able to connect with an FTP client signed in as the directory owner and manage the directory, but when I tryed to view them from a browser I get the "Forbidden" message saying I don't have permission to view the files. I noticed if I use sudo chmod -R 644 my_directory which changes the directory's permissions to drw-r-Sr-- and then use sudo chmod g+x my_directory to change the directory's permissions to drw-r-sr--, I can read the files from any browser, but can no longer transfer or view files via FTP to that directory.










    share|improve this question
















    bumped to the homepage by Community 1 hour ago


    This question has answers that may be good or bad; the system has marked it active so that they can be reviewed.


















      1












      1








      1








      I'm experiencing a problem having to do with permissions to a directory on my server. The file permissions initially read drwx--S--- and I was able to connect with an FTP client signed in as the directory owner and manage the directory, but when I tryed to view them from a browser I get the "Forbidden" message saying I don't have permission to view the files. I noticed if I use sudo chmod -R 644 my_directory which changes the directory's permissions to drw-r-Sr-- and then use sudo chmod g+x my_directory to change the directory's permissions to drw-r-sr--, I can read the files from any browser, but can no longer transfer or view files via FTP to that directory.










      share|improve this question
















      I'm experiencing a problem having to do with permissions to a directory on my server. The file permissions initially read drwx--S--- and I was able to connect with an FTP client signed in as the directory owner and manage the directory, but when I tryed to view them from a browser I get the "Forbidden" message saying I don't have permission to view the files. I noticed if I use sudo chmod -R 644 my_directory which changes the directory's permissions to drw-r-Sr-- and then use sudo chmod g+x my_directory to change the directory's permissions to drw-r-sr--, I can read the files from any browser, but can no longer transfer or view files via FTP to that directory.







      ubuntu permissions






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited Jan 13 at 21:43









      Rui F Ribeiro

      40.8k16 gold badges91 silver badges152 bronze badges




      40.8k16 gold badges91 silver badges152 bronze badges










      asked Feb 27 '15 at 20:57









      RogerRoger

      62 bronze badges




      62 bronze badges





      bumped to the homepage by Community 1 hour ago


      This question has answers that may be good or bad; the system has marked it active so that they can be reviewed.







      bumped to the homepage by Community 1 hour ago


      This question has answers that may be good or bad; the system has marked it active so that they can be reviewed.
























          1 Answer
          1






          active

          oldest

          votes


















          0














          Based on your question I'm going to make an assumption. The web server process is in the same group as the group ownership of the directory.



          You removed the execute (x) bit from the directory permissions and only gave it back to the group. This means that the directory owner doesn't have execute permission and that is required to be able to change into/traverse through a directory. Using chmod -R with absolute permissions can be dangerous for this very reason. I would recommend you do the following:



          Fix your directory permissions.



          sudo find my_directory -type d -exec chmod 2750 {} ;


          Since you broke directory traversal you may need to execute this multiple times. If you receive any permission errors while running the above command re-run it until those errors clear.



          Fix your file permissions.



          sudo find my_directory -type f -exec chmod 0640 {} ;


          When this is done your directories should have the following permissions.



          drwxr-s---


          And your files should have the following permissions.



          -rwxr-x---


          If you want to better understand UNIX permissions I would recommend reading man 2 chmod. It's certainly dry reading but it explains what the meaning of each bit is.






          share|improve this answer
























          • Thanks for the reply @SeeJayEmm , I want to gain a better understanding of the first two commands you suggested (to fix directory and file permissions). I read through the man chmod 2 & 1 and could not find what the {} accomplishes. I'm assuming this doesn't have anything to do specifically with chmod, could you shed some light on this?

            – Roger
            Feb 28 '15 at 22:04











          • You'll want to read through the -exec section of man find. For each file/directory that is found the command after -exec is executed and {} is replaced with the file name. ';' indicates the end of a command but since it's a special char for the shell it needs to be escaped out ';'.

            – SeeJayEmm
            Mar 2 '15 at 1:48











          • In the 1st command find is locating each directory (-type d) and executing 'chmod 2750' on it. In the 2nd command it is locating each file (-type f) and executing 'chmod 0640' on it. This is one way can use explicit permissions in chmod without screwing up the execute bit on directories.

            – SeeJayEmm
            Mar 2 '15 at 1:50














          Your Answer








          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "106"
          };
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function() {
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled) {
          StackExchange.using("snippets", function() {
          createEditor();
          });
          }
          else {
          createEditor();
          }
          });

          function createEditor() {
          StackExchange.prepareEditor({
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          bindNavPrevention: true,
          postfix: "",
          imageUploader: {
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          },
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          });


          }
          });














          draft saved

          draft discarded


















          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f187277%2fdirectory-permissions-for-web-server%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown

























          1 Answer
          1






          active

          oldest

          votes








          1 Answer
          1






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes









          0














          Based on your question I'm going to make an assumption. The web server process is in the same group as the group ownership of the directory.



          You removed the execute (x) bit from the directory permissions and only gave it back to the group. This means that the directory owner doesn't have execute permission and that is required to be able to change into/traverse through a directory. Using chmod -R with absolute permissions can be dangerous for this very reason. I would recommend you do the following:



          Fix your directory permissions.



          sudo find my_directory -type d -exec chmod 2750 {} ;


          Since you broke directory traversal you may need to execute this multiple times. If you receive any permission errors while running the above command re-run it until those errors clear.



          Fix your file permissions.



          sudo find my_directory -type f -exec chmod 0640 {} ;


          When this is done your directories should have the following permissions.



          drwxr-s---


          And your files should have the following permissions.



          -rwxr-x---


          If you want to better understand UNIX permissions I would recommend reading man 2 chmod. It's certainly dry reading but it explains what the meaning of each bit is.






          share|improve this answer
























          • Thanks for the reply @SeeJayEmm , I want to gain a better understanding of the first two commands you suggested (to fix directory and file permissions). I read through the man chmod 2 & 1 and could not find what the {} accomplishes. I'm assuming this doesn't have anything to do specifically with chmod, could you shed some light on this?

            – Roger
            Feb 28 '15 at 22:04











          • You'll want to read through the -exec section of man find. For each file/directory that is found the command after -exec is executed and {} is replaced with the file name. ';' indicates the end of a command but since it's a special char for the shell it needs to be escaped out ';'.

            – SeeJayEmm
            Mar 2 '15 at 1:48











          • In the 1st command find is locating each directory (-type d) and executing 'chmod 2750' on it. In the 2nd command it is locating each file (-type f) and executing 'chmod 0640' on it. This is one way can use explicit permissions in chmod without screwing up the execute bit on directories.

            – SeeJayEmm
            Mar 2 '15 at 1:50
















          0














          Based on your question I'm going to make an assumption. The web server process is in the same group as the group ownership of the directory.



          You removed the execute (x) bit from the directory permissions and only gave it back to the group. This means that the directory owner doesn't have execute permission and that is required to be able to change into/traverse through a directory. Using chmod -R with absolute permissions can be dangerous for this very reason. I would recommend you do the following:



          Fix your directory permissions.



          sudo find my_directory -type d -exec chmod 2750 {} ;


          Since you broke directory traversal you may need to execute this multiple times. If you receive any permission errors while running the above command re-run it until those errors clear.



          Fix your file permissions.



          sudo find my_directory -type f -exec chmod 0640 {} ;


          When this is done your directories should have the following permissions.



          drwxr-s---


          And your files should have the following permissions.



          -rwxr-x---


          If you want to better understand UNIX permissions I would recommend reading man 2 chmod. It's certainly dry reading but it explains what the meaning of each bit is.






          share|improve this answer
























          • Thanks for the reply @SeeJayEmm , I want to gain a better understanding of the first two commands you suggested (to fix directory and file permissions). I read through the man chmod 2 & 1 and could not find what the {} accomplishes. I'm assuming this doesn't have anything to do specifically with chmod, could you shed some light on this?

            – Roger
            Feb 28 '15 at 22:04











          • You'll want to read through the -exec section of man find. For each file/directory that is found the command after -exec is executed and {} is replaced with the file name. ';' indicates the end of a command but since it's a special char for the shell it needs to be escaped out ';'.

            – SeeJayEmm
            Mar 2 '15 at 1:48











          • In the 1st command find is locating each directory (-type d) and executing 'chmod 2750' on it. In the 2nd command it is locating each file (-type f) and executing 'chmod 0640' on it. This is one way can use explicit permissions in chmod without screwing up the execute bit on directories.

            – SeeJayEmm
            Mar 2 '15 at 1:50














          0












          0








          0







          Based on your question I'm going to make an assumption. The web server process is in the same group as the group ownership of the directory.



          You removed the execute (x) bit from the directory permissions and only gave it back to the group. This means that the directory owner doesn't have execute permission and that is required to be able to change into/traverse through a directory. Using chmod -R with absolute permissions can be dangerous for this very reason. I would recommend you do the following:



          Fix your directory permissions.



          sudo find my_directory -type d -exec chmod 2750 {} ;


          Since you broke directory traversal you may need to execute this multiple times. If you receive any permission errors while running the above command re-run it until those errors clear.



          Fix your file permissions.



          sudo find my_directory -type f -exec chmod 0640 {} ;


          When this is done your directories should have the following permissions.



          drwxr-s---


          And your files should have the following permissions.



          -rwxr-x---


          If you want to better understand UNIX permissions I would recommend reading man 2 chmod. It's certainly dry reading but it explains what the meaning of each bit is.






          share|improve this answer













          Based on your question I'm going to make an assumption. The web server process is in the same group as the group ownership of the directory.



          You removed the execute (x) bit from the directory permissions and only gave it back to the group. This means that the directory owner doesn't have execute permission and that is required to be able to change into/traverse through a directory. Using chmod -R with absolute permissions can be dangerous for this very reason. I would recommend you do the following:



          Fix your directory permissions.



          sudo find my_directory -type d -exec chmod 2750 {} ;


          Since you broke directory traversal you may need to execute this multiple times. If you receive any permission errors while running the above command re-run it until those errors clear.



          Fix your file permissions.



          sudo find my_directory -type f -exec chmod 0640 {} ;


          When this is done your directories should have the following permissions.



          drwxr-s---


          And your files should have the following permissions.



          -rwxr-x---


          If you want to better understand UNIX permissions I would recommend reading man 2 chmod. It's certainly dry reading but it explains what the meaning of each bit is.







          share|improve this answer












          share|improve this answer



          share|improve this answer










          answered Feb 27 '15 at 22:18









          SeeJayEmmSeeJayEmm

          3011 gold badge2 silver badges9 bronze badges




          3011 gold badge2 silver badges9 bronze badges













          • Thanks for the reply @SeeJayEmm , I want to gain a better understanding of the first two commands you suggested (to fix directory and file permissions). I read through the man chmod 2 & 1 and could not find what the {} accomplishes. I'm assuming this doesn't have anything to do specifically with chmod, could you shed some light on this?

            – Roger
            Feb 28 '15 at 22:04











          • You'll want to read through the -exec section of man find. For each file/directory that is found the command after -exec is executed and {} is replaced with the file name. ';' indicates the end of a command but since it's a special char for the shell it needs to be escaped out ';'.

            – SeeJayEmm
            Mar 2 '15 at 1:48











          • In the 1st command find is locating each directory (-type d) and executing 'chmod 2750' on it. In the 2nd command it is locating each file (-type f) and executing 'chmod 0640' on it. This is one way can use explicit permissions in chmod without screwing up the execute bit on directories.

            – SeeJayEmm
            Mar 2 '15 at 1:50



















          • Thanks for the reply @SeeJayEmm , I want to gain a better understanding of the first two commands you suggested (to fix directory and file permissions). I read through the man chmod 2 & 1 and could not find what the {} accomplishes. I'm assuming this doesn't have anything to do specifically with chmod, could you shed some light on this?

            – Roger
            Feb 28 '15 at 22:04











          • You'll want to read through the -exec section of man find. For each file/directory that is found the command after -exec is executed and {} is replaced with the file name. ';' indicates the end of a command but since it's a special char for the shell it needs to be escaped out ';'.

            – SeeJayEmm
            Mar 2 '15 at 1:48











          • In the 1st command find is locating each directory (-type d) and executing 'chmod 2750' on it. In the 2nd command it is locating each file (-type f) and executing 'chmod 0640' on it. This is one way can use explicit permissions in chmod without screwing up the execute bit on directories.

            – SeeJayEmm
            Mar 2 '15 at 1:50

















          Thanks for the reply @SeeJayEmm , I want to gain a better understanding of the first two commands you suggested (to fix directory and file permissions). I read through the man chmod 2 & 1 and could not find what the {} accomplishes. I'm assuming this doesn't have anything to do specifically with chmod, could you shed some light on this?

          – Roger
          Feb 28 '15 at 22:04





          Thanks for the reply @SeeJayEmm , I want to gain a better understanding of the first two commands you suggested (to fix directory and file permissions). I read through the man chmod 2 & 1 and could not find what the {} accomplishes. I'm assuming this doesn't have anything to do specifically with chmod, could you shed some light on this?

          – Roger
          Feb 28 '15 at 22:04













          You'll want to read through the -exec section of man find. For each file/directory that is found the command after -exec is executed and {} is replaced with the file name. ';' indicates the end of a command but since it's a special char for the shell it needs to be escaped out ';'.

          – SeeJayEmm
          Mar 2 '15 at 1:48





          You'll want to read through the -exec section of man find. For each file/directory that is found the command after -exec is executed and {} is replaced with the file name. ';' indicates the end of a command but since it's a special char for the shell it needs to be escaped out ';'.

          – SeeJayEmm
          Mar 2 '15 at 1:48













          In the 1st command find is locating each directory (-type d) and executing 'chmod 2750' on it. In the 2nd command it is locating each file (-type f) and executing 'chmod 0640' on it. This is one way can use explicit permissions in chmod without screwing up the execute bit on directories.

          – SeeJayEmm
          Mar 2 '15 at 1:50





          In the 1st command find is locating each directory (-type d) and executing 'chmod 2750' on it. In the 2nd command it is locating each file (-type f) and executing 'chmod 0640' on it. This is one way can use explicit permissions in chmod without screwing up the execute bit on directories.

          – SeeJayEmm
          Mar 2 '15 at 1:50


















          draft saved

          draft discarded




















































          Thanks for contributing an answer to Unix & Linux Stack Exchange!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid



          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.


          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2funix.stackexchange.com%2fquestions%2f187277%2fdirectory-permissions-for-web-server%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          Taj Mahal Inhaltsverzeichnis Aufbau | Geschichte | 350-Jahr-Feier | Heutige Bedeutung | Siehe auch |...

          Baia Sprie Cuprins Etimologie | Istorie | Demografie | Politică și administrație | Arii naturale...

          Ciclooctatetraenă Vezi și | Bibliografie | Meniu de navigare637866text4148569-500570979m