'上传兼容文件[]byte化'

This commit is contained in:
coward
2021-03-16 11:17:11 +08:00
parent 17b7856b9b
commit d89ca3242c
4 changed files with 23 additions and 11 deletions

View File

@@ -24,8 +24,8 @@ go get github.com/cowardmrx/go_aliyun_oss
ossClient := ossConfig.CreateOssConnect() ossClient := ossConfig.CreateOssConnect()
//put 方法返回完整的oss 可访问地址 //put 方法返回完整的oss 可访问地址 第三个参数 如果文件不是[]byte数组的可以直接传递空如果是[]byte也可以是空会默认给出一个png的文件类型建议实际中给出文件类型
uri := ossClient.Put("logo/","./File/3HaqWaOzJWD86DDvZD9Pmn9VUEOBOBbuWackGOXb (2).jpeg") uri := ossClient.Put("logo/","./File/3HaqWaOzJWD86DDvZD9Pmn9VUEOBOBbuWackGOXb (2).jpeg","")
fmt.Println(uri) fmt.Println(uri)
//HasExists 方法返回一个bool值 true-存在 false-不存在 //HasExists 方法返回一个bool值 true-存在 false-不存在

15
file.go
View File

@@ -31,6 +31,7 @@ func (ossFile *OssFile) FileTypeTransForm() (*OssFile,error) {
switch ossFile.File.(type) { switch ossFile.File.(type) {
case *os.File: case *os.File:
ossFile.FileByte,err = ioutil.ReadAll(ossFile.File.(*os.File)) ossFile.FileByte,err = ioutil.ReadAll(ossFile.File.(*os.File))
if err != nil { if err != nil {
@@ -76,10 +77,16 @@ func (ossFile *OssFile) FileTypeTransForm() (*OssFile,error) {
break break
// 支持[]byte数组传递 因为无法解析文件类型 默认直接给出文件类型为.jpeg // 支持[]byte数组传递 因为无法解析文件类型 默认直接给出文件类型为.png
case []byte: case []byte:
ossFile.FileByte = ossFile.File.([]byte) ossFile.FileByte = ossFile.File.([]byte)
ossFile.FileOldName = uuid.NewV4().String() + ".jpeg"
//判断是否指定了文件的类型 如果没有指定默认为png格式
if ossFile.FileType == "" || len(ossFile.FileType) <= 0 {
ossFile.FileOldName = uuid.NewV4().String() + ".png"
} else {
ossFile.FileOldName = uuid.NewV4().String() + ossFile.FileType
}
break break
@@ -96,12 +103,16 @@ func (ossFile *OssFile) FileTypeTransForm() (*OssFile,error) {
//split file type and generate file name //split file type and generate file name
//截取文件类型 //截取文件类型
func (ossFile *OssFile) GetFileType() *OssFile { func (ossFile *OssFile) GetFileType() *OssFile {
// 当没有传递文件类型时去文件名中截取出文件类型
if ossFile.FileType == "" || len(ossFile.FileType) <= 0 {
//from oldFileName split file type //from oldFileName split file type
fileTypeSufIndex := strings.Index(ossFile.FileOldName,".") fileTypeSufIndex := strings.Index(ossFile.FileOldName,".")
fileType := ossFile.FileOldName[fileTypeSufIndex:] fileType := ossFile.FileOldName[fileTypeSufIndex:]
ossFile.FileType = fileType ossFile.FileType = fileType
}
//generate only file name //generate only file name
ossFile.FileNewName = uuid.NewV5(uuid.NewV4(),ossFile.FileOldName).String() + ossFile.FileType ossFile.FileNewName = uuid.NewV5(uuid.NewV4(),ossFile.FileOldName).String() + ossFile.FileType

View File

@@ -15,11 +15,12 @@ type AliOssClient struct {
//params: ossDir string `oss dir [要推送到的oss目录]` example: test/20201121/ //params: ossDir string `oss dir [要推送到的oss目录]` example: test/20201121/
//params: file interface `upload file resource [文件资源]` //params: file interface `upload file resource [文件资源]`
//return string `oss file accessible uri [可访问地址]` //return string `oss file accessible uri [可访问地址]`
func (client *AliOssClient) Put(ossDir string, file interface{}) string { func (client *AliOssClient) Put(ossDir string, file interface{},fileType string) string {
//file to []byte //file to []byte
//文件转字节流 //文件转字节流
uploadFile := &OssFile{ uploadFile := &OssFile{
File: file, File: file,
FileType: fileType,
} }
ossFile,err := uploadFile.FileTypeTransForm() ossFile,err := uploadFile.FileTypeTransForm()

View File

@@ -17,7 +17,7 @@ func TestPut(t *testing.T) {
client := ossConfig.CreateOssConnect() client := ossConfig.CreateOssConnect()
uri := client.Put("logo/","./File/3HaqWaOzJWD86DDvZD9Pmn9VUEOBOBbuWackGOXb (2).jpeg") uri := client.Put("logo/","./File/3HaqWaOzJWD86DDvZD9Pmn9VUEOBOBbuWackGOXb (2).jpeg",".png")
fmt.Println(uri) fmt.Println(uri)
} }
@@ -41,7 +41,7 @@ func TestPutBase64(t *testing.T) {
bat,_ := base64.StdEncoding.DecodeString(fileStr) bat,_ := base64.StdEncoding.DecodeString(fileStr)
uri := client.Put("logo/",bat) uri := client.Put("logo/",bat,".png")
// //
fmt.Println(uri) fmt.Println(uri)
} }