本文整理匯總了Golang中encoding/xml.Escape函數的典型用法代碼示例。如果您正苦於以下問題:Golang Escape函數的具體用法?Golang Escape怎麽用?Golang Escape使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了Escape函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: String
func (s *stream) String() string {
var buf bytes.Buffer
buf.WriteString(`<stream:stream xmlns="`)
buf.WriteString(NsClient)
buf.WriteString(`" xmlns:stream="`)
buf.WriteString(NsStream)
buf.WriteString(`"`)
if s.To != "" {
buf.WriteString(` to="`)
xml.Escape(&buf, []byte(s.To))
buf.WriteString(`"`)
}
if s.From != "" {
buf.WriteString(` from="`)
xml.Escape(&buf, []byte(s.From))
buf.WriteString(`"`)
}
if s.Id != "" {
buf.WriteString(` id="`)
xml.Escape(&buf, []byte(s.Id))
buf.WriteString(`"`)
}
if s.Lang != "" {
buf.WriteString(` xml:lang="`)
xml.Escape(&buf, []byte(s.Lang))
buf.WriteString(`"`)
}
if s.Version != "" {
buf.WriteString(` version="`)
xml.Escape(&buf, []byte(s.Version))
buf.WriteString(`"`)
}
buf.WriteString(">")
return buf.String()
}
示例2: Link
/*
映射端口
POST /ipc HTTP/1.1
HOST: 192.168.1.253:1900
Content-Type: text/xml; charset="utf-8"
Content-Length: 615
SOAPACTION: "urn:schemas-upnp-org:service:WANIPConnection:1#AddPortMapping"
<?xml version="1.0"?>
<s:Envelope xmlns:s="http://schemas.xmlsoap.org/soap/envelope/" s:encodingStyle="http://schemas.xmlsoap.org/soap/encoding/">
<s:Body>
<u:AddPortMapping xmlns:u="urn:schemas-upnp-org:service:WANIPConnection:1">
<NewRemoteHost></NewRemoteHost>
<NewExternalPort>5678</NewExternalPort>
<NewProtocol>TCP</NewProtocol>
<NewInternalPort>3389</NewInternalPort>
<NewInternalClient>192.168.1.100</NewInternalClient>
<NewEnabled>1</NewEnabled>
<NewPortMappingDescription>xxxxxxxx</NewPortMappingDescription>
<NewLeaseDuration>0</NewLeaseDuration>
</u:AddPortMapping>
</s:Body>
</s:Envelope>
*/
func (this *UPnPService) Link(v *AddPortMapping) (err error) {
server_url := "http://" + this.ServerHost + "/ipc"
util.DEBUG.Logf("linking %s : %+v", server_url, v)
buf := bytes.NewBufferString("<?xml version=\"1.0\"?>\r\n")
buf.WriteString("<s:Envelope xmlns:s=\"http://schemas.xmlsoap.org/soap/envelope/\" s:encodingStyle=\"http://schemas.xmlsoap.org/soap/encoding/\">\r\n")
buf.WriteString("<s:Body>\r\n")
buf.WriteString("<u:AddPortMapping xmlns:u=\"urn:schemas-upnp-org:service:WANIPConnection:1\">\r\n")
buf.WriteString("<NewRemoteHost>")
xml.Escape(buf, []byte(v.NewRemoteHost))
buf.WriteString("</NewRemoteHost>\r\n")
buf.WriteString("<NewExternalPort>" + util.ToString(v.NewExternalPort) + "</NewExternalPort>\r\n")
buf.WriteString("<NewProtocol>")
xml.Escape(buf, []byte(v.NewProtocol))
buf.WriteString("</NewProtocol>\r\n")
buf.WriteString("<NewInternalPort>" + util.ToString(v.NewInternalPort) + "</NewInternalPort>\r\n")
buf.WriteString("<NewInternalClient>")
xml.Escape(buf, []byte(v.NewInternalClient))
buf.WriteString("</NewInternalClient>\r\n")
buf.WriteString("<NewEnabled>" + util.ToString(v.NewEnabled) + "</NewEnabled>\r\n")
buf.WriteString("<NewPortMappingDescription>")
xml.Escape(buf, []byte(v.NewPortMappingDescription))
buf.WriteString("</NewPortMappingDescription>\r\n")
buf.WriteString("<NewLeaseDuration>" + util.ToString(v.NewLeaseDuration) + "</NewLeaseDuration>\r\n")
buf.WriteString("</u:AddPortMapping>\r\n</s:Body>\r\n</s:Envelope>\r\n\r\n")
res, err := http.Post(server_url, "text/xml", buf)
if err != nil {
return
}
defer res.Body.Close()
b, err := ioutil.ReadAll(res.Body)
util.DEBUG.Log("\n[response]\n", string(b))
return
}
示例3: Export
func (this *Element) Export(w io.Writer) {
io.WriteString(w, "<")
io.WriteString(w, this.Tag)
keys := make([]string, 0, len(this.attributes))
for k, _ := range this.attributes {
keys = append(keys, k)
}
sort.Strings(keys)
for _, k := range keys {
v := this.attributes[k]
io.WriteString(w, " ")
xml.Escape(w, []byte(k))
io.WriteString(w, "=\"")
xml.Escape(w, []byte(v))
io.WriteString(w, "\"")
}
if this.IsSelfClosing() {
io.WriteString(w, " />")
} else {
io.WriteString(w, ">")
for _, c := range this.children {
c.Export(w)
}
io.WriteString(w, "</")
io.WriteString(w, this.Tag)
io.WriteString(w, ">")
}
}
示例4: atomServer
func (b *blog) atomServer() func(http.ResponseWriter, *http.Request) {
return func(w http.ResponseWriter, r *http.Request) {
w.Header().Set("Content-Type", "application/atom+xml")
fullArticles := make([]fullArticle, len(b.articles))
for i, article := range b.articles {
content, err := b.renderContent(article.Url)
if err != nil {
http.NotFound(w, r)
return
}
var buf bytes.Buffer
xml.Escape(&buf, []byte(content))
fullArticles[i] = fullArticle{
Article: article,
Content: template.HTML(buf.String()),
}
}
atom := &atomData{
Articles: fullArticles,
}
sort.Sort(atom)
atom.Updated = atom.Articles[0].Article.Date
err := b.tmpl.ExecuteTemplate(w, "atom", atom)
if err != nil {
http.Error(w, err.Error(), 500)
}
}
}
示例5: encodeMap
// encodeMap encodes a map to an XML plist dict.
func (e *Encoder) encodeMap(dict map[string]interface{}) error {
err := e.writeString("<dict>\n")
if err != nil {
return err
}
e.indentLevel++
for k, v := range dict {
_, err = e.bw.WriteString(e.indent() + "<key>")
if err != nil {
return err
}
xml.Escape(e.bw, []byte(k))
_, err = e.bw.WriteString("</key>\n")
if err != nil {
return err
}
err = e.encodeAny(v)
if err != nil {
return err
}
}
e.indentLevel--
err = e.writeString("</dict>\n")
if err != nil {
return err
}
return nil
}
示例6: escapeXML
func escapeXML(input []byte) []byte {
var buf *bytes.Buffer = bytes.NewBuffer(make([]byte, 0, len(input)+10))
xml.Escape(buf, input)
return buf.Bytes()
}
示例7: encodeValue
func encodeValue(val reflect.Value) ([]byte, error) {
var b []byte
var err error
if val.Kind() == reflect.Ptr || val.Kind() == reflect.Interface {
if val.IsNil() {
return []byte("<value/>"), nil
}
val = val.Elem()
}
switch val.Kind() {
case reflect.Struct:
switch val.Interface().(type) {
case time.Time:
t := val.Interface().(time.Time)
b = []byte(fmt.Sprintf("<dateTime.iso8601>%s</dateTime.iso8601>", t.Format(iso8601)))
default:
b, err = encodeStruct(val)
}
case reflect.Map:
b, err = encodeMap(val)
case reflect.Slice:
b, err = encodeSlice(val)
case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64:
b = []byte(fmt.Sprintf("<int>%s</int>", strconv.FormatInt(val.Int(), 10)))
case reflect.Uint, reflect.Uint8, reflect.Uint16, reflect.Uint32, reflect.Uint64:
b = []byte(fmt.Sprintf("<i4>%s</i4>", strconv.FormatUint(val.Uint(), 10)))
case reflect.Float32, reflect.Float64:
b = []byte(fmt.Sprintf("<double>%s</double>",
strconv.FormatFloat(val.Float(), 'g', -1, val.Type().Bits())))
case reflect.Bool:
if val.Bool() {
b = []byte("<boolean>1</boolean>")
} else {
b = []byte("<boolean>0</boolean>")
}
case reflect.String:
var buf bytes.Buffer
xml.Escape(&buf, []byte(val.String()))
if _, ok := val.Interface().(Base64); ok {
b = []byte(fmt.Sprintf("<base64>%s</base64>", buf.String()))
} else {
b = []byte(fmt.Sprintf("<value><string>%s</string></value>", buf.String()))
}
default:
return nil, fmt.Errorf("xmlrpc encode error: unsupported type")
}
if err != nil {
return nil, err
}
return []byte(fmt.Sprintf("%s", string(b))), nil
}
示例8: Exec
func (SitemapPlugin) Exec(topCtx mustache.Context) {
base_path := FromCtx(topCtx, "urls.base_path").(string)
f, err := os.OpenFile("compiled"+base_path+"sitemap.xml", os.O_WRONLY|os.O_TRUNC|os.O_CREATE, os.ModePerm)
if err != nil {
log.Println("Error when create sitemap", err)
return
}
defer f.Close()
//自行拚接XML比官方的xml包還靠譜
f.WriteString(`<?xml version="1.0" encoding="UTF-8"?>`)
f.WriteString("\n")
f.WriteString(`<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">`)
f.WriteString("\n")
production_url := FromCtx(topCtx, "site.config.production_url").(string)
production_url_base := FromCtx(topCtx, "site.config.production_url_base").(string)
f.WriteString("\t<url>\n")
f.WriteString("\t\t<loc>")
xml.Escape(f, []byte(production_url+"/")) //夠弱智不? 竟然要傳入一個io.Reader
f.WriteString("</loc>\n")
f.WriteString("\t</url>\n")
post_ids := FromCtx(topCtx, "db.posts.chronological").([]string)
posts := FromCtx(topCtx, "db.posts.dictionary").(map[string]Mapper)
for _, id := range post_ids {
f.WriteString("\t<url>\n")
post := posts[id]
f.WriteString("\t\t<loc>")
xml.Escape(f, []byte(production_url_base))
xml.Escape(f, []byte(post.Url()))
f.WriteString("</loc>\n")
f.WriteString(fmt.Sprintf("\t\t<lastmod>%s</lastmod>\n", post["date"])) // 是否應該抹除呢? 考慮中
f.WriteString("\t\t<changefreq>weekly</changefreq>\n")
f.WriteString("\t</url>\n")
}
f.WriteString(`</urlset>`)
f.Sync()
// ~_~ 大功告成!
}
示例9: escapeString
func (d *Decoder) escapeString(Value string) string {
var b *bytes.Buffer = bytes.NewBuffer([]byte{})
var writer io.Writer = b
var result string
xml.Escape(writer, []byte(Value))
result, _ = b.ReadString(0x00)
return result
}
示例10: Exec
func (SitemapPlugin) Exec(public string, topCtx mustache.Context) {
f, err := os.OpenFile(filepath.Join(public, "/sitemap.xml"), os.O_WRONLY|os.O_TRUNC|os.O_CREATE, DEFAULT_FILE_MODE)
if err != nil {
Log(ERROR, "When create sitemap %s", err)
return
}
defer f.Close()
//自行拚接XML比官方的xml包還靠譜
f.WriteString(`<?xml version="1.0" encoding="UTF-8"?>`)
f.WriteString("\n")
f.WriteString(`<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">`)
f.WriteString("\n")
production_url := FromCtx(topCtx, "site.config.production_url").(string)
f.WriteString("\t<url>\n")
f.WriteString("\t\t<loc>")
xml.Escape(f, []byte(production_url+"/")) //夠弱智不? 竟然要傳入一個io.Reader
f.WriteString("</loc>\n")
f.WriteString("\t</url>\n")
post_ids := FromCtx(topCtx, "db.posts.chronological").([]string)
posts := FromCtx(topCtx, "db.posts.dictionary").(map[string]Mapper)
for _, id := range post_ids {
f.WriteString("\t<url>\n")
post := posts[id]
f.WriteString("\t\t<loc>")
xml.Escape(f, []byte(production_url))
xml.Escape(f, []byte(post.Url()))
f.WriteString("</loc>\n")
f.WriteString(fmt.Sprintf("\t\t<lastmod>%s</lastmod>\n", post["date"])) // 是否應該抹除呢? 考慮中
f.WriteString("\t\t<changefreq>weekly</changefreq>\n")
f.WriteString("\t</url>\n")
}
f.WriteString(`</urlset>`)
f.Sync()
// ~_~ 大功告成!
}
示例11: writeXMLAttr
// Write a xml.Attr.
func writeXMLAttr(w io.Writer, attr xml.Attr) error {
if err := writeXMLName(w, attr.Name); err != nil {
return err
}
if _, err := w.Write([]byte{'=', '\''}); err != nil {
return err
}
xml.Escape(w, []byte(attr.Value))
if _, err := w.Write([]byte{'\''}); err != nil {
return err
}
return nil
}
示例12: postIssueComment
func postIssueComment(ctxt appengine.Context, id, comment string) error {
cfg, err := oauthConfig(ctxt)
if err != nil {
return fmt.Errorf("oauthconfig: %v", err)
}
var tok oauth.Token
if err := app.ReadMeta(ctxt, "codelogin.token", &tok); err != nil {
return fmt.Errorf("reading token: %v", err)
}
tr := &oauth.Transport{
Config: cfg,
Token: &tok,
Transport: urlfetch.Client(ctxt).Transport,
}
client := tr.Client()
var buf bytes.Buffer
buf.WriteString(`<?xml version='1.0' encoding='UTF-8'?>
<entry xmlns='http://www.w3.org/2005/Atom' xmlns:issues='http://schemas.google.com/projecthosting/issues/2009'>
<content type='html'>`)
xml.Escape(&buf, []byte(comment))
buf.WriteString(`</content>
<author>
<name>ignored</name>
</author>
<issues:updates>
</issues:updates>
</entry>
`)
u := "https://code.google.com/feeds/issues/p/go/issues/" + id + "/comments/full"
req, err := http.NewRequest("POST", u, &buf)
if err != nil {
return fmt.Errorf("write: %v", err)
}
req.Header.Set("Content-Type", "application/atom+xml")
resp, err := client.Do(req)
if err != nil {
return fmt.Errorf("write: %v", err)
}
defer resp.Body.Close()
if resp.StatusCode != 201 {
buf.Reset()
io.Copy(&buf, resp.Body)
return fmt.Errorf("write: %v\n%s", resp.Status, buf.String())
}
return nil
}
示例13: encodeString
// encodeString encodes a string to the XML plist format.
func (e *Encoder) encodeString(str string) error {
_, err := e.bw.WriteString(e.indent() + "<string>")
if err != nil {
return err
}
xml.Escape(e.bw, []byte(str))
_, err = e.bw.WriteString("</string>\n")
if err != nil {
return err
}
return nil
}
示例14: encodeStruct
// encodeStruct encodes a struct to an XML plist dict.
func (e *Encoder) encodeStruct(rv reflect.Value) error {
err := e.writeString("<dict>\n")
if err != nil {
return err
}
e.indentLevel++
for i := 0; i < rv.NumField(); i++ {
rt := rv.Type()
f := rt.Field(i)
name := f.Tag.Get("plist")
if name == "-" {
continue
}
if name == "" {
name = f.Name
}
_, err = e.bw.WriteString(e.indent() + "<key>")
if err != nil {
return err
}
xml.Escape(e.bw, []byte(name))
_, err = e.bw.WriteString("</key>\n")
if err != nil {
return err
}
err = e.encodeAny(rv.Field(i).Interface())
if err != nil {
return err
}
}
e.indentLevel--
err = e.writeString("</dict>\n")
if err != nil {
return err
}
return nil
}
示例15: encodeValue
// TODO: base64
func (e *encoder) encodeValue(val reflect.Value) {
if val.Kind() == reflect.Ptr || val.Kind() == reflect.Interface {
val = val.Elem()
}
fmt.Fprint(e, "<value>")
switch val.Kind() {
case reflect.Int, reflect.Int8, reflect.Int16, reflect.Int32, reflect.Int64:
fmt.Fprintf(e, "<int>%d</int>", val.Int())
case reflect.Bool:
var n int
if val.Bool() {
n = 1
} else {
n = 0
}
fmt.Fprintf(e, "<boolean>%d</boolean>", n)
case reflect.String:
fmt.Fprint(e, "<string>")
xml.Escape(e, []byte(val.String()))
fmt.Fprint(e, "</string>")
case reflect.Float32, reflect.Float64:
fmt.Fprintf(e, "<double>%f</double>", val.Float())
case reflect.Struct:
if t, isTime := val.Interface().(time.Time); isTime {
fmt.Fprintf(e, "<dateTime.iso8601>%s</dateTime.iso8601>", t.Format(iso8601))
} else {
e.encodeStruct(val)
}
case reflect.Slice:
e.encodeSlice(val)
}
fmt.Fprint(e, "</value>")
}