mirror of
https://github.com/inverse-inc/upnp.git
synced 2025-12-24 12:12:37 +08:00
GetGenericPortMappingEntry
This commit is contained in:
87
GetGenericPortMappingEntry.go
Normal file
87
GetGenericPortMappingEntry.go
Normal file
@@ -0,0 +1,87 @@
|
||||
package upnp
|
||||
|
||||
import (
|
||||
"io/ioutil"
|
||||
"log"
|
||||
|
||||
"encoding/xml"
|
||||
"net/http"
|
||||
"strconv"
|
||||
"strings"
|
||||
|
||||
"github.com/davecgh/go-spew/spew"
|
||||
)
|
||||
|
||||
type GetGenericPortMappingEntry struct {
|
||||
upnp *Upnp
|
||||
}
|
||||
|
||||
func (this *GetGenericPortMappingEntry) Send(index string) PortMappingEntry {
|
||||
request := this.buildRequest(index)
|
||||
response, _ := http.DefaultClient.Do(request)
|
||||
resultBody, _ := ioutil.ReadAll(response.Body)
|
||||
var portmap PortMappingEntry
|
||||
spew.Dump(resultBody)
|
||||
if response.StatusCode == 200 {
|
||||
|
||||
portmap, err := this.resolve(string(resultBody))
|
||||
if err != nil {
|
||||
log.Println(err.Error())
|
||||
return portmap
|
||||
}
|
||||
return portmap
|
||||
}
|
||||
return portmap
|
||||
}
|
||||
func (this *GetGenericPortMappingEntry) buildRequest(index string) *http.Request {
|
||||
//请求头
|
||||
header := http.Header{}
|
||||
header.Set("Accept", "text/html, image/gif, image/jpeg, *; q=.2, */*; q=.2")
|
||||
header.Set("SOAPAction", `"urn:schemas-upnp-org:service:WANIPConnection:2#GetGenericPortMappingEntry"`)
|
||||
header.Set("Content-Type", "text/xml")
|
||||
header.Set("Connection", "Close")
|
||||
header.Set("Content-Length", "")
|
||||
|
||||
//请求体
|
||||
body := Node{Name: "SOAP-ENV:Envelope",
|
||||
Attr: map[string]string{"xmlns:SOAP-ENV": `"http://schemas.xmlsoap.org/soap/envelope/"`,
|
||||
"SOAP-ENV:encodingStyle": `"http://schemas.xmlsoap.org/soap/encoding/"`}}
|
||||
childOne := Node{Name: `SOAP-ENV:Body`}
|
||||
childTwo := Node{Name: `m:GetGenericPortMappingEntry`,
|
||||
Attr: map[string]string{"xmlns:m": `"urn:schemas-upnp-org:service:WANIPConnection:2"`}}
|
||||
childList1 := Node{Name: "NewPortMappingIndex", Content: index}
|
||||
|
||||
childTwo.AddChild(childList1)
|
||||
childOne.AddChild(childTwo)
|
||||
body.AddChild(childOne)
|
||||
bodyStr := body.BuildXML()
|
||||
|
||||
//请求
|
||||
request, _ := http.NewRequest("POST", "http://"+this.upnp.Gateway.Host+this.upnp.CtrlUrl,
|
||||
strings.NewReader(bodyStr))
|
||||
request.Header = header
|
||||
request.Header.Set("Content-Length", strconv.Itoa(len([]byte(bodyStr))))
|
||||
return request
|
||||
}
|
||||
|
||||
func (this *GetGenericPortMappingEntry) resolve(result string) (PortMappingEntry, error) {
|
||||
|
||||
res := &GenericRespEnvelope{}
|
||||
err := xml.Unmarshal([]byte(result), res)
|
||||
|
||||
if err != nil {
|
||||
return res.Body.GetResponse, err
|
||||
}
|
||||
|
||||
return res.Body.GetResponse, nil
|
||||
}
|
||||
|
||||
type GenericRespEnvelope struct {
|
||||
XMLName xml.Name
|
||||
Body GenericBody
|
||||
}
|
||||
|
||||
type GenericBody struct {
|
||||
XMLName xml.Name
|
||||
GetResponse PortMappingEntry `xml:"GetGenericPortMappingEntryResponse"`
|
||||
}
|
||||
@@ -4,7 +4,6 @@ import (
|
||||
"io/ioutil"
|
||||
"log"
|
||||
|
||||
// "log"
|
||||
"encoding/xml"
|
||||
"net/http"
|
||||
"strconv"
|
||||
@@ -20,7 +19,6 @@ func (this *GetListOfPortMappings) Send() []PortMappingEntry {
|
||||
response, _ := http.DefaultClient.Do(request)
|
||||
resultBody, _ := ioutil.ReadAll(response.Body)
|
||||
if response.StatusCode == 200 {
|
||||
// log.Println(string(resultBody))
|
||||
portmap, err := this.resolve(string(resultBody))
|
||||
if err != nil {
|
||||
log.Println(err.Error())
|
||||
@@ -30,6 +28,7 @@ func (this *GetListOfPortMappings) Send() []PortMappingEntry {
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
func (this *GetListOfPortMappings) buildRequest() *http.Request {
|
||||
//请求头
|
||||
header := http.Header{}
|
||||
|
||||
2
go.mod
2
go.mod
@@ -1,3 +1,5 @@
|
||||
module github.com/inverse-inc/upnp
|
||||
|
||||
go 1.15
|
||||
|
||||
require github.com/davecgh/go-spew v1.1.1
|
||||
|
||||
6
upnp.go
6
upnp.go
@@ -156,6 +156,12 @@ func (this *Upnp) GetListOfPortMappings() []PortMappingEntry {
|
||||
return portmap
|
||||
}
|
||||
|
||||
func (this *Upnp) GetGenericPortMappingEntry(index string) PortMappingEntry {
|
||||
listPort := GetGenericPortMappingEntry{upnp: this}
|
||||
portmap := listPort.Send(index)
|
||||
return portmap
|
||||
}
|
||||
|
||||
func (this *Upnp) Reclaim() {
|
||||
mappings := this.MappingPort.GetAllMapping()
|
||||
tcpMapping, ok := mappings["TCP"]
|
||||
|
||||
Reference in New Issue
Block a user