ajax實(shí)現(xiàn)本地上傳圖片至數(shù)據(jù)庫

修改頭像圖片這個功能相信大家都玩過城瞎,選擇圖片->移動框選擇圖片范圍->確認(rèn)拳魁,頭像就修改成功了。今天簡單教大家實(shí)現(xiàn)這個功能狐血!

首先我們先簡單布一下局统倒!

html代碼如下:

<button class="changehead">更改頭像

<div id="changeBox">

? ? <div class="changeBox-center">

? ? ? ? <div class="changeBox-left">

? ? ? ? ? ? <img class="demoImg">

? ? ? ? ? ? <div class="chooseBox">

? ? ? ? <div class="changeBox-right">

? ? ? ? ? ? <canvas id="myCan" width="120" height="120">

? ? ? ? ? ? <input type="file" class="but1">

? ? ? ? ? ? <button class="but2">截取

? ? ? ? ? ? <button class="but3">保存

? ? ? ? ? ? <button class="but4">取消

</div>

css代碼如下:

#changeBox{

width:100%;

? ? height:100%;

? ? position:fixed;

? ? display:none;

? ? left:0;

? ? top:0;

? ? background:rgba(51,51,51,0.6);

}

.changeBox-center{

width:600px;

? ? height:300px;

? ? margin:100px auto 0;

? ? position:relative;

}

.changeBox-left{

width:300px;

? ? height:300px;

? ? float:left;

? ? position:relative;

}

.demoImg{

width:300px;

? ? height:300px;

}

.chooseBox{

width:120px;

? ? height:120px;

? ? border:1px solid blue;

? ? position:absolute;

? ? left:1px;

? ? top:1px;

}

.changeBox-right{

width:300px;

? ? height:300px;

? ? float:right;

? ? background:#fff;

}

#myCan{

display:block;

? ? margin-left:90px;

}

.but1,.but2,.but3,.but4{

display:block;

? ? margin:20px auto 0;

}

選擇圖片

$('.changehead').click(function () {

$('#changeBox').show();

})

var myCan=document.getElementById('myCan');

var ctx=myCan.getContext("2d");

var demoImg=document.getElementsByClassName('demoImg')[0];

$('.but1').change(function () {

var file=$('.but1')[0].files[0];

? ? var reader=new FileReader();

? ? reader.onload=function (e) {

$('.demoImg').attr('src', e.target.result);

? ? };

? ? reader.readAsDataURL(file);

});

限制選擇框的移動范圍

var chooseBox=document.getElementsByClassName('chooseBox')[0];

chooseBox.onmousedown=function (e) {

var x=e.offsetX;

? ? var y=e.offsetY;

? ? document.onmousemove=function (e) {

var l=e.clientX-383-x;

? ? ? ? var t=e.clientY-100-y;

? ? ? ? if(l<0)l=0;

? ? ? ? if(l>178)l=178;

? ? ? ? if(t>178)t=178;

? ? ? ? if(t<0)t=0;

? ? ? ? chooseBox.style.left=l+'px';

? ? ? ? chooseBox.style.top=t+'px';

? ? }

document.onmouseup=function () {

document.onmousemove=false;

? ? ? ? document.onmouseup=false;

? ? }

}

將選擇框內(nèi)的圖片截取到畫布上

$('.but2').click(function () {

var w=parseFloat(demoImg.naturalWidth/300);

? ? var h=parseFloat(demoImg.naturalHeight/300);

? ? var x=$('.chooseBox').position().left*w;? ? ? ??

? ? var y=$('.chooseBox').position().top*h;

? ? ctx.drawImage(demoImg,x,y,120*w,120*h,0,0,120,120);

})

demoImg.naturalWidth為圖片的原始寬高!

w和h是圖片的寬高和顯示框的比值氛雪。

ctx.drawImage這個方法參數(shù)較多房匆,詳情請參考MDN

我們將截取的圖片打印出來看一下是這個樣子报亩,只顯示部分:


