-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathupload.php
More file actions
executable file
·75 lines (67 loc) · 2.18 KB
/
upload.php
File metadata and controls
executable file
·75 lines (67 loc) · 2.18 KB
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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
<?php
//indicate file name and path
$target_dir = "images/";
$target_file = $target_dir . basename($_FILES["fileToUpload"]["name"]);
$uploadOk = 1;
$imageFileType = pathinfo($target_file,PATHINFO_EXTENSION);
//mySQL credentials
$servername = "mysql.cs.mcgill.ca";
$username = "dblade";
$password ="260503611";
$dbname = "2014fall307dblade";
$conn = new mysqli($servername, $username, $password, $dbname);
$sql = 'INSERT INTO Uploads (Path, Upvotes, Downvotes, Time)
VALUES("'.$target_file.'","0","0","'.date(DATE_ISO8601).'")';
if($conn->connect_error)
{
die("Connection failed: " . mysqli_connect_error());
}
$imageFileType = pathinfo($target_file,PATHINFO_EXTENSION);
echo var_dump("POST: ", $_POST)."<br>";
echo var_dump("FILES: ", $_FILES)."<br>";
// Check if image file is a actual image or fake image
if(isset($_POST["submit"])) {
$check = getimagesize($_FILES["fileToUpload"]["tmp_name"]);
if($check !== false) {
//TODO insert PATH, set default votes, time
echo "File is an image - " . $check["mime"] . ".<br>";
$uploadOk = 1;
}
else {
echo "File is not an image.";
$uploadOk = 0;
}
}
// Check if file already exists
if (file_exists($target_file)) {
echo "Sorry, file already exists.";
$uploadOk = 0;
}
// Check file size
if ($_FILES["fileToUpload"]["size"] > 500000) {
echo "Sorry, your file is too large.";
$uploadOk = 0;
}
// Allow certain file formats
if($imageFileType != "jpg" && $imageFileType != "png" && $imageFileType != "jpeg"
&& $imageFileType != "gif" ) {
echo "Sorry, only JPG, JPEG, PNG & GIF files are allowed.";
$uploadOk = 0;
}
// Check if $uploadOk is set to 0 by an error
if ($uploadOk == 0) {
echo "Sorry, your file was not uploaded.";
// if everything is ok, try to upload file
} else {
if (move_uploaded_file($_FILES["fileToUpload"]["tmp_name"], $target_file)) {
echo "The file ". basename( $_FILES["fileToUpload"]["name"]). " has been uploaded.";
if($conn->query($sql) === TRUE)
{
echo "File successfully added to DB.";
$uploadOk = 1;
}
} else {
echo "Sorry, there was an error uploading your file.";
}
}
?>