首頁 > 後端開發 > php教程 > sqlite - php读取远程图片保存到本地

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

WBOY
發布: 2016-06-06 20:23:23
原創
1185 人瀏覽過

<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>
登入後複製

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

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板