-
Notifications
You must be signed in to change notification settings - Fork 528
/
14_file_handling.php
46 lines (40 loc) · 2.16 KB
/
14_file_handling.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
<?php
/* ---------- File Handling --------- */
/*
File handling is the ability to read and write files on the server.
PHP has built in functions for reading and writing files.
*/
$file = 'extras/users.txt';
// if(file_exists($file)) {
// // Returns the content and number of bytes read from the file on success, or FALSE on failure.
// echo readfile('extras/users.txt');
// }
// File Open, Read, Write, Close
if (file_exists($file)) {
// fopen() gives you more control over the file.
// Modes: r, w, a, x, r+, w+, a+, x+ See below for details
$handle = fopen($file, 'r');
// fread() reads the file and returns the content as a string on success, or FALSE on failure.
$contents = fread($handle, filesize($file));
// fclose() closes the file resource on success, or FALSE on failure.
fclose($handle);
echo $contents;
} else {
// Create the file
$handle = fopen($file, 'w');
// PHP_EOL is a constant that represents the end of line character.
$contents = 'Brad' . PHP_EOL . 'Sara' . PHP_EOL . 'Mike' . PHP_EOL . 'John';
// fwrite() writes the contents to the file and returns the number of bytes written on success, or FALSE on failure.
fwrite($handle, $contents);
fclose($handle);
}
/*
r - Open a file for read only. File pointer starts at the beginning of the file
w - Open a file for write only. Erases the contents of the file or creates a new file if it doesn't exist. File pointer starts at the beginning of the file
a - Open a file for write only. The existing data in file is preserved. File pointer starts at the end of the file. Creates a new file if the file doesn't exist
x - Creates a new file for write only. Returns FALSE and an error if file already exists
r+ - Open a file for read/write. File pointer starts at the beginning of the file
w+ - Open a file for read/write. Erases the contents of the file or creates a new file if it doesn't exist. File pointer starts at the beginning of the file
a+ - Open a file for read/write. The existing data in file is preserved. File pointer starts at the end of the file. Creates a new file if the file doesn't exist
x+ - Creates a new file for read/write. Returns FALSE and an error if file already exists
*/