'兼容[]byte数组文件上传'
This commit is contained in:
@@ -5,6 +5,7 @@
|
|||||||
对阿里云oss-golang sdk 进行上传、删除的简单封装,便于使用
|
对阿里云oss-golang sdk 进行上传、删除的简单封装,便于使用
|
||||||
上传使用字节流,内自带 *os.File | *multipart.FileHeader 文件类型转字节流,
|
上传使用字节流,内自带 *os.File | *multipart.FileHeader 文件类型转字节流,
|
||||||
以及使用字符串路径 例如:./test.png 。测试案例oss_test.go中有不同操作的案例
|
以及使用字符串路径 例如:./test.png 。测试案例oss_test.go中有不同操作的案例
|
||||||
|
新版兼容文件[]byte化上传
|
||||||
|
|
||||||
#install
|
#install
|
||||||
go get github.com/cowardmrx/go_aliyun_oss
|
go get github.com/cowardmrx/go_aliyun_oss
|
||||||
|
|||||||
13
file.go
13
file.go
@@ -39,6 +39,8 @@ func (ossFile *OssFile) FileTypeTransForm() (*OssFile,error) {
|
|||||||
|
|
||||||
_,ossFile.FileOldName = filepath.Split(ossFile.File.(*os.File).Name())
|
_,ossFile.FileOldName = filepath.Split(ossFile.File.(*os.File).Name())
|
||||||
|
|
||||||
|
break
|
||||||
|
|
||||||
case *multipart.FileHeader:
|
case *multipart.FileHeader:
|
||||||
|
|
||||||
fileResources,err := ossFile.File.(*multipart.FileHeader).Open()
|
fileResources,err := ossFile.File.(*multipart.FileHeader).Open()
|
||||||
@@ -57,6 +59,8 @@ func (ossFile *OssFile) FileTypeTransForm() (*OssFile,error) {
|
|||||||
|
|
||||||
ossFile.FileOldName = ossFile.File.(*multipart.FileHeader).Filename
|
ossFile.FileOldName = ossFile.File.(*multipart.FileHeader).Filename
|
||||||
|
|
||||||
|
break
|
||||||
|
|
||||||
case string:
|
case string:
|
||||||
newFile,err := os.Open(ossFile.File.(string))
|
newFile,err := os.Open(ossFile.File.(string))
|
||||||
|
|
||||||
@@ -70,6 +74,15 @@ func (ossFile *OssFile) FileTypeTransForm() (*OssFile,error) {
|
|||||||
|
|
||||||
_,ossFile.FileOldName = filepath.Split(newFile.Name())
|
_,ossFile.FileOldName = filepath.Split(newFile.Name())
|
||||||
|
|
||||||
|
break
|
||||||
|
|
||||||
|
// 支持[]byte数组传递 因为无法解析文件类型 默认直接给出文件类型为.jpeg
|
||||||
|
case []byte:
|
||||||
|
ossFile.FileByte = ossFile.File.([]byte)
|
||||||
|
ossFile.FileOldName = uuid.NewV4().String() + ".jpeg"
|
||||||
|
|
||||||
|
break
|
||||||
|
|
||||||
default:
|
default:
|
||||||
fmt.Println(reflect.TypeOf(ossFile.File))
|
fmt.Println(reflect.TypeOf(ossFile.File))
|
||||||
panic("file type is not support" )
|
panic("file type is not support" )
|
||||||
|
|||||||
26
oss_test.go
26
oss_test.go
@@ -1,7 +1,9 @@
|
|||||||
package go_aliyun_oss
|
package go_aliyun_oss
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"encoding/base64"
|
||||||
"fmt"
|
"fmt"
|
||||||
|
"io/ioutil"
|
||||||
"testing"
|
"testing"
|
||||||
)
|
)
|
||||||
|
|
||||||
@@ -20,6 +22,30 @@ func TestPut(t *testing.T) {
|
|||||||
fmt.Println(uri)
|
fmt.Println(uri)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestPutBase64(t *testing.T) {
|
||||||
|
ossConfig := &AliOssConfig{
|
||||||
|
EndPoint: "oss-cn-shenzhen.aliyuncs.com",
|
||||||
|
AccessKeyId: "LTAI4FwmLMvboJf97riakG9e",
|
||||||
|
AccessKeySecret: "1dclKyqjiI1SDfr30IDvO0eZmcJLo3",
|
||||||
|
BucketName: "test-myself-bucket",
|
||||||
|
}
|
||||||
|
|
||||||
|
client := ossConfig.CreateOssConnect()
|
||||||
|
|
||||||
|
// 读取base
|
||||||
|
file,_ := ioutil.ReadFile("./File/3HaqWaOzJWD86DDvZD9Pmn9VUEOBOBbuWackGOXb (2).jpeg")
|
||||||
|
|
||||||
|
|
||||||
|
fileStr := base64.StdEncoding.EncodeToString(file)
|
||||||
|
|
||||||
|
bat,_ := base64.StdEncoding.DecodeString(fileStr)
|
||||||
|
|
||||||
|
|
||||||
|
uri := client.Put("logo/",bat)
|
||||||
|
//
|
||||||
|
fmt.Println(uri)
|
||||||
|
}
|
||||||
|
|
||||||
func TestExists(t *testing.T) {
|
func TestExists(t *testing.T) {
|
||||||
ossConfig := &AliOssConfig{
|
ossConfig := &AliOssConfig{
|
||||||
EndPoint: "oss-cn-shenzhen.aliyuncs.com",
|
EndPoint: "oss-cn-shenzhen.aliyuncs.com",
|
||||||
|
|||||||
Reference in New Issue
Block a user