golang进阶(五)——restful开发的json处理

lastsweetop · · 1742 次点击 · · 开始浏览    
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

前言

restful开发时,对象转json,json转对象是非常频繁的操作,怎么样才能少些重复的代码呢,以这个为目的开启这篇文章

所有代码放在github上

简化数据结构

每次需要返回的数据有code,msg,data这些字段,每个类型都加这些字段太繁复了,这里有interface的方式,去代替任意类型,然后使用的时候data字段与其他类型任意的组合

package model

type Resp struct {
    Code string      `json:"code"`
    Msg  string      `json:"msg,omitempty"`
    Data interface{} `json:"data,omitempty"`
}

type User struct {
    Username string `json:"username"`
    Password string `json:"password,omitempty"`
}

json和http请求结合起来

对golang自带的json处理包装,使之可以直接从http请求中读出对象,把对象以json格式输出到响应中

package tools

import (
    "bytes"
    "encoding/json"
    "fmt"
    "io/ioutil"
    "net/http"
)

// MarshalJson 把对象以json格式放到response中
func MarshalJson(w http.ResponseWriter, v interface{}) error {
    data, err := json.Marshal(v)
    if err != nil {
        return err
    }
    fmt.Fprint(w, string(data))
    return nil
}

// UnMarshalJson 从request中取出对象
func UnMarshalJson(req *http.Request, v interface{}) error {
    result, err := ioutil.ReadAll(req.Body)
    if err != nil {
        return err
    }
    json.Unmarshal([]byte(bytes.NewBuffer(result).String()), v)
    return nil
}

调用

经过以上的处理,调用变得相当容易,不需要再做更多的重复编码,代码可读性上大大提高

func UserLoginndler(w http.ResponseWriter, r *http.Request) {
    user := &model.User{}
    tools.UnMarshalJson(r, user)
    resp := &model.Resp{Code: "1001", Msg: "账号或者密码错误"}
    if user.Username == "sweetop" && user.Password == "123456" {
        resp = &model.Resp{Code: "0", Msg: "success"}
    }
    tools.MarshalJson(w, resp)
}

api/user/login

func UserListHandler(w http.ResponseWriter, r *http.Request) {
    resp := &model.Resp{Code: "0", Msg: "success"}
    users := make([]model.User, 0)
    resp.Data = append(users, model.User{Username: "sweetop"})
    tools.MarshalJson(w, resp)
}

api/user/list


有疑问加站长微信联系(非本文作者)

本文来自:CSDN博客

感谢作者:lastsweetop

查看原文:golang进阶(五)——restful开发的json处理

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

1742 次点击  
加入收藏 微博
暂无回复
添加一条新回复 (您需要 登录 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传