The SplFileObject flock() function is an inbuilt function of Standard PHP Library (SPL) in PHP which is used to apply portable lock on the file.
Syntax:
bool SplFileObject::flock( $opr, $isBlock )
Parameters: This function accept two parameters as mentioned above and described below:
$opr: It is used to specify the operation to be apply from the following list:
- LOCK_SH: Acquire a shared lock (reader).
- LOCK_EX: Acquire an exclusive lock (writer).
- LOCK_UN: Release a lock.
- LOCK_NB: Not block while locking.
$isBlock: This parameter is set to True if the lock is block.
Return values: This function returns True on on success or False on failure.
Note: Make sure the used file in below program named as gfg.txt and should have read and write permissions.
Below Programs illustrate the SplFileObject::flock() function in PHP:
Program 1:
<?php // Create Spl Object $file = new SplFileObject( "gfg.txt" , "w" ); // Add an Exclusive lock to gfg.txt if ( $file -> flock (LOCK_SH)) { $file ->ftruncate(0); $file ->fwrite( "Write GFG inside the gfg.txt" ); // Release the lock $file -> flock (LOCK_UN); echo "Success Lock and Unlock Operation" ; } else { echo "No Lock Available" ; } ?> |
Output:
Success Lock and Unlock Operation.
Program 2:
<?php // Create SplFile Object $file = new SplFileObject( "gfg.txt" , "w" ); // Add an Exclusive lock to gfg.txt if ( $file -> flock (LOCK_EX)) { $file ->ftruncate(0); $file ->fwrite( "Write GFG inside the gfg.txt" ); // Release the lock $file -> flock (LOCK_UN); echo "Success Exclusive Lock and Unlock Operation" ; } else { echo "No Lock Available" ; } ?> |
Output:
Success Exclusive Lock and Unlock Operation