使用jQuery更改图像src。 (在Firefox上不起作用)

时间:2013-10-23 13:11:44

标签: php jquery ajax captcha explorer

我正在写一个Ajax联系表单。我也写了自己的验证码。但我有一个关于刷新图像的问题。我这样写的是:

重新加载验证码:

<code>$("#captchaSection").load("captcha_p.php");</code>

captcha_p.php文件:

<code>< img src="captcha.php" name="imgCaptcha" /></code>

我已将这些行添加到capcha.php:

header("Cache-Control: no-cache, no-store, must-revalidate");
header('Content-type: image/png');
imagepng($im);
imagedestroy($im);

它适用于Google Chrome和Safari。但是在Firefox和资源管理器上不起作用。

谢谢!

1 个答案:

答案 0 :(得分:3)

似乎Firefox和IE正在缓存图像。要防止这种情况,请在URL和图像源中添加时间戳:

在Javascript中,您可以使用new Date().getTime()

$("#captchaSection").load("captcha_p.php?" + new Date().getTime());

在PHP中,您可以使用microtime()

< img src="captcha.php?<?php echo microtime(); ?>" name="imgCaptcha" />

我认为使用.load()加载包含图片的HTML没有任何好处。更改图像的src属性会更容易,例如:

// refresh captcha
$('img[name=imgCaptcha]').prop('src', 'captcha.php?' + new Date().getTime());