PHP+Mysql+jQuery实现文件下载次数统计

数据表
CREATE TABLE IF NOT EXISTS `downloads` (   `id` int(6) unsigned NOT NULL AUTO_INCREMENT,   `filename` varchar(50) NOT NULL,   `savename` varchar(50) NOT NULL,   `downloads` int(10) unsigned NOT NULL DEFAULT ‘1‘,   PRIMARY KEY (`id`),   UNIQUE KEY `filename` (`filename`) ) ENGINE=MyISAM  DEFAULT CHARSET=utf8; 
HTML
<div id="demo">
    <ul class="filelist">
    </ul>
</div>

CSS
#demo{width:728px;margin:50px auto;padding:10px;border:1px solid #ddd;background-color:#eee;}
ul.filelist li{background:url("img/bg_gradient.gif") repeat-x center bottom #F5F5F5;
border:1px solid #ddd;border-top-color:#fff;list-style:none;position:relative;}
ul.filelist li.load{background:url("img/ajax_load.gif") no-repeat; padding-left:20px;
border:none; position:relative; left:150px; top:30px; width:200px}
ul.filelist li a{display:block;padding:8px;}
ul.filelist li a:hover .download{display:block;}
span.download{background-color:#64b126;border:1px solid #4e9416;color:white;
display:none;font-size:12px;padding:2px 4px;position:absolute;right:8px;
text-decoration:none;text-shadow:0 0 1px #315d0d;top:6px;
-moz-border-radius:3px;-webkit-border-radius:3px;border-radius:3px;}
span.downcount{color:#999;padding:5px;position:absolute; margin-left:10px;text-decoration:none;} 
jQuery
前端页面jQuery主要完成两个任务,一是通过Ajax异步读取文件列表并展示,二是响应用户点击事件,将对应的文件下载次数+1,来看代码:
$(function(){
    $.ajax({ //异步请求
        type: ‘GET‘,
        url: ‘filelist.php‘,
        dataType: ‘json‘,
        cache: false,
        beforeSend: function(){
            $(".filelist").html("<li class=‘load‘>正在载入...</li>");
        },
        success: function(json){
            if(json){
                var li = ‘‘;
                $.each(json,function(index,array){
                    li = li + ‘<li><a href="download.php?id=‘+array[‘id‘]+‘">‘+array[‘file‘]+
            ‘<span class="downcount" title="下载次数">‘+array[‘downloads‘]+‘</span>
            <span class="download">点击下载</span></a></li>‘;
                });
                $(".filelist").html(li);
            }          
        $(‘ul.filelist a‘).on(‘click‘,function(){
            var count = $(‘.downcount‘,this);
            count.text( parseInt(count.text())+1); //下载次数+1
         }); 
    }    }); 

首先,页面载入完后,通过$.ajax()向后台filelist.php发送一个GET形式的Ajax请求,当filelist.php相应成功后,接收返回的json数据,通过$.each()遍历json数据对象,构造html字符串,并将最终得到的字符串加入到ul.filelist中,形成了demo中的文件列表。 然后,当点击文件下载时,通过on()响应动态加入的列表元素的click事件,将下载次数进行累加。
  PHP 为了更好的理解,我们分两个PHP文件,一个是filelist.php,用来读取mysql数据表中的数据,并输出为JSON格式的数据用来给前台index.html页面调用,另一个是download.php,用来响应下载动作,更新对应文件的下载次数,并且通过浏览器完成下载。其实还有一个数据库连接文件conn.php, filelist.php读取downloads表,并通过json_encode()将数据以JSON格式输出,这样是为下面的Ajax异步操作准备的。conn.php

  <?php
  $host="localhost";
  $db_user="root";
  $db_pass="";
  $db_name="test";
  $timezone="Asia/Shanghai";

  $link=mysqli_connect($host,$db_user,$db_pass);

  mysqli_select_db($link,$db_name);
  mysqli_query($link,"SET names UTF8");
  header("Content-Type: text/html; charset=utf-8");

?>

  
filelist.php
require ‘conn.php‘; //连接数据库
$result = mysql_query("SELECT * FROM downloads");
if(mysql_num_rows($result)){
    while($row=mysql_fetch_assoc($result)){
        $data[] = array(
            ‘id‘ => $row[‘id‘],
            ‘file‘ => $row[‘filename‘],
            ‘downloads‘=> $row[‘downloads‘]
        );
    }
    echo json_encode($data);
}
download.php根据url传参,查询得到对应的数据,检测要下载的文件是否存在,如果存在,则更新对应数据的下载次数+1,并且使用header()实现下载功能。值得一提的是,使用header()函数,强制下载文件,并且可以设置下载后保存到本地的文件名称。一般情况下,我们通过后台上传程序会将上传的文件重命名后保存到服务器上,常见的有以日期时间命名的文件,这样的好处之一就是避免了文件名重复和中文名称乱码的情况。而我们下载到本地的文件可以使用header("Content-Disposition: attachment; filename=" .$filename )将文件名设置为易于识别的文件名称。
download.php
require(‘conn.php‘);//连接数据库
$id = (int)$_GET[‘id‘]; 

if(!isset($id) || $id==0) die(‘参数错误!‘);
$query = mysql_query($link,"select * from downloads where id=‘$id‘");
$row = mysql_fetch_array($query);
if(!$row) exit;
$filename = iconv(‘UTF-8‘,‘GBK‘,$row[‘filename‘]);//中文名称注意转换编码
$savename = $row[‘savename‘]; //实际在服务器上的保存名称
$myfile = ‘file/‘.$savename;
if(file_exists($myfile)){//如果文件存在
    //更新下载次数
    mysqli_query($link,"update downloads set downloads=downloads+1 where id=‘$id‘");
    //下载文件
    $file = @ fopen($myfile, "r");
    header("Content-type: application/octet-stream");
    header("Content-Disposition: attachment; filename=" .$filename );
    while (!feof($file)) {
        echo fread($file, 50000);
    }
    fclose($file);
    exit;
}else{
    echo ‘文件不存在!‘;
}
时间: 2024-11-02 21:54:28

PHP+Mysql+jQuery实现文件下载次数统计的相关文章

PHP+Mysql统计文件下载次数实例

PHP+Mysql统计文件下载次数实例,实现的原理也很简单,是通过前台点击链接download.php传参id,来更新点击次数. 获取文件列表: <?php require 'conn.php'; $query = mysql_query("SELECT * FROM downloads"); $lists = array(); while ($row = mysql_fetch_assoc($query)) { $lists[] = $row; } ?> 读取文件列表,并

PHP+Mysql+jQuery实现中国地图区域数据统计(raphael.js)

使用过百度统计或者cnzz统计的童鞋应该知道,后台有一个地图统计,不同访问量的省份显示的颜色也不一样,今天我将带领大家开发一个这样的案例.上一篇<使用raphael.js绘制中国地图>文章中,我给大家介绍了如何使用raphael.js绘制中国地图,今天我要给大家介绍在实际应用中,如何把数据载入到地图中.本文结合实例,使用PHP+Mysql+jQuery实现中国地图各省份数据统计效果. 本例以统计某产品在各省份的活跃用户数为背景,数据来源于mysql数据库,根据各省份的活跃用户数,分成不同等级,

PHP+Mysql+jQuery实现中国地图区域数据统计

使用过百度统计或者cnzz统计的童鞋应该知道,后台有一个地图统计,不同访问量的省份显示的颜色也不一样,今天我将带领大家开发一个这样的案例.上一篇<使用raphael.js绘制中国地图>文章中,我给大家介绍了如何使用raphael.js绘制中国地图,今天我要给大家介绍在实际应用中,如何把数据载入到地图中.本文结合实例,使用PHP+Mysql+jQuery实现中国地图各省份数据统计效果. 本例以统计某产品在各省份的活跃用户数为背景,数据来源于mysql数据库,根据各省份的活跃用户数,分成不同等级,

spark 省份次数统计实例

//统计access.log文件里面IP地址对应的省份,并把结果存入到mysql package access1 import java.sql.DriverManager import org.apache.spark.broadcast.Broadcast import org.apache.spark.{SparkConf, SparkContext} object AccessIp { def main(args: Array[String]): Unit = { //new sc va

scala实战之spark用户在线时长和登录次数统计实例

接触spark后就开始学习scala语言了,因为有一点python和java的基础学习起来还行,今天在这里把我工作中应用scala编程统计分析用户行为日志的实例和大家分析一下,我这里主要讲一下用户的在线时长统计和登录次数统计算法实现过程. 第一步 编程环境:首先你得有spark安装包 你可以先不用本地安装spark,但是可以通过import spark-assembly-1.6.2-hadoop2.6.0.jar包来完成程序调试 另外需要scala的运行环境,我用的版本:scala-sdk-2.

MySql 按周/月/日统计数据的方法

知识关键词:DATE_FORMAT select DATE_FORMAT(create_time,'%Y%u') weeks,count(caseid) count from tc_case group by weeks; select DATE_FORMAT(create_time,'%Y%m%d') days,count(caseid) count from tc_case group by days; select DATE_FORMAT(create_time,'%Y%m') month

MySQL查询重复出现次数最多的记录

MySQL查询重复出现次数最多的记录 http://database.51cto.com/art/201011/235139.htm 2010-11-25 14:40 佚名 互联网 字号:T | T 对于MySQL数据库来说,查询永远是最重要的功能,下文就教您查询重复出现次数最多的记录的方法,供您借鉴参考. AD:51CTO移动APP安全沙龙!马上要爆满,手慢没座位! MySQL查询的方法很多,下面为您介绍的MySQL查询语句用于实现查询重复出现次数最多的记录,对于学习MySQL查询有很好的帮助

mysql+thinkphp +amcharts 完成图表统计功能

思路:从mysql数据库查询数据,经过thinkphp 后端控制器做逻辑处理,返回给前端,前端调用阿妈charts 插件 1.数据查询: public function order($time='',$radio=1){ if($time== ''){ $time = Date("Y"); } $bt = $time."-01-01 00:00:00"; $et = (string)((int)$time+1)."-01-01 00:00:00"

2018-08-10期 MapReduce实现双色球近10年每个号码中奖次数统计

package cn.itcast.bigdata.shsq; import java.io.IOException; import org.apache.commons.lang.StringUtils; import org.apache.hadoop.io.LongWritable; import org.apache.hadoop.io.Text; import org.apache.hadoop.mapreduce.Mapper; /** * MapReduce实现双色球近10年每个号