質問

ファイルがダウンロードされた回数をカウントするカウンターを表示するにはどうすればよいですか?前に見たことがあります。 「450回ダウンロード済み」。ありがとう。

役に立ちましたか?

解決

ユーザーにファイルを直接ダウンロードさせないでください。次のようなスクリプトを使用してください...

<?php

   $file = 

ユーザーにファイルを直接ダウンロードさせないでください。次のようなスクリプトを使用してください...

<*>REQUEST['file']; $dldir = "downloads/"; if ( (file_exists($dldir.$file) && // file exists (strpos($file, "../") === false) && // prevent an attacker from switching to a parent directory ) { header('Content-type: '.mime_content_type($dldir.file)); header("Content-Transfer-Encoding: binary"); header("Content-Length: " . filesize($dldir.$file) ."; "); header('Content-Disposition: attachment; filename="'.$file.'"'); echo file_get_contents($dldir.$file); /** Update the counter here, e.g. by using mysql **/ } else { die("File not found"); } ?>

他のヒント

PHPでそれを行うには、PHPスクリプトでダウンロードを制御する必要があります。基本的には、次の2行の擬似コードになります。

set_number_of_downloads(get_number_of_downloads() + 1);
readfile($file_being_downloaded);

そこに行きます。 また、永続性のためにMySQLを使用する場合は、 this ソリューションがあります。

Apacheでは、ファイルが要求されたときにmod_rewriteでデータベースを更新できます。これには送信の速度という利点があり(sendfileを使用できます)、URLやディレクトリ構造を変更する必要はありません。

#!/usr/bin/perl
$| = 1;
$dbh = DBI->connect("dbi:mysql:database=; host=localhost; user=; password=")
or die "Connecting from PHP to MySQL database failed: $DBI::errstr";
while (<STDIN>) {
    $dbh->query(... update database ...);
    print 

Apacheでは、ファイルが要求されたときにmod_rewriteでデータベースを更新できます。これには送信の速度という利点があり(sendfileを使用できます)、URLやディレクトリ構造を変更する必要はありません。

<*>

http://httpd.apache.org/docs/2.2 /mod/mod_rewrite.html#rewriteengine

; }

http://httpd.apache.org/docs/2.2 /mod/mod_rewrite.html#rewriteengine

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top