這就是圖片的base64格式浴鸿!

存至數(shù)據(jù)庫:

$('.but3').click(function () {

$.ajax({

url:'/Dphoto',

? ? ? ? data:{

? ? ? ? ? ? id:1,

? ? ? ? ? ? src:myCan.toDataURL()?

},

? ? ? ? success:function (res) {

? ? ? ? ? ? ?console.log(res);

? ? ? ? }

})

})

后臺接收id與src存至數(shù)據(jù)庫,這里省略.

結(jié)尾:

可以在數(shù)據(jù)庫看到弦追,圖片的base64格式已經(jīng)存進(jìn)了數(shù)據(jù)庫:


這里值得一提的是:在創(chuàng)建表時岳链。u_img這個字段的字段類型需要是longtext,不然會存不進(jìn)去!

在取數(shù)據(jù)的時候只要讓img標(biāo)簽的src屬性等于這個base64數(shù)據(jù)即可顯示出圖片劲件!

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末掸哑,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子零远,更是在濱河造成了極大的恐慌苗分,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,561評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件牵辣,死亡現(xiàn)場離奇詭異摔癣,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)纬向,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,218評論 3 385
  • 文/潘曉璐 我一進(jìn)店門择浊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人逾条,你說我怎么就攤上這事琢岩。” “怎么了师脂?”我有些...
    開封第一講書人閱讀 157,162評論 0 348
  • 文/不壞的土叔 我叫張陵担孔,是天一觀的道長。 經(jīng)常有香客問我危彩,道長攒磨,這世上最難降的妖魔是什么泳桦? 我笑而不...
    開封第一講書人閱讀 56,470評論 1 283
  • 正文 為了忘掉前任汤徽,我火速辦了婚禮,結(jié)果婚禮上灸撰,老公的妹妹穿的比我還像新娘谒府。我一直安慰自己拼坎,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,550評論 6 385
  • 文/花漫 我一把揭開白布完疫。 她就那樣靜靜地躺著泰鸡,像睡著了一般。 火紅的嫁衣襯著肌膚如雪壳鹤。 梳的紋絲不亂的頭發(fā)上盛龄,一...
    開封第一講書人閱讀 49,806評論 1 290
  • 那天,我揣著相機(jī)與錄音芳誓,去河邊找鬼余舶。 笑死,一個胖子當(dāng)著我的面吹牛锹淌,可吹牛的內(nèi)容都是我干的匿值。 我是一名探鬼主播,決...
    沈念sama閱讀 38,951評論 3 407
  • 文/蒼蘭香墨 我猛地睜開眼赂摆,長吁一口氣:“原來是場噩夢啊……” “哼挟憔!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起烟号,我...
    開封第一講書人閱讀 37,712評論 0 266
  • 序言:老撾萬榮一對情侶失蹤绊谭,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后汪拥,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體龙誊,經(jīng)...
    沈念sama閱讀 44,166評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,510評論 2 327
  • 正文 我和宋清朗相戀三年喷楣,在試婚紗的時候發(fā)現(xiàn)自己被綠了趟大。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,643評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡铣焊,死狀恐怖逊朽,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情曲伊,我是刑警寧澤叽讳,帶...
    沈念sama閱讀 34,306評論 4 330
  • 正文 年R本政府宣布,位于F島的核電站坟募,受9級特大地震影響岛蚤,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜懈糯,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,930評論 3 313
  • 文/蒙蒙 一涤妒、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧赚哗,春花似錦她紫、人聲如沸硅堆。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,745評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽渐逃。三九已至,卻和暖如春民褂,著一層夾襖步出監(jiān)牢的瞬間茄菊,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,983評論 1 266
  • 我被黑心中介騙來泰國打工赊堪, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留买羞,地道東北人。 一個月前我還...
    沈念sama閱讀 46,351評論 2 360
  • 正文 我出身青樓雹食,卻偏偏與公主長得像畜普,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子群叶,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,509評論 2 348

推薦閱讀更多精彩內(nèi)容