各位老铁们好,相信很多人对图片存储服务器都不是特别的了解,因此呢,今天就来为大家分享下关于图片存储服务器以及VB怎样上传图片到服务器的问题知识,还望可以帮助大家,解决大家的一些困惑,下面一起来看看吧!

一、VB怎样上传图片到服务器

<%

'****************************************************

'这是类文件,用来保存有关文件上传的类

'****************************************************

'----------------------------------------------------------------------------------

Class jjUpload

'定义几个私有变量,在类内部都可以使用

Private formData,formSize,bncrlf,divider

'下面是初始化类的方法

Private Sub Class_Initialize()

formsize=Request.TotalBytes'获取传上来的二进制数据的大小

formdata=Request.BinaryRead(formsize)'获取传上来的二进制数据

bncrlf=ChrB(13)& ChrB(10)'回车换行标记

divider=LeftB(formData,CInt(InstrB(formdata,bncrlf))-1)'分隔符

End Sub

'下面的函数用来返回上传文件对象

Public Function GetFiles(FormName)

Dim objGetFiles

Set objGetFiles=New MyGetFiles

Call objGetFiles.GetProperty(formData,FormName)

Set GetFiles=objGetFiles

End Function

'下面的函数用来返回上传表单对象

Public Function GetForms(FormName)

Dim objGetForms

Set objGetForms=New MyGetForms

Call objGetForms.GetValue(formdata,FormName)

Set GetForms=objGetForms

End Function

End Class

'----------------------------------------------------------------------------------

Class MyGetFiles

'定义几个私有变量

Dim theFilePath,theFileName,theExt,theSize,theMIME,theformData

'定义几个只读属*,用来返回有关信息

Public Property Get FilePath

FilePath=theFilePath

End Property

Public Property Get FileName

FileName=theFileName

End Property

Public Property Get Ext

Ext=theExt

End Property

Public Property Get Size

Size=theSize

End Property

Public Property Get MIME

MIME=theMIME

End Property

'下面是初始化类的方法

Private Sub Class_Initialize()

End Sub

'下面是返回各个类的属*

Public Sub GetProperty(formData,FormName)

Dim bncrlf,divider

bncrlf=ChrB(13)& ChrB(10)'回车换行标记

图片存储服务器 VB怎样上传图片到服务器

divider=LeftB(formData,CInt(InstrB(formdata,bncrlf))-1)'分隔符

'下面开始查找该FormName对应的内容,strTemp变量用来保存一个二进制字符串

'dataStart为开始位置,dataEnd为结束位置,dataLen为要取信息的长度,temp为临时使用。

Dim strTemp,dataStart,dataEnd,dataLen,temp,intFlag

'因为发生引号嵌套,这里的内层引号用""代替。

strTemp=StringToBinary("Content-Disposition: form-data; name="""& FormName&"""; filename=""")

'在formData中查找二进制字符串strTemp,如果找到了就继续处理,如果找不到返回错误信息。

intFlag=InstrB(formData,Divider& bncrlf& strTemp)

Dim arrayTemp()

If intFlag>0 Then

'重定义数组长度

Redim arrayTemp(4)

'首先返回文件在客户端的路径

dataStart=intFlag+LenB(Divider& bncrlf& strTemp)'定位到第1个字符

dataend=InstrB(datastart,formdata,bncrlf)-2'定位到最后1个字符

dataLen=dataend-datastart+1'返回要取信息的长度

theFilePath=BinaryToString(MidB(formdata,datastart,datalen))'返回文件路径

'返回文件的名称,其实只要从客户端路径中分析出文件名称即可

