本文整理匯總了Golang中io.WriteString函數的典型用法代碼示例。如果您正苦於以下問題:Golang WriteString函數的具體用法?Golang WriteString怎麽用?Golang WriteString使用的例子?那麽, 這裏精選的函數代碼示例或許可以為您提供幫助。
在下文中一共展示了WriteString函數的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Golang代碼示例。
示例1: sign
// 內容簽名。生成規則:
// A)提取請求方法method(GET或POST);
// B)提取請求url信息,包括Host字段的IP或域名和URI的path部分,注意不包括Host的端口和Path的querystring。請在請求中帶上Host字段,否則將視為無效請求。比如openapi.xg.qq.com/v2/push/single_device或者10.198.18.239/v2/push/single_device;
// C)將請求參數(不包括sign參數)格式化成K=V方式,注意:計算sign時所有參數不應進行urlencode;
// D)將格式化後的參數以K的字典序升序排列,拚接在一起,注意字典序中大寫字母在前;
// E)拚接請求方法、url、排序後格式化的字符串以及應用的secret_key;
// F)將E形成字符串計算MD5值,形成一個32位的十六進製(字母小寫)字符串,即為本次請求sign(簽名)的值;
// Sign=MD5($http_method$url$k1=$v1$k2=$v2$secret_key); 該簽名值基本可以保證請求是合法者發送且參數沒有被修改,但無法保證不被偷窺。
// 例如: POST請求到接口http://openapi.xg.qq.com/v2/push/single_device,有四個參數,access_id=123,timestamp=1386691200,Param1=Value1,Param2=Value2,secret_key為abcde。則上述E步驟拚接出的字符串為POSTopenapi.xg.qq.com/v2/push/single_deviceParam1=Value1Param2=Value2access_id=123timestamp=1386691200abcde,注意字典序中大寫在前。計算出該字符串的MD5為ccafecaef6be07493cfe75ebc43b7d53,以此作為sign參數的值
func (xgpush *XGPush) sign(method string, device_type int, params map[string]string) (err error) {
var secret_key string
switch device_type {
case XGPushDeviceType_IOS:
params["environment"] = xgpush.Param_environment
params["access_id"] = xgpush.Param_ios_access_id
secret_key = xgpush.Param_ios_secret_key
case XGPushDeviceType_Android:
params["access_id"] = xgpush.Param_android_access_id
secret_key = xgpush.Param_android_secret_key
default:
return ErrUnknownDeviceType
}
if _, found := params["timestamp"]; !found {
params["timestamp"] = strconv.FormatInt(time.Now().Unix(), 10)
}
//params["valid_time"] = XGPUSH_VALID_TIME
h := md5.New()
io.WriteString(h, XGPUSH_METHOD)
io.WriteString(h, XGPUSH_V2_BASE_URL)
io.WriteString(h, method)
var kvs []string
for key, value := range params {
kvs = append(kvs, key+"="+value)
}
sort.Sort(sort.StringSlice(kvs))
for _, kv := range kvs {
io.WriteString(h, kv)
}
io.WriteString(h, secret_key)
params["sign"] = fmt.Sprintf("%x", h.Sum(nil))
return
}
示例2: escapeString
// mysql_real_escape_string() “\”, “'”, “"”, NUL (ASCII 0), “\n”, “\r”, and Control+Z
func escapeString(txt string) string {
var (
esc string
buf bytes.Buffer
)
last := 0
for ii, bb := range txt {
switch bb {
case 0:
esc = `\0`
case '\n':
esc = `\n`
case '\r':
esc = `\r`
case '\\':
esc = `\\`
case '\'':
esc = `\'`
case '"':
esc = `\"`
case '\032':
esc = `\Z`
default:
continue
}
io.WriteString(&buf, txt[last:ii])
io.WriteString(&buf, esc)
last = ii + 1
}
io.WriteString(&buf, txt[last:])
return buf.String()
}
示例3: ListFilesHandlers
//--------------------------------------
//文件管理邏輯
//
//KindEditor提交參數:
//dir{"image", "flash", "media", "file"},默認"image"
//path,默認"",格式:"2014年","2014年1月","201401-<filename>"
//order,默認"name"
//
//返回給KindEditor的參數:
//moveup_dir_path": "",
//"current_dir_path": "",
//"current_url": "/ke4/php/../attached/",
//"total_count": 5,
//"file_list": [
//
//{
// "is_dir": false,
// "has_file": false,
// "filesize": 208736,
// "is_photo": true,
// "filetype": "jpg",
// "filename": "1241601537255682809.jpg",
// "datetime": "2011-08-02 15:32:43"
//},
//{
// "is_dir": true,
// "has_file": (file.listFiles() != null),
// "filesize": 0L,
// "is_photo": false,
// "filetype": "",
// "filename": file.getName(),
// "datetime": "2011-08-02 15:32:43"
//},
//--------------------------------------
//martini handler
func ListFilesHandlers() []martini.Handler {
var bind = binding.Bind(ListReqData{})
var listHandler = func(data ListReqData, w http.ResponseWriter, r *http.Request) {
if strings.ToUpper(data.Dir) != "IMAGE" {
data.Err(w, "dir should be IMAGE")
return
}
//根據path建立KindList
list := &KindList{CurrentDirPath: strings.TrimSuffix(data.Path, "/")}
switch length := len([]rune(list.CurrentDirPath)); length {
case 0: //""
listYears(r, list)
case 5: //"2014年, 2014年"
if err := listMonths(r, list); err != nil {
data.Err(w, err.Error())
return
}
case 7, 8: //"2014年4月"
if err := listFiles(&data, list); err != nil {
data.Err(w, err.Error())
return
}
default:
data.Err(w, `Path wrong:`+data.Path)
return
}
io.WriteString(w, data.Callback+"(")
resJson(w, list)
io.WriteString(w, ")")
}
return []martini.Handler{bind, listHandler}
}
示例4: doLogin
/**
* 登錄處理
*/
func doLogin(w http.ResponseWriter, r *http.Request) {
r.ParseForm()
manageName := r.Form["manage_name"][0]
password := r.Form["password"][0]
code := r.Form["code"][0]
if manageName == "" || password == "" || code == "" {
io.WriteString(w, "<script type='text/javascript'>location.href='/login'</script>")
}
//判斷驗證碼是否正確
imagecode := getSession(w, r, imageCodeKey)
if code == imagecode {
//判斷賬號和密碼是否正確
userInfo, err := checkLogin(manageName, getSha1(password))
if err != nil {
io.WriteString(w, "<script type='text/javascript'>location.href='/login'</script>")
} else {
setSession(w, r, manageIdKey, userInfo["manage_id"])
io.WriteString(w, "<script type='text/javascript'>location.href='/admin'</script>")
}
} else {
io.WriteString(w, "<script type='text/javascript'>location.href='/login'</script>")
}
}
示例5: GenerateId
//生成節點id
func GenerateId() Id {
random := rand.New(rand.NewSource(time.Now().UnixNano()))
h := sha1.New()
io.WriteString(h, time.Now().String())
io.WriteString(h, string(random.Int()))
return h.Sum(nil)
}
示例6: jsonify
// Generate JSON output
func jsonify(w http.ResponseWriter, r *http.Request, question []dns.Question, answer []dns.RR, authority []dns.RR, additional []dns.RR) {
var answerArray, authorityArray, additionalArray []*Section
callback := r.URL.Query().Get("callback")
for _, answer := range answer {
answerArray = append(answerArray, &Section{answer.Header().Name, dns.TypeToString[answer.Header().Rrtype], dns.ClassToString[answer.Header().Class], answer.Header().Ttl, answer.Header().Rdlength, rdata(answer)})
}
for _, authority := range authority {
authorityArray = append(authorityArray, &Section{authority.Header().Name, dns.TypeToString[authority.Header().Rrtype], dns.ClassToString[authority.Header().Class], authority.Header().Ttl, authority.Header().Rdlength, rdata(authority)})
}
for _, additional := range additional {
additionalArray = append(additionalArray, &Section{additional.Header().Name, dns.TypeToString[additional.Header().Rrtype], dns.ClassToString[additional.Header().Class], additional.Header().Ttl, additional.Header().Rdlength, rdata(additional)})
}
if json, err := json.MarshalIndent(Message{[]*Question{&Question{question[0].Name, dns.TypeToString[question[0].Qtype], dns.ClassToString[question[0].Qclass]}}, answerArray, authorityArray, additionalArray}, "", " "); err == nil {
if callback != "" {
io.WriteString(w, callback+"("+string(json)+");")
} else {
io.WriteString(w, string(json))
}
}
}
示例7: bEncode
// bEncode encodes s using base64 encoding and writes it to buf.
func (e WordEncoder) bEncode(buf *bytes.Buffer, charset, s string) {
w := base64.NewEncoder(base64.StdEncoding, buf)
// If the charset is not UTF-8 or if the content is short, do not bother
// splitting the encoded-word.
if !isUTF8(charset) || base64.StdEncoding.EncodedLen(len(s)) <= maxContentLen {
io.WriteString(w, s)
w.Close()
return
}
var currentLen, last, runeLen int
for i := 0; i < len(s); i += runeLen {
// Multi-byte characters must not be split accross encoded-words.
// See RFC 2047, section 5.3.
_, runeLen = utf8.DecodeRuneInString(s[i:])
if currentLen+runeLen <= maxBase64Len {
currentLen += runeLen
} else {
io.WriteString(w, s[last:i])
w.Close()
e.splitWord(buf, charset)
last = i
currentLen = runeLen
}
}
io.WriteString(w, s[last:])
w.Close()
}
示例8: commandHandler
func commandHandler(res http.ResponseWriter, req *http.Request) {
req.ParseForm()
command := new(SlackCommand)
decoder := schema.NewDecoder()
err := decoder.Decode(command, req.PostForm)
if err != nil {
res.WriteHeader(400)
io.WriteString(res, "Invalid form data\n")
return
}
if command.Token != config.IncomingToken {
res.WriteHeader(403)
io.WriteString(res, "Invalid token\n")
return
}
user, created := userStore.GetOrAdd(command.UserID)
if created {
user.UserName = command.UserName
}
commandFunc, exists := commands[command.getSubCommand()]
if !exists {
commandFunc = commands["help"]
}
err = commandFunc(command, user)
if err != nil {
res.WriteHeader(400)
io.WriteString(res, err.Error())
}
}
示例9: Quote
func (l List) Quote(w io.Writer, t Type) error {
_, err := io.WriteString(w, "[ ")
if err != nil {
return err
}
lt, isList := t.(ListType)
if !isList {
return fmt.Errorf("internal error: %v is not a list", t.Name())
}
for i, v := range l {
if i != 0 {
_, err = io.WriteString(w, ", ")
if err != nil {
return err
}
}
if err := v.Quote(w, lt.Elem); err != nil {
return err
}
}
_, err = io.WriteString(w, " ]")
return err
}
示例10: RegisterHandler
func RegisterHandler(w http.ResponseWriter, r *http.Request) {
if r.Method == "GET" {
tmpl, _ := template.ParseFiles("./static/adduser.html")
tmpl.Execute(w, "")
return
}
username := r.FormValue("user")
pwd := r.FormValue("pwd")
pwdConfirm := r.FormValue("pwd_confirm")
user := dao.QueryUserByUserName(username)
if user != nil {
io.WriteString(w, "user "+username+"alread exists")
return
}
if pwd == "" || pwd != pwdConfirm {
io.WriteString(w, "password confirm error, not the same one!")
return
}
user = new(dao.User)
user.UserName = username
user.Name = username
user.Pwd = wb_util.CreateMD5String(pwd)
dao.CreateUser(user)
dao.RegistUser(user)
msg := "register success!!!"
tmpl, _ := template.ParseFiles("./static/success.html")
tmpl.Execute(w, msg)
}
示例11: handlePing
func (svc *GoPushService) handlePing(w http.ResponseWriter, r *http.Request) {
if r.Method != "GET" {
serve404(w)
return
}
v, _ := url.ParseQuery(r.URL.RawQuery)
center := v.Get("center")
callback := v.Get("callback") // For JSONP
if _, ok := svc.lastState[center]; center == "" || !ok {
serve404(w)
return
}
if callback == "" { // Normal response
w.Header().Set("Content-Type", "text/plain; charset=utf-8")
w.WriteHeader(http.StatusOK)
io.WriteString(w, svc.lastState[center])
} else { // JSONP response
w.Header().Set("Content-Type", "application/javascript; charset=utf-8")
w.WriteHeader(http.StatusOK)
marshaled, _ := json.Marshal(svc.lastState[center])
io.WriteString(w, callback+"("+string(marshaled)+");")
}
}
示例12: pushHandler
func pushHandler(w http.ResponseWriter, r *http.Request, backend *dbBackend) {
decoder := json.NewDecoder(r.Body)
decoder.UseNumber()
var ent map[string]interface{}
e := decoder.Decode(&ent)
if nil != e {
w.WriteHeader(http.StatusBadRequest)
io.WriteString(w, e.Error())
return
}
job, e := createJobFromMap(backend, ent)
if nil != e {
w.WriteHeader(http.StatusInternalServerError)
io.WriteString(w, e.Error())
return
}
e = backend.create(job)
if nil != e {
w.WriteHeader(http.StatusInternalServerError)
io.WriteString(w, e.Error())
return
}
w.WriteHeader(http.StatusOK)
io.WriteString(w, "OK")
return
}
示例13: testJobHandler
func testJobHandler(w http.ResponseWriter, r *http.Request, backend *dbBackend) {
decoder := json.NewDecoder(r.Body)
decoder.UseNumber()
var ent map[string]interface{}
e := decoder.Decode(&ent)
if nil != e {
w.WriteHeader(http.StatusBadRequest)
io.WriteString(w, e.Error())
return
}
job, e := createJobFromMap(backend, ent)
if nil != e {
w.WriteHeader(http.StatusInternalServerError)
io.WriteString(w, e.Error())
return
}
if args, _ := job.attributes(); args != nil {
if _, ok := args["content"]; !ok {
args["content"] = "this is test job message."
}
}
e = job.invokeJob()
if nil != e {
w.WriteHeader(http.StatusInternalServerError)
io.WriteString(w, e.Error())
return
}
w.WriteHeader(http.StatusOK)
io.WriteString(w, "OK")
return
}
示例14: countsHandler
func countsHandler(w http.ResponseWriter, r *http.Request, backend *dbBackend) {
var all_size, failed_size, queued_size, active_size int64
var e error
all_size, e = backend.count(nil)
if nil != e {
goto failed
}
failed_size, e = backend.count(map[string]interface{}{"@failed_at": "[notnull]"})
if nil != e {
goto failed
}
queued_size, e = backend.count(map[string]interface{}{"@failed_at": nil, "locked_by": nil})
if nil != e {
goto failed
}
active_size, e = backend.count(map[string]interface{}{"@failed_at": nil, "locked_by": "[notnull]"})
if nil != e {
goto failed
}
w.Header()["Content-Type"] = []string{"application/json; charset=utf-8"}
io.WriteString(w, fmt.Sprintf(`{"all":%v,"failed":%v,"active":%v,"queued":%v}`, all_size, failed_size, active_size, queued_size))
return
failed:
w.Header()["Content-Type"] = []string{"text/plain; charset=utf-8"}
w.WriteHeader(http.StatusInternalServerError)
io.WriteString(w, e.Error())
return
}
示例15: genToken
// create a csrf token
func (cf *Csrf) genToken(salt, secret string) string {
h := sha1.New()
io.WriteString(h, salt)
io.WriteString(h, "-")
io.WriteString(h, secret)
return salt + "-" + base64.StdEncoding.EncodeToString(h.Sum(nil))
}