0% found this document useful (0 votes)
46 views5 pages

File Access Permission

The document explains file ownership and permissions in UNIX, detailing owner, group, and other user permissions. It describes how to use the 'chmod' command to change permissions using both symbolic and absolute modes, as well as how to change file ownership with 'chown' and 'chgrp' commands. The document emphasizes the importance of file permissions as a security measure in UNIX systems.

Uploaded by

123shreyashukla
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
0% found this document useful (0 votes)
46 views5 pages

File Access Permission

The document explains file ownership and permissions in UNIX, detailing owner, group, and other user permissions. It describes how to use the 'chmod' command to change permissions using both symbolic and absolute modes, as well as how to change file ownership with 'chown' and 'chgrp' commands. The document emphasizes the importance of file permissions as a security measure in UNIX systems.

Uploaded by

123shreyashukla
Copyright
© © All Rights Reserved
We take content rights seriously. If you suspect this is your content, claim it here.
Available Formats
Download as DOCX, PDF, TXT or read online on Scribd
You are on page 1/ 5

File ownership is an important component of UNIX that provides a secure

method for storing files. Every file in UNIX has the following attributes −

 Owner permissions − The owner's permissions determine what actions the owner of the file can perform on the
file.

 Group permissions − The group's permissions determine what actions a user, who is a member of the group
that a file belongs to, can perform on the file.

 Other (world) permissions − The permissions for others indicate what action all other users can perform on
the file.

The Permission Indicators


While using ls -l command it displays various information related to file
permission as follows −

$ls -l /home/amrood

-rwxr-xr-- 1 amrood users 1024 Nov 2 00:10 myfile

drwxr-xr--- 1 amrood users 1024 Nov 2 00:10 mydir

Here first column represents different access mode ie. permission


associated with a file or directory.

The permissions are broken into groups of threes, and each position in the
group denotes a specific permission, in this order: read (r), write (w),
execute (x) −

 The first three characters (2-4) represent the permissions for the file's owner.
For example -rwxr-xr-- represents that onwer has read (r), write (w) and
execute (x) permission.

 The second group of three characters (5-7) consists of the permissions for
the group to which the file belongs. For example -rwxr-xr-- represents that
group has read (r) and execute (x) permission but no write permission.

 The last group of three characters (8-10) represents the permissions for
everyone else. For example -rwxr-xr-- represents that other world has read
(r) only permission.

File Access Modes


The permissions of a file are the first line of defense in the security of a Unix
system. The basic building blocks of Unix permissions are the read, write,
and execute permissions, which are described below −

1. Read
Grants the capability to read ie. view the contents of the file.
2. Write
Grants the capability to modify, or remove the content of the file.

3. Execute
User with execute permissions can run a file as a program.

Directory Access Modes


Directory access modes are listed and organized in the same manner as any
other file. There are a few differences that need to be mentioned:

1. Read
Access to a directory means that the user can read the contents. The user
can look at the filenames inside the directory.

2. Write
Access means that the user can add or delete files to the contents of the
directory.

3. Execute
Executing a directory doesn't really make a lot of sense so think of this as a
traverse permission.

A user must have execute access to the bin directory in order to execute ls
or cd command.

Changing Permissions
To change file or directory permissions, you use the chmod (change mode)
command. There are two ways to use chmod: symbolic mode and absolute
mode.

Using chmod in Symbolic Mode


The easiest way for a beginner to modify file or directory permissions is to
use the symbolic mode. With symbolic permissions you can add, delete, or
specify the permission set you want by using the operators in the following
table.

Chmod operator Description

+ Adds the designated permission(s) to a file or directory.


- Removes the designated permission(s) from a file or directory.

= Sets the designated permission(s).

Here's an example using testfile. Running ls -1 on testfile shows that the


file's permissions are as follows −

$ls -l testfile

-rwxrwxr-- 1 amrood users 1024 Nov 2 00:10 testfile

Then each example chmod command from the preceding table is run on
testfile, followed by ls -l so you can see the permission changes −

$chmod o+wx testfile

$ls -l testfile

-rwxrwxrwx 1 amrood users 1024 Nov 2 00:10 testfile

$chmod u-x testfile

$ls -l testfile

-rw-rwxrwx 1 amrood users 1024 Nov 2 00:10 testfile

$chmod g=rx testfile

$ls -l testfile

-rw-r-xrwx 1 amrood users 1024 Nov 2 00:10 testfile

Here's how you could combine these commands on a single line:

$chmod o+wx,u-x,g=rx testfile

$ls -l testfile

-rw-r-xrwx 1 amrood users 1024 Nov 2 00:10 testfile

Using chmod with Absolute Permissions


The second way to modify permissions with the chmod command is to use a
number to specify each set of permissions for the file.

Each permission is assigned a value, as the following table shows, and the
total of each set of permissions provides a number for that set.

Number Octal Permission Representation Ref

0 No permission ---

1 Execute permission --x

2 Write permission -w-

3 Execute and write permission: 1 (execute) + 2 (write) = 3 -wx

4 Read permission r--


5 Read and execute permission: 4 (read) + 1 (execute) = 5 r-x

6 Read and write permission: 4 (read) + 2 (write) = 6 rw-

7 All permissions: 4 (read) + 2 (write) + 1 (execute) = 7 rwx

Here's an example using testfile. Running ls -1 on testfile shows that the


file's permissions are as follows −

$ls -l testfile

-rwxrwxr-- 1 amrood users 1024 Nov 2 00:10 testfile

Then each example chmod command from the preceding table is run on
testfile, followed by ls -l so you can see the permission changes −

$ chmod 755 testfile

$ls -l testfile

-rwxr-xr-x 1 amrood users 1024 Nov 2 00:10 testfile

$chmod 743 testfile

$ls -l testfile

-rwxr---wx 1 amrood users 1024 Nov 2 00:10 testfile

$chmod 043 testfile

$ls -l testfile

----r---wx 1 amrood users 1024 Nov 2 00:10 testfile

Changing Owners and Groups


While creating an account on Unix, it assigns a owner ID and a group ID to
each user. All the permissions mentioned above are also assigned based on
Owner and Groups.

Two commands are available to change the owner and the group of files −

 chown − The chown command stands for "change owner" and is used to change the owner of a file.

 chgrp − The chgrp command stands for "change group" and is used to change the group of a file.

Changing Ownership
The chown command changes the ownership of a file. The basic syntax is as
follows −

$ chown user filelist

The value of user can be either the name of a user on the system or the
user id (uid) of a user on the system.
Following example −

$ chown amrood testfile

Changes the owner of the given file to the user amrood.

NOTE: The super user, root, has the unrestricted capability to change the
ownership of a any file but normal users can change only the owner of files
they own.

Changing Group Ownership


The chrgp command changes the group ownership of a file. The basic
syntax is as follows −

$ chgrp group filelist

The value of group can be the name of a group on the system or the group
ID (GID) of a group on the system.

Following example −

$ chgrp special testfile

Changes the group of the given file to special group.

You might also like