Home  >  Article  >  Backend Development  >  sqlite - php读取远程图片保存到本地

sqlite - php读取远程图片保存到本地

WBOY
WBOYOriginal
2016-06-06 20:23:231130browse

<code>$handle = fopen('http://...图片地址', 'r');
$content = '';
while(!feof($handle)){
    $content .= fread($handle, 8080);
}
fclose($handle);
$sql = "INSERT INTO chat_msg (data) VALUES('$content')";
</code>

上文代码insert的时候不能保存。

回复内容:

<code>$handle = fopen('http://...图片地址', 'r');
$content = '';
while(!feof($handle)){
    $content .= fread($handle, 8080);
}
fclose($handle);
$sql = "INSERT INTO chat_msg (data) VALUES('$content')";
</code>

上文代码insert的时候不能保存。

你确定要存成base64.....
你说的本地应该是存在某个文件夹吧
直接用write

为什么要存图片,不存地址呢

要使用二进制存储

可能是你$content的大小超出了data字段设置(或默认)的大小

数据库存储图片不都是存储一个图片地址吗???

依照上面的代码$content是二进制文件了,strlen长度估计都要超2万了,估计超出你数据库插入字段的限制了吧.
我觉得你应该是先把图片下载保存到本地,数据库只要存储图片路径就行.暂时没见到直接把文件放到数据的做法.

我擦,你这种写法我不得不说很SB。
请别生气,听我慢慢道来。

<code>$data = file_get_contents('图片网址');
file_put_contents('图片存储的路径和文件名');// 如file_put_contents('./download/test.jpg',$data);
//然后,数据库存储这个图片的存储地址就可以了,例如:
$sql = "INSERT INTO chat_msg (data) VALUES('download/test.jpg')";</code>

当然,这个文件名每存储一个文件的文件名是不一样的,你自己想办法进行命名,这个我就不多做解释。

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn