php将图片以二进制存到mysql中的方法
很奇怪,直接用file_get_contents存入数据库成功后,结果读取的时候图片不能显示,后来解决方法是什么!!是用了下base64编码。。。不多说直接上图。 1.这是upload.php ? php include ('./conn.php' ); if ( $_POST ['submit' ]) { if ( $_FILES ['image']['
很奇怪,直接用file_get_contents存入数据库成功后,结果读取的时候图片不能显示,后来解决方法是什么!!是用了下base64编码。。。不多说直接上图。
1.这是upload.php
<span>php </span><span>include</span>('./conn.php'<span>); </span><span>if</span> (<span>$_POST</span>['submit'<span>]) { </span><span>if</span> (<span>$_FILES</span>['image']['size'<span>]) { </span><span>$names</span> = <span>$_FILES</span>['image']['name'<span>]; </span><span>$arr</span> = <span>explode</span>('.', <span>$names</span><span>); </span><span>$name</span> = <span>$arr</span>[0]; <span>//</span><span>图片名称</span> <span>$date</span> = <span>date</span>('Y-m-d H:i:s'); <span>//</span><span>上传日期</span> <span>$fp</span> = <span>fopen</span>(<span>$_FILES</span>['image']['tmp_name'], 'rb'<span>); </span><span>$type</span> = <span>$_FILES</span>['image']['type'<span>]; </span><span>$file_uploads</span> = <span>file_get_contents</span>(<span>$_FILES</span>['image']['tmp_name'<span>]); </span><span>$file_uploads</span> = <span>base64_encode</span>(<span>$file_uploads</span><span>); </span><span>if</span> (!<span>$fp</span><span>) { showInfo(</span>'读取图片失败!'<span>); } </span><span>else</span><span> { </span><span>if</span> (<span>$image</span><span>) { </span><span>$q</span> = "insert into image (name, pic, type, date) values ('<span>$name</span>','<span>$file_uploads</span>','<span>$type</span>','<span>$date</span>')"<span>; </span><span>$result</span> = <span>mysql_query</span>(<span>$q</span><span>); </span><span>if</span> (<span>$result</span><span>) { showInfo(</span>'上传成功!'<span>); } </span><span>else</span><span> { showInfo(</span>'上传失败!'<span>); } </span><span>mysql_close</span>(<span>$link</span><span>); } </span><span>else</span><span> { showInfo(</span>'请选择要上传的文件!'<span>); } } } </span><span>else</span><span> { showInfo(</span>'请选择要上传的文件!'<span>); } } </span><span>function</span> showInfo(<span>$info</span><span>) { </span><span>echo</span> "<meta http-equiv='\"Content-Type\"' content='\"text/html;' charset='utf-8\"'>"<span>; </span><span>echo</span> "<meta http-equiv="refresh" content="1;url=show.php">"<span>; </span><span>echo</span> ""<span>; </span><span>echo</span> "" . <span>$info</span> . "……"<span>; </span><span>echo</span> ""<span>; } </span>?>
2.image.php用于从数据库中读取图片
<span>php </span><span>include</span>('./conn.php'<span>); </span><span>$id</span> = <span>$_GET</span>['id'<span>]; </span><span>$sql</span> = "select * from image where id='<span>$id</span>'"<span>; </span><span>$result</span> = <span>mysql_query</span>(<span>$sql</span><span>); </span><span>if</span> (!<span>$result</span><span>) </span><span>die</span>("读取图片失败!"<span>); </span><span>$num</span> = <span>mysql_num_rows</span>(<span>$result</span><span>); </span><span>if</span> (<span>$num</span> ) <span>die</span>("暂无图片"<span>); </span><span>$obj</span> = <span>mysql_fetch_object</span>(<span>$result</span><span>); </span><span>$data</span> = <span>base64_decode</span>(<span>$obj</span>->pic); <span>//</span><span>Base64解码</span> <span>$type</span> = <span>mysql_result</span>(<span>$result</span>, 0, 'type'<span>); </span><span>header</span>("Content-type: <span>$type</span>"<span>); </span><span>echo</span> <span>$data</span><span>; </span>?>
3.show.php显示和上传图片
<span>php </span><span>include</span>('./conn.php'<span>); </span>?> span>PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <meta http-equive="Content-Type" content="text/html" charset="utf-8"> <title> </title>
![]()
php
echo $row['name'];
?>
php
echo $row['date'];
?>
|
最后运行结果:
总结:网上的都是坑爹么?谁有其他不用base64编码的方法能否告知?

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











PHP 8.4 では、いくつかの新機能、セキュリティの改善、パフォーマンスの改善が行われ、かなりの量の機能の非推奨と削除が行われています。 このガイドでは、Ubuntu、Debian、またはその派生版に PHP 8.4 をインストールする方法、または PHP 8.4 にアップグレードする方法について説明します。

Visual Studio Code (VS Code とも呼ばれる) は、すべての主要なオペレーティング システムで利用できる無料のソース コード エディター (統合開発環境 (IDE)) です。 多くのプログラミング言語の拡張機能の大規模なコレクションを備えた VS Code は、

MySQL 8.4 (2024 年時点の最新の LTS リリース) で導入された主な変更の 1 つは、「MySQL Native Password」プラグインがデフォルトで有効ではなくなったことです。さらに、MySQL 9.0 ではこのプラグインが完全に削除されています。 この変更は PHP および他のアプリに影響します

このチュートリアルでは、PHPを使用してXMLドキュメントを効率的に処理する方法を示しています。 XML(拡張可能なマークアップ言語)は、人間の読みやすさとマシン解析の両方に合わせて設計された多用途のテキストベースのマークアップ言語です。一般的にデータストレージに使用されます

文字列は、文字、数字、シンボルを含む一連の文字です。このチュートリアルでは、さまざまな方法を使用してPHPの特定の文字列内の母音の数を計算する方法を学びます。英語の母音は、a、e、i、o、u、そしてそれらは大文字または小文字である可能性があります。 母音とは何ですか? 母音は、特定の発音を表すアルファベットのある文字です。大文字と小文字など、英語には5つの母音があります。 a、e、i、o、u 例1 入力:string = "tutorialspoint" 出力:6 説明する 文字列「TutorialSpoint」の母音は、u、o、i、a、o、iです。合計で6元があります

あなたが経験豊富な PHP 開発者であれば、すでにそこにいて、すでにそれを行っていると感じているかもしれません。あなたは、運用を達成するために、かなりの数のアプリケーションを開発し、数百万行のコードをデバッグし、大量のスクリプトを微調整してきました。

CMSはコンテンツマネジメントシステムの略称です。これは、ユーザーが高度な技術知識を必要とせずにデジタル コンテンツを作成、管理、変更できるようにするソフトウェア アプリケーションまたはプラットフォームです。 CMS を使用すると、ユーザーはコンテンツを簡単に作成および整理できます

PHPがMySQLに接続した後、ページは空白になり、DIE()関数が失敗する理由。 PHPとMySQLデータベースの間の接続を学習するとき、あなたはしばしばいくつかの混乱することに遭遇します...
