Счетчик скачиваний файла на PHP + mySQL
Не знаю как остальным, но мне очень часто требуется подсчитывать количество скачиваний файла с сервера. Причем так уж выходит, что эта задача возникает от проекта к проекту, в виду чего я решил набросать небольшой простеньких скрипт на PHP, который будет отдавать файл пользователю увеличивать счетчик скачиваний на единицу и все это сохранять в базу данных mySQL. Кроме всего этого скрипт будет предоставлять нам статистику по каждому файлу: дату последнего скачивания и их количество.
Скрипт будет использовать PHP класс для работы с базой данных.
<?php $folder = '/examples/'; // Папка с файлами $ext = array('rar','zip'); // Устанавливаем разрешенные типы файлов для скачивания $subfolder = true; // Разрешить скачивание из вложенных папок $settings = array( 'dbName' => '', 'dbUser' => '', 'dbPass' => '', 'dbHost' => 'localhost' ); // Настройки подключения к БД // Подключаем класс для работы с БД include('lib/dbsql.class.php'); // Инициализируем подключение к БД $DB = new DB_Engine('mysql', $settings['dbHost'], $settings['dbUser'], $settings['dbPass'], $settings['dbName']); $filename=$_GET['f']; $f=explode('.',$filename); if(!in_array($f[count($f)-1], $ext)) die('Данный тип файла запрщен для скачивания'); $crc=md5($filename); // Генерируем хеш имени файла $date=time(); // Текущее время $sql="SELECT * FROM `rche_uploads` WHERE `crc` = '$crc' LIMIT 1"; $exrow=$DB->getAll($sql); // Берем из БД запись с таким хешем if($_GET['event']=='show') { echo "Скачали: {$exrow[0]['count']} раз(а), Последняя дата скачивания: ".date('H:i d.m.Y',$exrow[0]['date']); exit; } if(count($exrow)>0) // Если запись в БД с таким хешем есть увеличиваем счетчик, если нет вносим новую запись в БД { $count=$exrow[0]['count']+1; //Текущее значение счетчика увеличиваем на 1 $sql="UPDATE `rche_uploads` SET `count` = '$count' WHERE `crc` = '$crc' LIMIT 1;"; } else { $sql="INSERT INTO `rche_uploads` (`crc`,`count`,`date`) VALUES ('$crc','1','$date');"; } $DB->execute($sql); // Выполняем mySQL запрос header("Location: {$folder}{$filename}"); // Переход на скачиваемый файл |
Структура БД
CREATE TABLE IF NOT EXISTS `rche_uploads` ( `id` int(11) NOT NULL AUTO_INCREMENT, `crc` varchar(50) NOT NULL, `count` int(11) NOT NULL, `date` int(11) NOT NULL, PRIMARY KEY (`id`), KEY `id` (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ; |
Пример использования скрипта, для скачивания файла вызываем ссылки вида (переменная «f» содержит путь к файлу который требуется скачать):
http://rche.ru/upload2.php?f=854/upload2.zip
Для просмотра статистики по количеству и времени скачиваний, добавляем в запрос переменную event со значением show
http://rche.ru/upload2.php?f=854/upload2.zip&event=show
Исходники скрипта можно скачать по этой ссылке.
Надеюсь пример моей реализации вам пригодиться или послужит маленьким уроком быстрого создания счетчика скачиваний на PHP.
Похожие записи
2 комментария to “Счетчик скачиваний файла на PHP + mySQL”
Оставить комментарий
- Перенести ли домены с Рег.ру на Бегет? спросил (а) Виктор
- RuCaptcha bot и бан по IP спросил (а) Родмик
- MySQL запрос с несколькими JOIN спросил (а) Александр
- MySQL выбрать данные из двух таблиц спросил (а) Виталий
- Редирект при переносе сайта на WordPress спросил (а) Николай
- Подключение сайта к хранилищу на Яндекс Облаке к записи
- Подключение сайта к хранилищу на Яндекс Облаке к записи
- Подключение сайта к хранилищу на Яндекс Облаке к записи
- PHP: распознать цифры, буквы с картинки к записи
- Анализ рынка Совместных покупок к записи
- Переустановка Apache к записи
- Интеграция сайта со СДЭК по API к записи
Archive
- +2021 (2)
- Апрель 2021 (1)
- Март 2021 (1)
- +2020 (20)
- Декабрь 2020 (6)
- Сентябрь 2020 (2)
- Август 2020 (1)
- Июль 2020 (2)
- Май 2020 (2)
- Апрель 2020 (2)
- Март 2020 (2)
- Февраль 2020 (1)
- Январь 2020 (2)
- +2019 (18)
- Декабрь 2019 (3)
- Ноябрь 2019 (2)
- Октябрь 2019 (2)
- Сентябрь 2019 (1)
- Август 2019 (2)
- Июль 2019 (1)
- Июнь 2019 (1)
- Апрель 2019 (2)
- Март 2019 (1)
- Февраль 2019 (3)
- +2018 (44)
- Декабрь 2018 (4)
- Ноябрь 2018 (7)
- Октябрь 2018 (8)
- Сентябрь 2018 (1)
- Август 2018 (4)
- Июль 2018 (5)
- Май 2018 (3)
- Апрель 2018 (7)
- Март 2018 (1)
- Февраль 2018 (2)
- Январь 2018 (2)
- +2017 (19)
- Декабрь 2017 (2)
- Ноябрь 2017 (1)
- Октябрь 2017 (1)
- Сентябрь 2017 (2)
- Июль 2017 (1)
- Июнь 2017 (1)
- Май 2017 (2)
- Апрель 2017 (3)
- Март 2017 (2)
- Февраль 2017 (1)
- Январь 2017 (3)
- +2016 (37)
- Декабрь 2016 (3)
- Ноябрь 2016 (3)
- Октябрь 2016 (2)
- Сентябрь 2016 (3)
- Август 2016 (7)
- Июнь 2016 (3)
- Май 2016 (3)
- Апрель 2016 (3)
- Март 2016 (1)
- Февраль 2016 (1)
- Январь 2016 (8)
- +2015 (36)
- Ноябрь 2015 (5)
- Октябрь 2015 (4)
- Сентябрь 2015 (1)
- Август 2015 (8)
- Июнь 2015 (1)
- Май 2015 (4)
- Апрель 2015 (8)
- Март 2015 (3)
- Февраль 2015 (2)
- +2014 (26)
- Ноябрь 2014 (2)
- Октябрь 2014 (5)
- Сентябрь 2014 (6)
- Июль 2014 (1)
- Июнь 2014 (2)
- Май 2014 (3)
- Апрель 2014 (6)
- Февраль 2014 (1)
- +2013 (27)
- Декабрь 2013 (2)
- Ноябрь 2013 (1)
- Октябрь 2013 (1)
- Август 2013 (1)
- Июль 2013 (3)
- Июнь 2013 (10)
- Май 2013 (1)
- Апрель 2013 (2)
- Февраль 2013 (3)
- Январь 2013 (3)
- +2012 (42)
- Декабрь 2012 (2)
- Ноябрь 2012 (3)
- Октябрь 2012 (7)
- Сентябрь 2012 (2)
- Август 2012 (1)
- Июль 2012 (3)
- Июнь 2012 (2)
- Май 2012 (6)
- Апрель 2012 (2)
- Март 2012 (8)
- Февраль 2012 (5)
- Январь 2012 (1)
- +2011 (57)
- Декабрь 2011 (6)
- Ноябрь 2011 (2)
- Октябрь 2011 (3)
- Сентябрь 2011 (5)
- Август 2011 (4)
- Июль 2011 (3)
- Июнь 2011 (3)
- Май 2011 (3)
- Апрель 2011 (4)
- Март 2011 (10)
- Февраль 2011 (5)
- Январь 2011 (9)
- +2010 (43)
- Декабрь 2010 (7)
- Ноябрь 2010 (21)
- Октябрь 2010 (14)
- Сентябрь 2010 (1)
Свежие записи
- Почему парсинг сайта не всегда может быть полностью автоматическим 09.04.2021
- Интеграция по API с страховым маркетплейсом INSSMART 11.03.2021
- Регистрация программы для ЭВМ или базы данных в Роспатенте 27.12.2020
- Парсер для форума XenForo 22.12.2020
- Интеграция Тинькофф банк Эквайринг на сайт для приема платежей 18.12.2020


Господи иисусе! Да почему просто не сделать тоже самое только через аякс и вывод количества скачиваний рядом с сылкой!
Что же у всех так юзабилити хромает… ужас..
Ну вообще этот пример призван показать принцип работы, а аякс это уже по желанию и усмотрению каждого вебмастера индивидуально. Но опять же если задуматься: представим такую картину, на странице выводится информация о 10 файлах и количество скачиваний каждого — зачем нам делать запросы на аякс для получения информации о скачивании того или иного файла? в чем тут юзабилити? Ведь это дополнительно 10 аякс запросов к серверу…. не проще ли сразу вывести данную информацию сгенерированную PHP кодом рядом с файлом.
И вообще статья не много не об этом!