这是我的index.php:
<?php
require_once('includes/settings.php');
require_once('includes/functions/images.php');
$_SESSION['userisonpage'] = true;在设置文件中有session_start和一些类似数据库连接的东西:
<?php
error_reporting(0);
// ini_set('session.gc_maxlifetime', 180);
session_start();现在我有了一个image.php,它在特定的重写规则之后接收GET-Parameter。
RewriteRule ^images/items/(.+)$ /index.php?image=$1 [L,QSA]到目前一切尚好。然后,image.php会在加载映像之前检查是否设置了$_SESSION‘’userisonpage‘-sessionvariable。我不知道为什么,但结果总是假的,并显示"hotlink.jpg"-file -即使图像是在网页中加载的。
<?php
if(isset($_GET['image'])){
$path = '/data/web/123456/html/abc/images/';
$file = trim($_GET['image']);
if(file_exists($path.'items/'.$file)){
if($_SESSION['userisonpage'] === true){
echo file_get_contents($path.'items/'.$file);
}else{
echo file_get_contents($path.'hotlink.jpg');
}
}else{
header('location: https://abc.de/');
}
die;
}
?>编辑#1
好的,我发现当我用URL调用图像时
http://abc.de/images/items/test.jpg当我使用URL调用相同的图像时,会话ID始终是另一个
http://abc.de/?image=test.jpg会话ID保持不变。
因此,Sessions和Mod重写之间似乎存在问题。
编辑#2:
我现在发现,当我使用此URL调用图像时
http://abc.de/images/items/test.php // <-- !!! PHP-extension !!!并将get参数中的.php替换为.jpg
if(isset($_GET['image'])){
$path = '/data/web/123456/html/abc/images/';
$file = trim($_GET['image']);
$file = str_replace('.php', '.jpg', $file); // <-- replace the extension
if(file_exists($path.'items/'.$file)){它还会根据需要加载会话变量和图像。
发布于 2019-01-14 21:59:18
部分解决方案
您需要在重写器规则中添加完整 URL:
RewriteRule ^images/items/(.+)$ https://abc.de/index.php?image=$1 [L]然后,脚本将识别会话变量。您还可以在img-src属性中放入图像的“漂亮”(未重写)路径。
https://abc.de/images/items/test.jpg但是:如果你在一个新的标签中打开图像(单独的图像),它将显示“丑陋”(重写)路径
https://abc.de/index.php?image=test.jpghttps://stackoverflow.com/questions/54177035
复制相似问题