From 084e0ab7bb7c0425623581787372bfc2cb6edbc4 Mon Sep 17 00:00:00 2001 From: Chris Lu Date: Tue, 20 Nov 2012 00:42:45 -0800 Subject: [PATCH] adding exception handling for this case --- weed-fs/src/pkg/storage/needle.go | 13 +++++++++---- 1 file changed, 9 insertions(+), 4 deletions(-) diff --git a/weed-fs/src/pkg/storage/needle.go b/weed-fs/src/pkg/storage/needle.go index 99765589d..2333588c1 100644 --- a/weed-fs/src/pkg/storage/needle.go +++ b/weed-fs/src/pkg/storage/needle.go @@ -19,7 +19,7 @@ type Needle struct { Id uint64 "needle id" Size uint32 "Data size" Data []byte "The actual file data" - Checksum CRC "CRC32 to check integrity" + Checksum CRC "CRC32 to check integrity" Padding []byte "Aligned to 8 bytes" } @@ -32,7 +32,12 @@ func NewNeedle(r *http.Request) (n *Needle, fname string, e error) { e = fe return } - part, _ := form.NextPart() + part, fe := form.NextPart() + if fe != nil { + fmt.Println("Reading Multi part [ERROR]", fe) + e = fe + return + } fname = part.FileName() data, _ := ioutil.ReadAll(part) //log.Println("uploading file " + part.FileName()) @@ -99,9 +104,9 @@ func (n *Needle) Read(r io.Reader, size uint32) (int, error) { n.Id = util.BytesToUint64(bytes[4:12]) n.Size = util.BytesToUint32(bytes[12:16]) n.Data = bytes[16 : 16+size] - checksum := util.BytesToUint32(bytes[16+size : 16+size+4]) + checksum := util.BytesToUint32(bytes[16+size : 16+size+4]) if checksum != NewCRC(n.Data).Value() { - return 0, errors.New("CRC error! Data On Disk Corrupted!") + return 0, errors.New("CRC error! Data On Disk Corrupted!") } return ret, e }