mirror of
https://github.com/v2fly/v2ray-core.git
synced 2025-01-05 00:47:51 -05:00
length protection in ReadSegment
This commit is contained in:
parent
f050113925
commit
7056b414e2
@ -116,7 +116,7 @@ func (this *CmdOnlySegment) Bytes(b []byte) []byte {
|
|||||||
func (this *CmdOnlySegment) Release() {}
|
func (this *CmdOnlySegment) Release() {}
|
||||||
|
|
||||||
func ReadSegment(buf []byte) (ISegment, []byte) {
|
func ReadSegment(buf []byte) (ISegment, []byte) {
|
||||||
if len(buf) <= 6 {
|
if len(buf) <= 4 {
|
||||||
return nil, nil
|
return nil, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -132,6 +132,9 @@ func ReadSegment(buf []byte) (ISegment, []byte) {
|
|||||||
Conv: conv,
|
Conv: conv,
|
||||||
Opt: opt,
|
Opt: opt,
|
||||||
}
|
}
|
||||||
|
if len(buf) < 16 {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
seg.Timestamp = serial.BytesToUint32(buf)
|
seg.Timestamp = serial.BytesToUint32(buf)
|
||||||
buf = buf[4:]
|
buf = buf[4:]
|
||||||
|
|
||||||
@ -141,11 +144,14 @@ func ReadSegment(buf []byte) (ISegment, []byte) {
|
|||||||
seg.SendingNext = serial.BytesToUint32(buf)
|
seg.SendingNext = serial.BytesToUint32(buf)
|
||||||
buf = buf[4:]
|
buf = buf[4:]
|
||||||
|
|
||||||
len := serial.BytesToUint16(buf)
|
dataLen := int(serial.BytesToUint16(buf))
|
||||||
buf = buf[2:]
|
buf = buf[2:]
|
||||||
|
|
||||||
seg.Data = alloc.NewSmallBuffer().Clear().Append(buf[:len])
|
if len(buf) < dataLen {
|
||||||
buf = buf[len:]
|
return nil, nil
|
||||||
|
}
|
||||||
|
seg.Data = alloc.NewSmallBuffer().Clear().Append(buf[:dataLen])
|
||||||
|
buf = buf[dataLen:]
|
||||||
|
|
||||||
return seg, buf
|
return seg, buf
|
||||||
}
|
}
|
||||||
@ -155,6 +161,10 @@ func ReadSegment(buf []byte) (ISegment, []byte) {
|
|||||||
Conv: conv,
|
Conv: conv,
|
||||||
Opt: opt,
|
Opt: opt,
|
||||||
}
|
}
|
||||||
|
if len(buf) < 9 {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
|
||||||
seg.ReceivingWindow = serial.BytesToUint32(buf)
|
seg.ReceivingWindow = serial.BytesToUint32(buf)
|
||||||
buf = buf[4:]
|
buf = buf[4:]
|
||||||
|
|
||||||
@ -167,6 +177,9 @@ func ReadSegment(buf []byte) (ISegment, []byte) {
|
|||||||
seg.NumberList = make([]uint32, 0, seg.Count)
|
seg.NumberList = make([]uint32, 0, seg.Count)
|
||||||
seg.TimestampList = make([]uint32, 0, seg.Count)
|
seg.TimestampList = make([]uint32, 0, seg.Count)
|
||||||
|
|
||||||
|
if len(buf) < int(seg.Count)*8 {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
for i := 0; i < int(seg.Count); i++ {
|
for i := 0; i < int(seg.Count); i++ {
|
||||||
seg.NumberList = append(seg.NumberList, serial.BytesToUint32(buf))
|
seg.NumberList = append(seg.NumberList, serial.BytesToUint32(buf))
|
||||||
seg.TimestampList = append(seg.TimestampList, serial.BytesToUint32(buf[4:]))
|
seg.TimestampList = append(seg.TimestampList, serial.BytesToUint32(buf[4:]))
|
||||||
@ -182,6 +195,10 @@ func ReadSegment(buf []byte) (ISegment, []byte) {
|
|||||||
Opt: opt,
|
Opt: opt,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if len(buf) < 8 {
|
||||||
|
return nil, nil
|
||||||
|
}
|
||||||
|
|
||||||
seg.SendingNext = serial.BytesToUint32(buf)
|
seg.SendingNext = serial.BytesToUint32(buf)
|
||||||
buf = buf[4:]
|
buf = buf[4:]
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user