sqlite - php讀取遠程圖片儲存到本地

來源:互聯網
上載者:User
$handle = fopen('http://...圖片地址', 'r');$content = '';while(!feof($handle)){    $content .= fread($handle, 8080);}fclose($handle);$sql = "INSERT INTO chat_msg (data) VALUES('$content')";

上文代碼insert的時候不能儲存。

回複內容:

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

上文代碼insert的時候不能儲存。

你確定要存成base64.....
你說的本地應該是存在某個檔案夾吧
直接用write

為什麼要存圖片,不存地址呢

要使用二進位儲存

可能是你$content的大小超出了data欄位設定(或預設)的大小

資料庫儲存圖片不都是儲存一個圖片地址嗎???

依照上面的代碼$content是二進位檔案了,strlen長度估計都要超2萬了,估計超出你資料庫插入欄位的限制了吧.
我覺得你應該是先把圖片下載儲存到本地,資料庫只要儲存圖片路徑就行.暫時沒見到直接把檔案放到資料的做法.

我擦,你這種寫法我不得不說很SB。
請別生氣,聽我慢慢道來。

$data = file_get_contents('圖片網址');file_put_contents('圖片儲存的路徑和檔案名稱');// 如file_put_contents('./download/test.jpg',$data);//然後,資料庫儲存這個圖片的儲存地址就可以了,例如:$sql = "INSERT INTO chat_msg (data) VALUES('download/test.jpg')";

當然,這個檔案名稱每儲存一個檔案的檔案名稱是不一樣的,你自己想辦法進行命名,這個我就不多做解釋。

  • 相關文章

    聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.