PHP:如何缩短网址+从数据库中获取数据

标签 php mysql file-upload download download-manager

我正在尝试为我的文件上传脚本制作自动下载页面 url 缩短器。

向数据库插入数据的部分示例:

function RandomString($length) {
    $key = "";
    $keys = array_merge(range(0,9), range('a', 'z'), range('A', 'Z'));

    for($i=0; $i < $length; $i++) {
        $key .= $keys[array_rand($keys)];
    }
    return $key;
}

try {
    $db = new PDO('mysql:host='. DB_HOST .';dbname=' . DB_DATABASE .';charset=utf8', DB_USER, DB_PASSWORD);
    $db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_WARNING);

    $download_code = RandomString(5);
    $query = "INSERT INTO user_uploads(User_Id, Name, File, DownloadCode) VALUES('".$USER_ID."','".$upload_name."','".$upload_file."','".$download_code."'")";
    $link = $db->prepare($query);
    if($link->execute()){
        header("location: upload-success");
        exit();
    }
    $db = null;
}catch(PDOException $e) {
    die($e->getMessage());
}

所以,假设下载代码是“KD9UI”

如何制作这样的下载页面? http://domain.com/KD9UI

当访问者转到该 url 时,页面通过此下载代码从数据库中获取数据并向访问者打印文件详细信息。

家庭帮助会很好 :)

最佳答案

将 id 传递给上传成功页面。

像这样:

header('Location: upload-success?download_code='.$download_code);

并将 domain.com/id 重定向到 domain.com/download.php?download_code=id

像这样:

RewriteRule ^upload-success$ upload_success.php [L,NC]
/*
other rewrite rules..
this rule must be at last rule
becuse another rules may be exists too and it's domain.com/(...)
*/
RewriteRule ^(.+?)$ download.php?download_code=$1 [L,NC]

关于PHP:如何缩短网址+从数据库中获取数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15729026/

相关文章:

php上传文件错误代码3

java - InputStream 无限循环

php - 事务在 laravel 中不起作用

php - SQL 插入跳过条目

PHP OpCache 优化

mysql - 使用现有的 mysql 数据库创建 ActiveAdmin 项目?

file-upload - 为什么 RackMultipart* 文件会保留在我的 Rails/tmp 目录中?

php - 使用 PHP 解析原始 PDF 数据以创建 PDF

mysql - 确定 RDS 中断的原因

mysql - 将日期字符串转换为 MYSQL 中正确的日期戳(我需要 sql 代码,而不是 php)