将图像从FTP检索到网页

问题描述 投票:4回答:3

我的ftp服务器中有一个包含多个图像的文件夹。我正在尝试访问并在网页中显示这些图像

<img src="ftp://my_ftp_ip_address/Images/imagename.jpg"/>

但是它要求输入FTP用户名和密码。我怎样才能做到这一点?也可以使用Java做同样的事情吗?

html ftp webpage imagesource
3个回答
4
投票

使用最新版本的Web浏览器(Chrome 59Firefox 61),您甚至无法使用ftp:// URL来检索图像。无论如何,它从来都不是一个好的解决方案。


正确的解决方案是通过您的网络服务器路由图像,不仅隐藏凭据,还隐藏图像的原始来源。

创建一个充当图像源的脚本(PHP或您使用的任何其他脚本)(您将在<img src=...>属性中使用它。脚本将通过从FTP服务器下载来“生成”图像。

在PHP中实现这样一个脚本最简单的方法(比如image.php)是:

<?

header('Content-Type: image/jpeg');

echo file_get_contents('ftp://username:[email protected]/path/image.jpg');

然后你在HTML中使用它:

<a src="image.php" />

(假设image.php与HTML页面位于同一文件夹中)


该脚本使用FTP URL wrappers。如果您的Web服务器上不允许这样做,您必须更加努力地使用FTP功能。见PHP: How do I read a file from FTP server into a variable?


虽然对于一个非常正确的解决方案,您应该提供一些与该文件相关的HTTP头,例如Content-LengthContent-TypeContent-Disposition。为此,请参阅Download file via PHP script from FTP server to browser with Content-Length header without storing the file on the web server


2
投票

您告诉浏览器使用ftp协议访问图像,这就是它尝试登录的原因。

将ftp://更改为http://(或https://如果使用ssl)以访问图像。

您可以在场景中为图像添加用户名和密码,但这样每个人都可以查看您的代码并登录到您的ftp服务器...不太安全;)


-1
投票

您可以尝试修改您的src属性,如下所示:

<img src="ftp://username:password@my_ftp_ip_address/Images/imagename.jpg"/>
© www.soinside.com 2019 - 2024. All rights reserved.