本文目錄一覽:
PHP實現上傳圖片到數據庫並顯示輸出的方法
本文實例講述了PHP實現上傳圖片到數據庫並顯示輸出的方法。分享給大家供大家參考,具體如下:
1.
創建數據表
CREATE
TABLE
ccs_image
(
id
int(4)
unsigned
NOT
NULL
auto_increment,
description
varchar(250)
default
NULL,
bin_data
longblob,
filename
varchar(50)
default
NULL,
filesize
varchar(50)
default
NULL,
filetype
varchar(50)
default
NULL,
PRIMARY
KEY
(id)
)engine=myisam
DEFAULT
charset=utf8
2.
用於上傳圖片到服務器的頁面
upimage.html
!doctype
html
html
lang=”en”
head
meta
charset=”UTF-8″
meta
name=”viewport”
content=”width=device-width,
user-scalable=no,
initial-scale=1.0,
maximum-scale=1.0,
minimum-scale=1.0″
meta
http-equiv=”X-UA-Compatible”
content=”ie=edge”
style
type=”text/css”
*{margin:
1%}
/style
titleDocument/title
/head
body
form
method=”post”
action=”upimage.php”
enctype=”multipart/form-data”
描述:
input
type=”text”
name=”form_description”
size=”40″
input
type=”hidden”
name=”MAX_FILE_SIZE”
value=”1000000″
br
上傳文件到數據庫:
input
type=”file”
name=”form_data”
size=”40″br
input
type=”submit”
name=”submit”
value=”submit”
/form
/body
/html
3.
處理圖片上傳的php
upimage.php
?php
if
(isset($_POST[‘submit’]))
{
$form_description
=
$_POST[‘form_description’];
$form_data_name
=
$_FILES[‘form_data’][‘name’];
$form_data_size
=
$_FILES[‘form_data’][‘size’];
$form_data_type
=
$_FILES[‘form_data’][‘type’];
$form_data
=
$_FILES[‘form_data’][‘tmp_name’];
$dsn
=
‘mysql:dbname=test;host=localhost’;
$pdo
=
new
PDO($dsn,
‘root’,
‘root’);
$data
=
addslashes(fread(fopen($form_data,
“r”),
filesize($form_data)));
//echo
“mysqlPicture=”.$data;
$result
=
$pdo-query(“INSERT
INTO
ccs_image
(description,bin_data,filename,filesize,filetype)
VALUES
(‘$form_description’,’$data’,’$form_data_name’,’$form_data_size’,’$form_data_type’)”);
if
($result)
{
echo
“圖片已存儲到數據庫”;
}
else
{
echo
“請求失敗,請重試”;
注:圖片是以二進制blob形式存進數據庫的,像這樣
4.
顯示圖片的php
getimage.php
?php
$id
=2;//
$_GET[‘id’];
為簡潔,直接將id寫上了,正常應該是通過用戶填入的id獲取的
$dsn=’mysql:dbname=test;host=localhost’;
$pdo=new
PDO($dsn,’root’,’root’);
$query
=
“select
bin_data,filetype
from
ccs_image
where
id=2″;
$result
=
$pdo-query($query);
$result=$result-fetchAll(2);
//
var_dump($result);
$data
=
$result[0][‘bin_data’];
$type
=
$result[0][‘filetype’];
Header(
“Content-type:
$type”);
echo
$data;
到瀏覽器查看已經上傳的圖片,看是否可以顯示
是沒有問題的,證明圖片已經以二進制的形式存儲到數據庫了
更多關於PHP相關內容感興趣的讀者可查看本站專題:《php+mysql數據庫操作入門教程》、《php+mysqli數據庫程序設計技巧總結》、《php面向對象程序設計入門教程》、《PHP數組(Array)操作技巧大全》、《php字符串(string)用法總結》及《php常見數據庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
您可能感興趣的文章:php實現上傳圖片保存到數據庫的方法php上傳圖片存入數據庫示例分享php上傳圖片到指定位置路徑保存到數據庫的具體實現php中如何將圖片儲存在數據庫里php下將圖片以二進制存入mysql數據庫中並顯示的實現代碼php
從數據庫提取二進制圖片的處理代碼php將圖片保存入mysql數據庫失敗的解決方法php將圖片文件轉換成二進制輸出的方法php圖片的二進制轉換實現方法
php 編寫 實現上傳圖片至服務器的函數
?php
class FileUpload{
private $filepath; //指定上傳文件保存的路徑
private $allowtype=array(“gif”,”jpg”,”jpeg”,”png”);//允許上傳文件的類型
private $maxsize=1000000;//允許上傳文件的最大值
private $israndname=true;//是否隨機重命名,
private $originName;//源文件名字
private $tmpFileName;//臨時文件名字
private $fileType;//上傳後的文件類型,主要是文件後綴名
private $fileSize;//文件尺寸
private $newFileName;//新文件名字
private $errorName=0;//錯誤號
private $errorMess=””;//用來提供錯誤報告
//用於對上傳文件初始化
//指定上傳路徑 2·允許的類型 3·限制大小 4·是否使用隨機文件名稱
//讓用戶可以不用換位置傳參數,後面參數給值不用按照位置或者必須有值
function __construct($options=array()){
foreach($options as $key=$val){
$key = strtolower($key);
//查看用戶參數中的數組下標是否和成員屬性名相同
//get_class_vars(get_class($this))得到類屬性的數組
//如果$key下標不在這個類屬性的數組中,則退出for循環
if (!in_array($key,get_class_vars(get_class($this)))){
continue;
}
$this – setOption($key,$val);
}
}
private function setOption($key,$val){
//讓實例化後獲取過來的數組下標 = 數組下標的值,這裡即為構造函數初始化
//構造函數中調用,等於把所有屬性初始化,將來可以直接訪問
$this – $key=$val;
}
private function getError(){
$str=”上傳文件{$this-originName}時出錯”;
switch($this – errorNum){
case 4: $str.=”沒有文件被上傳”;
break;
case 3: $str.=”文件只有部分上傳”;
break;
case 2: $str.=”上傳文件超過了表單的值”;
break;
case 1: $str.=”上傳文件超過phpini的值”;
break;
case -1: $str.=”未允許的類型”;
break;
case -2: $str.=”文件過大上傳文件不能超過{$this-maxsize}字節”;
break;
case -3: $str.=”上傳文件失敗”;
break;
case -4: $str.=”建立存放上傳文件目錄失效,請重新上傳指定目錄”;
break;
case -5: $str.=”必須指定上傳文件的路徑”;
break;
default: $str.=”未知錯誤”;
}
return $str.’br’;
}
//用來檢查文件上傳路徑
private function checkFilePath(){
if(empty($this – filepath)){
$this – setOption(“errorNum”,-5);
return false;
}
if(!file_exists($this – filepath) || !is_writable($this – filepath)){
if(!@mkdir($this – filepath,0755)){
$this – setOption(“errorNum”,-4);
return false;
}
}
return true;
}
//用來檢查上傳文件尺寸大小
private function checkFileSize(){
if($this – fileSize $this -maxsize){
$this – setOption(“errorNum”,-2);
return false;
}else{
return true;
}
}
//用來檢查文件上傳類型
private function checkFileType(){
if(in_array(strtolower($this-fileType),$this – allowtype)){
return true;
}else{
//如果$this-fileType這個類型 不在$this – allowtype這個數組中,則把錯誤號變成-1
$this – setOption(“errorNum”,-1);
return false;
}
}
private function setNewFileName(){
if($this – israndname){
$this – setOption(“newFileName”,$this-preRandName());
}else{
$this – setOption(“newFileName”,$this – originName);
}
}
//用於檢查文件隨機文件名
private function preRandName(){
$fileName=date(“Ymdhis”).rand(100,999);
return $fileName.”.”.$this – fileType;
}
//用來上傳一個文件
function uploadFile($fileField){
//檢查文件路徑
$return = true;
if(!$this – checkFilePath()){
$this – errorMess=$this – getError();
return false;
}//獲取文件信息
$name = $_FILES[$fileField][‘name’];
$tmp_name = $_FILES[$fileField][‘tmp_name’];
$size = $_FILES[$fileField][‘size’];
$error = $_FILES[$fileField][‘error’];
if(is_array($name)){//判斷獲取過來的文件名字是否為數組
$errors=array();//如果為數組則設置為一個數組錯誤號
for($i=0;$icount($name);$i++){
//循環每個文件即每個類屬性賦值或者說初始化屬性值 或者初始化構造函數
if($this-setFiles($name[$i],$tmp_name[$i],$size[$i],$error[$i])){
if(!$this-checkFileSize() || !$this-checkFileType()){
//如果上面尺寸或者類型不對,則調用這個錯誤信息
$errors[$i]=$this-getError();
$return=false;
}
}else{
//這裡是
$error[]=$this-getError();
$return=false;
}
if(!$return)
$this-setFiles();
}
if($return){
$fileNames=array();
for($i=0;$icount($name);$i++){
if($this-setFiles($name[$i],$tmp_name[$i],$size[$i],$error[$i])){
$this-setNewFileName();
if(!$this-copyFile()){
$errors=$this-getError();
$return=false;
}else{
$fileNames[$i]=$this-newFileName;
}
}
}
$this-newFileName=$fileNames;
}
$this-errorMess=$errors;
return $return;
}else{
//看看$name,$tmp_name,$size,$error這些是否賦值成功 否則返回FALSE
if($this – setFiles($name,$tmp_name,$size,$error)){
//看看文件大小尺寸是否匹配,不匹配返回FALSE
if($this – checkFileSize() $this – checkFileType()){
//獲取新文件名
$this-setNewFileName();
if($this-copyFile()){
return true;
}else{
return false;
}
}else{
$return=false;
}
}else{
$return=false;
}
if(!$return){
$this – errorMess = $this -getError();
return $return;
}
}
}
function copyFile(){//將文件從臨時目錄拷貝到目標文件夾
if(!$this-errorNum){
//如果傳遞來的路徑有斜杠,則刪除斜杠再加上斜杠
//./upload+./
$filepath=rtrim($this-filepath,’/’).’/’;
//./upload+./+加上隨機後的新文件名和後綴
//這裡指創建一個新的$filepath.這個文件 像佔位符但是為空的
$filepath.=$this-newFileName;
//嘗試着把臨時文件$this-tmpFileName移動到$filepath下哪裡覆蓋原來的這個文件
if(@move_uploaded_file($this-tmpFileName,$filepath)){
return true;
}else{
$this-setOption(‘errorNum’,-3);
return false;
}
}else{
return false;
}
}
//這裡是為了其他剩餘的屬性進行初始化操作!
private function setFiles($name=””,$tmp_name=””,$size=0,$error=0){
//這裡給錯誤號賦值
$this – setOption(“errorNum”,$error);
//如果這裡有錯誤,直接返回錯誤
if ($error){
return false;
}
$this – setOption(“originName”,$name);//複製名字為源文件名
$this – setOption(“tmpFileName”,$tmp_name);
$arrstr = explode(“.”,$name);//按點分割文件名,
//取分割後的字符串數組最後一個 並轉換為小寫,賦值為文件類型
$this – setOption(“fileType”,strtolower($arrstr[count($arrstr)-1]));
$this – setOption(“fileSize”,$size);
return true;
}
//用來獲取上傳後的文件名
function getNewFileName(){
return $this – newFileName;
}
//上傳失敗,後則返回這個方法,就可以產看報告
function getErrorMsg(){
return $this – errorMess;
}
}
?
============================調用====================================
?php
require(“FileUpload.class.php”);
//這裡實例化後賦值為數組,數組的下標要對應類中屬性的值,否則不能傳遞值,可以不分先後但是必須一致
$up = new FileUpload(array(‘israndname’=’true’,”filepath”=”./upload/”,’allowtype’=array(‘txt’,’doc’,’jpg’,’gif’),”maxsize”=1000000));
echo ‘pre’;
if($up – uploadFile(“pic”)){
print_r($up – getNewFileName());
} else{
print_r($up – getErrorMsg());
}
echo ‘pre’;
?
——————-HTML————————-
html
head
meta http-quive=”content-type” content=”text/html;charset=utf-8″ /meta
/head
body
form action=”upload.php” method=”post” enctype=”multipart/form-data”
shoppic:input type=”file” name=”pic[]”br
input type=”hidden” name=”MAX_FILE_SIZE” value=”1000000″
input type=”submit” name=”sub” value=”添加商品”
/form
/body
/html
——————-或者HTML————————-
html
head
meta http-quive=”content-type” content=”text/html;charset=utf-8″ /meta
/head
body
form action=”upload.php” method=”post” enctype=”multipart/form-data”
//區別在這裡
shoppic:input type=”file” name=”pic[]”br
shoppic:input type=”file” name=”pic[]”br
shoppic:input type=”file” name=”pic[]”br
input type=”hidden” name=”MAX_FILE_SIZE” value=”1000000″
input type=”submit” name=”sub” value=”添加商品”
/form
/body
/html
=====================================================================
以上是自己總結的 還沒有怎麼精簡加工過,僅供參考
以上不止可以上傳圖片,可以上自定義任何文件
php如何實現上傳圖片文件,並替換
首先建立兩個文件: change.html 和 change.php
change.html 文件的表單代碼如下:
html
head
titlechange file example./title
meta charset=”UTF-8″
/head
body
form method=”post” action=”changefile.php” enctype=”multipart/form-data”
table border=0 cellspacing=0 cellpadding=0 align=center width=”100%”
tr
td width=55 height=20 align=”center”
input type=”hidden” name=”MAX_FILE_SIZE” value=”2000000″ /
文件:
/td
td
input name=”file” type=”file” /
input type=”submit” name=”submit” value=”submit” /
/td
/tr
/table
/form
/body
/html
這裡有幾個要注意的地方,首先看這句form method=”post” action=”change.php” enctype=”multipart/form-data”,這裡我們採用POST方法,個別瀏覽器還支持PUT方法,當然這需要對腳本進行修改,我並不建議這麼做。表單中必須設置enctype=”multipart/form-data,這樣,服務器就知道上傳文件帶有常規表單信息,記住,這個是必須設置的。此外還需要一個隱藏域來限制上傳文件的最大長度:input type=”hidden” name=”MAX_FILE_SIZE” value=”2000000″,這裡name必須設置成MAX_FILE_SIZE,其值就是上傳文件的最大長度,單位是B,這裡我限制成2M。再看這句:input name=”file” type=”file” value=”瀏覽” ,type=”file”說明了文件類型,這樣一個基本的上傳文件接口就完成了,接下來講講如何用PHP來處理上傳的文件,此外你的php.ini中設置的上傳文件最大長度可能會影響到你的實際上傳,請根據實際情況修改,另PHP的上傳是先傳到臨時目錄,在移至指定目錄的,了;臨時目錄的可根據需要修改,也可使用默認值……
以下為表單提交change.php文件代碼,來看看這個文件都有什麼:
?php
header(“content-type:text/html;charset=utf-8”);
/**
* @param string $oldfile 需要更換的文件名(包含具體路徑名)
*/
function changeFile($oldfile){
$newfile = $_FILES[‘file’][‘name’];//獲取上傳文件名
$fileclass = substr(strrchr($newfile, ‘.’), 1);//獲取上傳文件擴展名,做判斷用
$type = array(“jpg”, “gif”, “bmp”, “jpeg”, “png”);//設置允許上傳文件的類型
if(in_array(strtolower($fileclass), $type)){
if(file_exists($oldfile)){
unlink($oldfile);
}
if(is_uploaded_file($_FILES[‘file’][‘tmp_name’])){//必須通過 PHP 的 HTTP POST 上傳機制所上傳的
if(move_uploaded_file($_FILES[‘file’][‘tmp_name’], $oldfile)){
//輸出圖片預覽
echo “center您的文件已經上傳完畢 上傳圖片預覽: /centerbrcenterimg src=’$oldfile’/center”;
}
}else{
echo “center上傳失敗,文件大於2M,請重新上傳!/center”;
}
}else{
$text = implode(“,”, $type);
echo “center您只能上傳以下類型文件:”, $text, “/centerbr”;
// echo “scriptalert(‘您只能上傳以下類型文件:$text’)/script”;
}
}
changeFile(“./files/1.png”);
剛看這些你可能有點暈~~,慢慢看,你就會發現其實這玩意SO EASY!!先講下原理,該程序以上傳圖片為例,先判斷文件類型是否為圖片格式,若是則上傳文件,接着上傳文件到並替換指定文件,成功上傳則輸出上傳的圖片預覽。這裡要對程序中一些函數作些解釋。先看substr(strrchr($newfile, ‘.’), 1), strrchar()函數有什麼作用呢,我舉個例子大家就知道,比如一個圖片文件 pic.jpg,我們用 strrchar()處理,strrchr(pic.jpg,’.’),它將返回.jpg,明白了嗎?該函數返回指定字符在該字符串最後出現的位置後的字符串。配合 substr() 我們就可以取到jpg,這樣我們就得到了文件的後綴名,來判斷上傳文件是否符合指定格式。本程序把指定的格式放在一個數組中,實際使用時可根據需要添加。
接着,我們調用判斷文件類型的函數,並將其轉化為小寫strtolower($_FILES[‘file’][‘name’]),這裡有個很關鍵的東東$_FILES ,這是個超級全局數組,保存了需要處理的表單數據,如果開啟了register_globals,也可以直接訪問,但這是不安全的。看剛才那個上傳接口input name=”file” type=”file”,根據這個表單名稱,我們可以得到很多信息:
$_FILES[‘file’][‘name’]– 得到文件名稱
$_FILES[‘file’][‘tmp_name’]–得到臨時存儲位置
$_FILES[‘file’][‘size’]–得到文件大小
$_FILES[‘file’][‘type’]–得到文件MIME類型
得到這些信息,就可以輕鬆判斷文件的信息了,是不是很方便?^_^,接下來還有一些函數需要了解,file_exists()–判斷指定目錄是否存在,不存在我們當然不能上傳(好像是廢話!),is_uploaded_file–判斷文件是否已經通過HTTP POST上傳,move_uploaded_file–將上傳文件移至指定目錄。成功上傳,我們就輸出預覽,否則輸出上傳失敗……
怎樣用php實現上傳圖片到數據庫
php實現上傳圖片保存到數據庫的方法。具體分析如下:
php 上傳圖片,一般都使用move_uploaded_file方法保存在服務器上。但如果一個網站有多台服務器,就需要把圖片發布到所有的服務器上才能正常使用(使用圖片服務器的除外)
如果把圖片數據保存到數據庫中,多台服務器間可以實現文件共享,節省空間。
首先圖片文件是二進制數據,所以需要把二進制數據保存在mysql數據庫。
mysql數據庫提供了BLOB類型用於存儲大量數據,BLOB是一個二進制對象,能容納不同大小的數據。
BLOB類型有以下四種,除存儲的最大信息量不同外,其他都是一樣的。可根據需要使用不同的類型。
TinyBlob 最大 255B
Blob 最大 65K
MediumBlob 最大 16M
LongBlob 最大 4G
數據表photo,用於保存圖片數據,結構如下:
CREATE TABLE `photo` (
`id` int(10) unsigned NOT NULL auto_increment,
`type` varchar(100) NOT NULL,
`binarydata` mediumblob NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=1 ;
upload_image_todb.php代碼如下:
?php
// 連接數據庫
$conn=@mysql_connect(“localhost”,”root”,””) or die(mysql_error());
@mysql_select_db(‘demo’,$conn) or die(mysql_error()); // 判斷action
$action = isset($_REQUEST[‘action’])? $_REQUEST[‘action’] : ”;
// 上傳圖片
if($action==’add’){
$image = mysql_escape_string(file_get_contents($_FILES[‘photo’][‘tmp_name’]));
$type = $_FILES[‘photo’][‘type’];
$sqlstr = “insert into photo(type,binarydata) values(‘”.$type.”‘,'”.$image.”‘)”;
@mysql_query($sqlstr) or die(mysql_error());
header(‘location:upload_image_todb.php’);
exit();
// 顯示圖片
}elseif($action==’show’){
$id = isset($_GET[‘id’])? intval($_GET[‘id’]) : 0;
$sqlstr = “select * from photo where id=$id”;
$query = mysql_query($sqlstr) or die(mysql_error());
$thread = mysql_fetch_assoc($query);
if($thread){
header(‘content-type:’.$thread[‘type’]);
echo $thread[‘binarydata’];
exit();
}
}else{
// 顯示圖片列表及上傳表單
?
!DOCTYPE HTML PUBLIC “-//W3C//DTD HTML 4.01 Transitional//EN” “”
html
head
meta http-equiv=”content-type” content=”text/html; charset=utf-8″
title upload image to db demo /title
/head
body
form name=”form1″ method=”post” action=”upload_image_todb.php” enctype=”multipart/form-data”
p圖片:input type=”file” name=”photo”/p
pinput type=”hidden” name=”action” value=”add”input type=”submit” name=”b1″ value=”提交”/p
/form
?php
$sqlstr = “select * from photo order by id desc”;
$query = mysql_query($sqlstr) or die(mysql_error());
$result = array();
while($thread=mysql_fetch_assoc($query)){
$result[] = $thread;
}
foreach($result as $val){
echo ‘pimg
src=”upload_image_todb.php?action=showid=’.$val[‘id’].’t=’.time().'”
width=”150″/p’;
}
?
/body
/html
?php
}
?
程序運行截圖和數據庫截圖:
原創文章,作者:GEAP,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/148186.html