mirror of
https://github.com/nadoo/glider.git
synced 2025-02-23 17:35:40 +08:00
dns: check bytes length in unmarshal message
This commit is contained in:
parent
5467e4bbc1
commit
b27f153426
@ -134,6 +134,7 @@ func (c *Client) exchange(qname string, reqBytes []byte, preferTCP bool) (server
|
|||||||
if err == nil {
|
if err == nil {
|
||||||
break
|
break
|
||||||
}
|
}
|
||||||
|
|
||||||
log.F("[dns] failed to exchange with server %v: %v", server, err)
|
log.F("[dns] failed to exchange with server %v: %v", server, err)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -119,6 +119,10 @@ func (m *Message) Marshal() ([]byte, error) {
|
|||||||
|
|
||||||
// UnmarshalMessage unmarshals []bytes to Message
|
// UnmarshalMessage unmarshals []bytes to Message
|
||||||
func UnmarshalMessage(b []byte) (*Message, error) {
|
func UnmarshalMessage(b []byte) (*Message, error) {
|
||||||
|
if len(b) <= 2+HeaderLen {
|
||||||
|
return nil, errors.New("UnmarshalMessage: not enough data")
|
||||||
|
}
|
||||||
|
|
||||||
m := &Message{unMarshaled: b}
|
m := &Message{unMarshaled: b}
|
||||||
err := UnmarshalHeader(b[:HeaderLen], &m.Header)
|
err := UnmarshalHeader(b[:HeaderLen], &m.Header)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
@ -280,6 +284,10 @@ func (m *Message) UnmarshalQuestion(b []byte, q *Question) (n int, err error) {
|
|||||||
return 0, errors.New("unmarshal question must not be nil")
|
return 0, errors.New("unmarshal question must not be nil")
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if len(b) <= 5 {
|
||||||
|
return 0, errors.New("UnmarshalQuestion: not enough data")
|
||||||
|
}
|
||||||
|
|
||||||
domain, idx, err := m.UnmarshalDomain(b)
|
domain, idx, err := m.UnmarshalDomain(b)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return 0, err
|
return 0, err
|
||||||
|
Loading…
Reference in New Issue
Block a user