theFileName=Mid(theFilePath,InstrRev(theFilePath,"\")+1)

'返回文件的扩展名,其实只要从文件名称中分析出文件扩展名即可

theExt=Mid(theFileName,InstrRev(theFileName,".")+1)

'下面获取文件的MIME类型

temp=dataend'记住当前位置

datastart=temp+18'定位到第1个字符

dataend=InstrB(datastart,formdata,bncrlf& bncrlf)-1'定位到最后1个字符

dataLen=dataend-datastart+1'返回要取信息的长度

theMIME=BinaryToString(MidB(formdata,datastart,datalen))'返回MIME类型

'下面获取文件大小

temp=dataend

datastart=dataend+5'定位到第1个字符

dataend=InstrB(datastart,formdata,divider)-3'定位到最后1个字符

theSize=dataend-datastart+1'返回文件大小

End If

'将formData保存在本类的私有变量中,以备使用

theformData=formData

End Sub

'----------------------------------------------------------------------------------

'下面定义一个保存文件的方法

Public Function S*eToFile(FormName,S*eFilePath,OverWriteFlag)

Dim bncrlf,divider

bncrlf=ChrB(13)& ChrB(10)'回车换行标记

divider=LeftB(theformData,CInt(InstrB(theformdata,bncrlf))-1)'分隔符

'下面开始查找该FormName对应的内容,strTemp变量用来保存一个二进制字符串

'dataStart为开始位置,dataEnd为结束位置,dataLen为要取信息的长度,temp为临时使用。

Dim strTemp,dataStart,dataEnd,dataLen,temp,intFlag,filepath,filename

'因为发生引号嵌套,这里的内层引号用""代替。

strTemp=StringToBinary("Content-Disposition: form-data; name="""& FormName&"""; filename=""")

'在formData中查找二进制字符串strTemp,如果找到了就继续处理,如果找不到返回错误信息。

intFlag=InstrB(theformData,Divider& bncrlf& strTemp)

Dim arrayTemp()

If intFlag>0 Then

'因为后面要用到文件的名字,所以首先返回文件的名字

dataStart=intFlag+LenB(Divider& bncrlf& strTemp)'定位到第1个字符

dataend=InstrB(datastart,theformData,bncrlf)-2'定位到最后1个字符

dataLen=dataend-datastart+1'返回要取信息的长度

filepath=BinaryToString(MidB(theformData,datastart,datalen))'返回文件路径

filename=Mid(filepath,InstrRev(filepath,"\")+1)

'从当前位置找到两个回车换行符,也就是文件内容开头的地方

dataStart=InstrB(intFlag,theformData,bncrlf& bncrlf)+4'定位到文件内容所在的第1个字符

dataEnd=InstrB(datastart,theformData,divider)-3'定位到文件内容的最后一个字符

dataLen=dataend-datastart+1'返回文件内容的长度

If dataLen<=0 Then

S*eToFile=3

Exit Function

End If

'下面建立了两个Stream对象,objStream1将整个theformData读取到对象中,然后将其中的文件内容部分复制到

'objStream2对象中,然后再利用S*eToFile方法保存到指定文件夹下。

Dim objStream1

Set objStream1=Server.CreateObject("Adodb.Stream")

objStream1.Type= 1'设置二进制方式

objStream1.Open'打开对象

objStream1.Write theformData'写出文件内容到对象中

Dim objStream2

Set objStream2=Server.CreateObject("Adodb.Stream")

objStream2.Type= 1'设置二进制方式

objStream2.Open'打开对象

objStream1.Position=datastart-1'设定起始位置,这里索引从0开始,所以减1

objStream1.CopyTo objStream2,dataLen'写出文件内容到对象中

'如果允许覆盖,才覆盖,否则给出提示信息,提示客户更改名字

If OverWriteFlag=True Then

objStream2.S*eToFile S*eFilePath&"\"& filename,2'保存文件,2表示可以覆盖

Else

Set fso=Server.CreateObject("Scripting.FileSystemObject")

IF fso.FileExists(S*eFilePath&"\"& filename)=True Then

S*eToFile=2'返回函数值,1表示已经存在同名文件

Exit Function

Else

objStream2.S*eToFile S*eFilePath&"\"& filename,1'1表示不可以覆盖

End If

End IF

'关闭对象

objStream1.Close

Set objStream1=Nothing

objStream2.Close

Set objStream2=Nothing

S*eToFile=1'下面返回函数值,0表示正常

Else

S*eToFile=0'下面返回函数值,2表示找不到,发生错误

End If

End Function

'下面定义保存文件到数据库的方法

Public Function S*eToDataBase(FormName,strConn,strSql)

Dim bncrlf,divider

bncrlf=ChrB(13)& ChrB(10)'回车换行标记

divider=LeftB(theformData,CInt(InstrB(theformdata,bncrlf))-1)'分隔符

'下面开始查找该FormName对应的内容,strTemp变量用来保存一个二进制字符串

'dataStart为开始位置,dataEnd为结束位置,dataLen为要取信息的长度,temp为临时使用。

Dim strTemp,dataStart,dataEnd,dataLen,temp,intFlag,fileimage

'因为发生引号嵌套,这里的内层引号用""代替。

strTemp=StringToBinary("Content-Disposition: form-data; name="""& FormName&"""; filename=""")

'在formData中查找二进制字符串strTemp,如果找到了就继续处理,如果找不到返回错误信息。

intFlag=InstrB(theformData,Divider& bncrlf& strTemp)

Dim arrayTemp()

If intFlag>0 Then

'从当前位置找到两个回车换行符,也就是文件内容开头的地方

dataStart=InstrB(intFlag,theformData,bncrlf& bncrlf)+4'定位到文件内容所在的第1个字符

dataEnd=InstrB(datastart,theformData,divider)-3'定位到文件内容的最后一个字符

dataLen=dataend-datastart+1'返回文件内容的长度

fileimage=MidB(theformData,datastart,datalen)'返回二进制文件内容

If dataLen<=0 Then

S*eToFile=3'3表示根本没有选择文件

Exit Function

End If

'!!!因为当文件大小为奇数字符时,在往数据库中保存时有一些小问题,会少一个字节,所以这里先给它加一个二进制空格

If dataLen Mod 2= 1 Then

fileimage=fileimage& Chrb(32)

datalen=datalen+1

End If

'下面将文件保存到数据库中

Dim db,cmd,rs

Set db=Server.CreateObject("ADODB.Connection")

db.Open strConn

Set cmd= Server.CreateObject("ADODB.Command")

cmd.ActiveConnection=db

cmd.CommandText=strSql

'下面建立一个参数对象prm,并将该对象加入到参数集合中,204表示是二进制值

Dim prm

Set prm=cmd.CreateParameter("fileimage",204,1,datalen,fileimage)

cmd.Parameters.Append prm

set rs=cmd.Execute

S*eToDatabase=1'返回函数值,0表示正常

Else

S*eToDatabase=0'返回函数值,2表示错误

End If

End Function

'下面是注销该类的方法

Private Sub Class_Terminate()

'theformData=Nothing

End Sub

End Class

'----------------------------------------------------------------------------------

Class MyGetForms

'定义1个私有变量

Dim theValue

'定义几个只读属*,用来返回有关信息

Public Property Get Value

Value=theValue

End Property

'下面是初始化类的方法

Private Sub Class_Initialize()

End Sub

'该方法给属*赋值

Public Sub GetValue(formData,FormName)

Dim bncrlf,divider

bncrlf=ChrB(13)& ChrB(10)'回车换行标记

divider=LeftB(formData,CInt(InstrB(formdata,bncrlf))-1)'分隔符

'下面开始查找该FormName对应的内容,下面会首先定义几个变量,strTemp为一个字符串变量,临时保存二进制字符串

'dataStart为开始位置,dataEnd为结束位置,dataLen为要取信息的长度,temp为临时使用,为了记住当前位置。

Dim strTemp,dataStart,dataEnd,dataLen,temp,intFlag

strTemp=StringToBinary("Content-Disposition: form-data; name="""& FormName&"""")

'在整个二进制字符串中查找下面这一个二进制字符串

intFlag=InstrB(formData,Divider& bncrlf& strTemp& bncrlf& bncrlf)

'如果找到了,就依次返回有关信息,如果找不到,就返回一个错误信息

If intFlag>0 Then

datastart=intFlag+LenB(Divider& bncrlf& strTemp& bncrlf& bncrlf)'定位到第1个字符

dataend=InstrB(datastart,formdata,divider)-3'定位到最后1个字符

dataLen=dataend-datastart+1'返回要取信息的长度

theValue=BinaryToString(MidB(formdata,datastart,datalen))'返回出表单内容信息

Else

theValue=""

End If

End Sub

End Class

'------------------------------------------------------------------------------------------------

'该函数可以将二进制字符串转换成文本字符串

Function BinaryToString(thedata)

'变量strNow表示正在处理的字符,strTemp用来保存已经处理完毕的字符串

'变量flag是一个标志,False表示前一个字符不是中文,True表示前一个字符是中文

Dim strNow,strTemp,flag,I

flag=False

'利用循环依次转换每一个字符

For I=1 To LenB(thedata)

'因为一个中文字符包括两个字节,如果flag=True,表示前一个字符是中文,所以

'要跳过该字符,需要令标志flag=False。否则表示不是中文,就需要将其转换

If flag=True Then

flag=False

Else

'取出当前二进制字符

strNow=MidB(thedata,I,1)

'如果AscB(strNow)>127,表示这是一个中文字符,AscB(tsrNow)<127,表示不是中文字符

If AscB(strNow)> 127 Then

'如果是中文,首先需要把当前字符和下一个字符调换位置,然后用AscW

'返回对应的ASCII码。随之,用Chr函数返回该ASCII码对应的文本

'最后,还要把中文标志设为True

strTemp=strTemp& Chr(AscW(MidB(thedata,I+1,1)& strNow))

flag=True

Else

'这表示是英文,AscB返回对应的ASCII码,Chr返回对应的文本字符

strTemp=strTemp& Chr(AscB(strNow))

End If

End If

Next

BinaryToString=strTemp'返回函数值

End Function

'该函数可以将文本字符串转换成二进制字符串

Function StringToBinary(thedata)

'变量strNow表示正在处理的字符,strTemp用来保存已经处理完毕的字符串

'变量intNow用来表示当前字符的ASCII码

'变量ascLow和ascHigh用来保存中文字符的第1个和第2个字节

Dim strNow,intNow,strTemp,I,binLow,binHigh

'利用循环依次转换每一个字符

For I=1 To Len(thedata)

'取出当前文本字符,并返回ASCII码

strNow=Mid(thedata,I,1)

intNow=Asc(strNow)

'如果Asc(strNow)<0,则表示是中文字符,则需要加上65535返回它的无符号数值

If intNow<0 Then

intNow=intNow+65535

End If

'如果加上65535后ASCII码大于255,则表示是中文,中文是用两个字节表示的,必须分开处理。当然,如果是英文字符就简单了

If intNow>255 Then

'这里binLow返回低字节,binHigh返回高字节其中Hex函数返回一个字符串,表示一个数字的十六进制数

binLow="&H"& Left(Hex(Asc(strNow)),2)

binHigh="&H"& Right(Hex(Asc(strNow)),2)

strTemp=strTemp& ChrB(binLow)& ChrB(binHigh)

Else

'这表示是英文,Asc函数返回ASCII码,ChrB返回对应的二进制字符。

strTemp=strTemp& ChrB(Asc(strNow))

End If

Next

StringToBinary=strTemp'返回函数值

End Function

%>

二、为什么里得图片加载不出来

1、请确认图片是否很早之前接收的,但是没有及时查看,图片可能已经被服务器删除,仅保存图片3天,超过3天将无法查看原图。

2、请确认是否是从别的手机备份恢复过来的图片、语音或视频,可能是恢复过程中数据丢失。

3、如果手机支持插入 microSD,请更换 microSD卡后再尝试,可能是您的 microSD卡损坏引起。

4、如果手机支持插入 microSD,请切换默认存储位置后再尝试,操作如下:

EMUI 5.X:设置>内存和存储

EMUI 8.X&9.X:设置>存储

5、请清除缓存后再尝试,在设置中,进入

EMUI5.X:设置>应用管理>>存储,

EMUI8.X:设置>应用和通知>应用管理>>存储,

EMUI9.X:设置>应用>应用管理>>存储,

Magic UI 2.0/2.0.1:设置>应用>应用管理>>存储,

清空缓存。若清空缓存后图片仍无法打开,请确认图片是否有保存在图库中,如果图片是在图库中的,请尝试在图库中打开该图片,看是否是文件本身损坏。

6、若图片在图库中能正常打开,而在中无法打开,请您备份数据之后卸载并重新安装最新版本再尝试。

7、您是否使用过手机管家类应用的专清功能,专清功能会清除的图片缓存,请谨慎使用。

8、有可能是网络原因引起的,在网络状态差的情况下,图片加载时会出现转圈的现象。

请您在网络状态好的环境下查看图片,或者还原网络设置后重试:

EMUI 5.X:设置>高级设置>备份和重置>还原网络设置

EMUI 8.X&9.X:设置>系统>重置>还原网络设置

Magic UI 2.0/2.0.1:设置>系统>重置>还原网络设置

此操作不会删除任何数据或文件,仅还原 WLAN、移动数据网络和蓝牙(如热点连接信息,蓝牙配对信息等)的设置,其他手机设置不会被还原。

三、你不知道的网站图片存储格式-base64

最近在前端模仿163网易登录界面的时候惊奇的发现:

大家先自己想想,这个图片应该怎么设置,很多人就是img就搞定了,后者一个a标签,或者background等等,但是我打开开发者工具后我发现是这样的:

我也没太在意,不就是一张网图吗,放到网站服务器上,然后get下来不就好了。但是事情好像不是那么简单。我给大家看看那个资源:

data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAR4AAAA+CAMAAADKzIRmAAAAsVBMVEVHcEw3NzfPAyaJiYk2NjbPBCZlZWWhXGM3Nzc3Nzc2NjY2NjY2NjY4ODiJiYk2NjY7OzvPBCc2NjaKioo3Nzc2NjaKioo6Ojo2NjY3NzeMjIyIiIjVECw3NzfPBCY4ODjQAyfPBCY3NzfSCCrPAyaJiYmKiorQBCeJiYnQBSfPAyaIiIiJiYmJiYnRBSjPAyfPBCaJiYmJiYmJiYnPAyZYWFjPBCbPAybOAyY2NjaIiIh1+0RMAAAAOHRSTlMAXPmnyoUPBUdu86PTOXO0FnH7NIzpRSHemiG0D8DPLFKyex/vhV1Ex2Kl79aXMJbA+uRo5ljV3b1RDw0AAAzoSURBVHja7Zxnl7K8FobBQiwooKBYsfc+rhnx//+ws1OABELxvO+z1nlmnXyQjuRy594lzCiKpKHtVvl/S2lj6+dVLXruZWZVr4fDfH67yZGOt7O9Ze1n2/GvgLOsrl6vInjGs+r8+eLaXgL68BMd/znM0F8O53Ioka7k4Vlat9Ir1uJ4tofEKc/q32xD23nQj2oOxJekiXiWc9k5r+f+v3qy/qIeawtPPGNhtzKuNwx8GD5riUODilEv8ARoNo16Uf0YTgyPVXqltLnMgHS9Imm6q7LjLT/RxI5qDd93vdRnnvgdU1G*t9PHJLulOnxqwieFKuI4am+0tv3MnlX15e3gIGXPCQaS933G2qG9fguNhS/oUjwBDs10zQ1/NHXZHpcBM/sKe/z83a9RGcdXlntO2k/eg6evu9X+KFVieExHb9TM0nr9z0zoqZPSHP8BvnskC3dMWV4FuHXqjI9zsczvkp6W5pbW9EgrFd2O8jw1Frxpgt4BrERweNBE56po/FGJW2cC41MKjq5L9PjPDxo+Z04cXWYjRXRX6NLKQfPayvBQ39Qk7tXRcAzUbkWsx47TZXU5oA012/Ap+536EZHOrgAj+O6MM7d6OhU+vxSPMvEwHpaEp1FP3l0XvNUP*HJgJr2zUk4snQHqCj12iDVUMqzZz2GAyP2bShATO8sAcYD3xfTTDUV1E8KEHnuZeGeVYunVdpmcTTVyc1/Oh+RYPbOrCMBhfKwoNgpLlsOCDdbwh+qLWoY2vTfQc+JyDf1PQoHuF+DYbHFqSnMJ4Enbk8xENPbuTttxdIO66r+P1nSTzwcBXiwuqTOnlyT7Qeg5clI8LTh9McL1LXBTwC+B+UKT5EnZCwy2V4QkP+BA8aP3OC5ITxlKooJWx4vSzJ4MI0AAusugjinAmnPShdmusNOYBWyKtiGIbjO/AJomPgNqlQAMDc8wy/4XleI8CDn0CJ4/m5znKsJybgpVma659KzxjfhMuvEjwYiQpPCF1XF9jCRetxDa45Qf+xM3YcCR4vlKUaUXlDEvf4fjOQ5hAPSI8t4vmu4pCllInHKmg7yjLFQMSxWZVJM3Cp+A7qdwCF39F4PF5qSKR2XA9iYhINAYsJWdFDPAMYrKDYjl+BTzAUpuBqPQ2PKD3KT5WFc5l44r76mhqfWmnOqZo3uBTgQsZQE/feEBy7JKkIOlEzwS9Rq6gR5REShWZK4NNMwyNKT9Sy8KBYwDNNr0ywQbRKZA6zHGmmOREeMwRTXcCj9U0swbYWNLNv8m6b4lEDaBwetwJhMk7IIIeDqJnkci7DKMETk55ieOJD65Ke3XyniRePpzSW4oEh1EDsJzcFPOCFdfaTR1loP45nEVwQSzNhv66F2mOG50nw1LBP+BAPehYdWtD2GNAz6fSrWVkFxQMC3OnToaSLUbNSk8jvJI7HDiRHwFOrBHERxaO6HXYYfg3HaWBtdwLHjgxRmovgsXKCuridTBPaEkOcklQMqPbgbmJMER5PKiGDCI/fIc1nK4Hn0lqqTYoBNktkG/X6wm4EdiiLezQ9XivJwzNOGs9lu7eq1mybAmqLMo1nriip0twwFROHMnaIB2FX73eazSbsgNQJPnXyWeeSM7ljt6WyrFfqiOFxSQYGeVgnDAtbOO76BE9ceQ63KAp+XosVkPl7JGU7dOxNbBPQKcdvBI6dZuM6SHbLITtoOso7YEibFtDgYmPBmt1nOYY/gTyDK7G5oc+Xey6S16if4LllJ1BPKxcQ4gshJcmUBsYDwtwEx9GpdfymjW2DWY+Jk0b4ilqDOByVik6TGwMurVAAR7dpiykXbBo4WYGRa9Q96t1y8KjSrDYVzzI3w/zOmRbb/uTF2yyp8IiMQFZJLDzQnr4B1oLwQFmQwhcJmA2um0bT0EjUM3EllVGGp0LFKh9*6ho5OIpkIFLpJiDc8s/FfDY5GFVSIyw7gAElY+aF7CjU6dDzRBKIKGfx5oKmbkix4M61Cvm49F8Wc01Fc+0AJ5UXz+24peXLDkeKqeaQat9A1+vBXjUgRvID/a7tBLqCDUtuLCCuelBUNcfIBFPi7mrf9t6xq9C7SBjs5+Xis1VAB6jgx+/ZXSIMHqtyLGTokRjgWjxokP2abE+4KHpmhGelu8utMDt61SrPMUjN2txeDQN8CCEODwDaWSYhmdbDE8ySZ3d0oqq07FMe/pUNTQ1UUyFHthgMtoCxLmjBulVhbtedWjRJ8SjsgAce/fBgATOBni7SU0dNDk88bhHrbiOz4UM+XisgnhKl+wSCN9uKK2YGrg6jTokigctTOyEcDjktJS6YdsDhw9u8TCks1x6AEUoqvZVXEQyiRWyYm1aWEhyX/2DuEcyKfNzONySEzrT4ngSQzEhtJMG+RlZVzy1SZOKpkl9F44TqRGg2oBsNzV2nwkpHDeoCdTUuk2VC2xLU5ukdlYJZli5+n44uOAMw/wgao4X1n+qy5QZjm1xPPGUPeGQvQ5BoAkzUJOoBOY7bAzWO/yWwdWOcSc9Vkvs2BobuXTKx0C0mBomuQ1weQRPc1H7KCUVBWTFld/jE8W3D/A8Rft14rOeCunGgp+pmUS1MX2ghnNZHs4Kgi2vEvDQa4EG+U5T5aY9PUggdJPJezAAkd9oRAn/B3hQxhRMdp1j/kGkpNbUWDi3qBj8SwWDATeBLs7xek1hbh2RFp5qq4k4kYSZ2NsZRmg9+IJ6Rf8YzzKrRj/P6jJ962m7ne2vktDp+3/zJRX0IZ5LhvtGy8zRlTWJ/3ot/66Xe4rhiUmq6NZKKP1HWd6KFvP/JjzokumdZh9YxPWDkuNfYz3LzCozKhWtQSf4zH+F9Yyz3624Zb95kfFuwu1XWA/KxnP9AI84FKe/Ao+yyhRU64PBpaDVr7MeJbuYtf/IWc9/m/bE36K8Zo2XV95by9df57li9Z5blvWsPpmvsD59wO5ut9vAEhZr8UgPdvWCLKK9O94fozasDr9GJ7z+hf4gnnFm5Gd95KurxWVcguf9fuNew6IsHFjDnvcXO+nxJu0E6+c3a6fhn8OT7buvr08MgguyV+hfwqONCIIN2Rge3+9jeX0+lQm23Xl9hj3v3R/EM8sSn3mK45Kr0DO7Np3j9zQNv3UYwzM8vTk8gOoxDJL67jAg9h7+OTziCwjirz7mXfVPEGhfp6vX6pD08tvUGOB8PneVTfmENUNb704jJiXd9Qg21rSfcBLsRgIehAfTMcAzvL/fvfi3luFol9serke*47es3sePU7lNgruj1B7dCpv8MbuVB4WmiWtprv2vSQmugZ3usZMCE1TZQqPmzKxgjMzB9LdLyYex140uEQ8ygYuaQfnw8ox8aPsBOtB7Tu9J9wDrdn6CePrwUqPfPl90z2Srx0WwSOYiPh+xneyAMiJ9XOWpjzxlzyYCZBHpYsHcUnHc3uzBgM5oTQ8ynqjhHhgbJWH6/L5iyuYtUXtwZvH81d716aaXu59PSiIHnkIAuzIluUUB3XNiP24aRgr*ZLAfM8wjA+ZIg4/snamoZ9zf1LGwY/OK369ejoSMHDukzwANoT6dejx8ZsGQ++R2QFRLuHtMaCh2KZDcky/ZpHD5EvhyU2oEex8OYm/5OafSn5Qt0+Puc3I2cvrWdWSMi6jAms2aAiHUTdTW84pL0vgIdY4InIkcZuK9IhBrPm1nvM6N6I4Plid+sxzQrrFrF6517QjWWs1neYXcbLmeC12FspSDIttvr5Fqd95igDT5vDs8E9vZfpc6fGPSEeTA53vhwwuFNt2Q0Fne5x61rAqSvg6QZ4tofDYT6V/BnSz21+uF6RtOyVMTNTYNbwkAx55HjwA4/a5/sneO7QYWxuIxYVdUeC9vA6Det37nopnpzuj*2uppSfJXMpsqCRzmeB+3Yuige5U7DZYWFzbSdeMd++jN4RJ1JdHmfplPJGQpp0UOKZ8jGSLcwnhPFgu68way58SQEQUUGV1E8ymyVTod34JdV1uyf/I945HiCLSkeHENrcTxlGvd0BYJMbuj5a3aThDRr/xBPcq4hdHOiQVyeaTdbpf6ddqr1JAcX81xDDkGIZ0M7HFxA0/k7FaQTQdd9R2kH79hHyj/FAwb0LRsts3hfx9WV9G8qM17SlGsPForduvwujAfBFfczvgDiSPQ+js7rHfNmDA9J4x/ndflx5sPC+zAFz2ya2WI/d/xP91fy/2ww3h8EEypNr/vMUlmK56J+WSrNUjzKkNUzHl16Bm1nFOHRymwn2CUKSh4kipTi+Thv3lYP0+eq9Py+HarbjKrEZY//u8b1WrX2l9zixWhEC1iwJE8Kyy7JEnc7yFXLZG9wkJ6rsUsUdnqPZfXr0xHyTaxKGqSex3uQfCrn0Yji7JV3xyPb2zvvjo8ROV3psrtsYIkPtmH5H3KUgmsWzQULAAAAAElFTkSuQmCC

是这么一大堆东西,这,我真的不懂。不懂不怕呀,我可以百度,我在百度上看到的是这样婶的:

不懂,还是不懂,我又去看了阮一峰老师的 Base64笔记

这下才明白,是为了节省服务器资源,一次请求服务器就需要一个GET/POST请求,我放在本地不香吗,又不费我的服务器。传输效率又快,还能加密(虽然不怎么管用)。

所以一定要有一种探索的精神,对新鲜的事物有好奇。