| | |
| | | "mime/multipart" |
| | | "net/http" |
| | | "github.com/kirinlabs/HttpRequest" |
| | | "strings" |
| | | "time" |
| | | ) |
| | | |
| | |
| | | _, err := body.ReadFrom(resp.Body) |
| | | if err != nil { |
| | | fmt.Println("UploadFile body.ReadForm(resp.Body) err:", err) |
| | | return "", err |
| | | } |
| | | |
| | | m := make(map[string]interface{}) |
| | | if err := json.Unmarshal([]byte(body.String()), &m); err != nil { |
| | | return "", err |
| | | } |
| | | filePath := m["fileUrl"].(string) |
| | | return filePath,nil |
| | | if furl,ok := m["fileUrl"]; ok { |
| | | filePath := furl.(string) |
| | | return appendCollection2Uri(uri, filePath),nil |
| | | } else { |
| | | fmt.Println("no fileUrl in m, m:", m) |
| | | return "", errors.New("file server err") |
| | | } |
| | | } |
| | | } |
| | | |
| | | // 获得一个fid |
| | | func appendCollection2Uri(weedfsUri, fileUri string) string { |
| | | //判断weedfsUri中是否包含collection参数 |
| | | idx := strings.Index(weedfsUri, "?") |
| | | if idx > -1 { |
| | | return fileUri + weedfsUri[idx:] |
| | | } else { |
| | | return fileUri |
| | | } |
| | | } |
| | | |
| | | // 获得一个fid url eg:http://192.168.5.23:6333/assign/dir?collection=11111-persistent |
| | | func GetFid(url string)(weedPath string ,err error) { |
| | | res,err := HttpRequest.NewRequest().Post(url) |
| | | if err != nil { |
| | |
| | | if err != nil { |
| | | return "",err |
| | | } |
| | | u,ok1 := m["url"] |
| | | u,ok1 := m["publicUrl"] |
| | | f,ok2 := m["fid"] |
| | | if ok1 && ok2 { |
| | | return "http://"+u.(string)+"/"+f.(string),err |
| | | filePath := "http://"+u.(string)+"/"+f.(string) |
| | | return appendCollection2Uri(url, filePath),err |
| | | } else { |
| | | return "", errors.New("未获取到url和fid") |
| | | } |