php - 在 PHP 中使用 imagejpeg 显示图像时出现问题

标签 php mysql

我在使用水印脚本时遇到问题。下面是脚本:

if (isset($_GET['imgid'])) {
    include "../mysql_connect.php";
    $imgid = $_GET['imgid'];
    $query = "SELECT * FROM img_ref WHERE id='$imgid'";
    $result = mysql_query($query) or die(mysql_error());
    $row = mysql_fetch_array($result);
    $imagesource = "../ajax_uploads/$row[submitter_id]-uploads/$row[filename]";
} else {        
    $imagesource =  "../ajax_uploads/" . $_GET['path'];
}
$info = pathinfo($imagesource); 
$filetype = $info['extension']; 
if($filetype == "gif")  $image = @imagecreatefromgif($imagesource);  
if($filetype == "jpg")  $image = @imagecreatefromjpeg($imagesource);  
if($filetype == "png")  $image = @imagecreatefrompng($imagesource);  
if (!$image) die(); 
$watermark = @imagecreatefrompng('../images/watermark.png');
// This is the key. Without ImageAlphaBlending on, the PNG won't render correctly.
imagealphablending($image, true);
$imagewidth = imagesx($image); 
$imageheight = imagesy($image);  
$watermarkwidth =  imagesx($watermark); 
$watermarkheight =  imagesy($watermark); 
$startwidth = (($imagewidth - $watermarkwidth)/2); 
$startheight = (($imageheight - $watermarkheight)/2); 
imagecopy($image, $watermark,  $startwidth, $startheight, 0, 0, $watermarkwidth, $watermarkheight); 
imagejpeg($image);
imagedestroy($image); 
imagedestroy($watermark); 

现在,如果我传递“路径”变量,一切都会正常工作,并且图像会按照我的想象正确显示。但是,当我尝试传递 imgid 值并从数据库检索路径时,图像以原始数据形式显示在屏幕上 - 而不是图像。

我尝试指定标题

header("Content-type: image/jpeg");

但这并没有帮助。这似乎不是文件夹权限的问题,就好像我使用数据库中的引用指定路径名一样,它工作得很好。似乎包含第一个“if”部分似乎会破坏输出,而我不知道为什么。

有人可以帮我解释一下吗?

谢谢您,

更新

好吧,不知何故,它开始使用“Header(”Content-type: image/jpeg”);”放置在 PHP 文件的顶部,因此如果我直接转到该文件并输入 GET id,我会得到返回的图片 - 这很好(但不知道发生了什么变化)。

但是,在其他地方显示这张图片时,我似乎仍然遇到问题。我使用 jquery 插件“fancybox”来调用图片。当它显示图像时,它仍然显示原始数据。如果我使用该路径,它会显示正常 - 只是出于某种原因,在使用 GET id 选项时会显示原始数据。我仍在研究它,但感谢迄今为止的建议。

最佳答案

似乎使用了标题

header("Content-type: image/jpeg");

似乎可以让它显示为图像 - 但由于某种原因它不能与 fancybox 一起使用。我查看了 API,并强制 fancybox 意识到它是一个图像:

$.fancybox({
            'href':'processes/process_watermark.php?imgid=' + id,
            'type':'image'
        });

这使其正确显示。

感谢大家的帮助 - 以及所有提醒我注意 SQL 攻击的评论。

关于php - 在 PHP 中使用 imagejpeg 显示图像时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/4073633/

相关文章:

mysql - 如果条件为真,则在 MySQL 存储过程中运行查询

php - 数组中的复选框没有值

php - 将 JSON 数组转换为 JSON 格式

php - 按日期顺序在高级自定义字段中发布对象

php - PHP 中的 mysqli - bind_result 总是返回 null

php - Smarty中如何获取COOKIE

php - mysql_affected_rows() 为 UPDATE 语句返回 0,即使实际上发生了更新

php - 我如何使用面向对象编程改进此代码?

php - 一种将用户重定向到仪表板的简单方法

java - 如何将此代码转换为 prepared-statement 或 jdbc 中的语句?