zoukankan      html  css  js  c++  java
  • 1.基础入门

    第一步创建UserService

    package Services
    
    type IUserService interface {
        GetName(userid int) string
    }
    
    type UserService struct{}
    
    func (this UserService) GetName(userid int) string {
        if userid == 101 {
            return "jerry"
        }
        return "guest"
    }
    

    第二部:创建UserEndPoint

    package Services
    
    import (
        "context"
        "github.com/go-kit/kit/endpoint"
    )
    
    type UserRequest struct { //封装User请求结构体
        Uid int `json:"uid"`
    }
    
    type UserResponse struct {
        Result string `json:"result"`
    }
    
    func GenUserEnPoint(userService IUserService) endpoint.Endpoint {
        return func(ctx context.Context, request interface{}) (response interface{}, err error) {
            r := request.(UserRequest)           //通过类型断言获取请求结构体
            result := userService.GetName(r.Uid) //
            return UserResponse{Result: result}, nil
        }
    }
    

    第三部:创建Transport

    创建UserTransport

    package Services
    
    import (
        "context"
        "encoding/json"
        "errors"
        "net/http"
        "strconv"
    )
    
    func DecodeUserRequest(c context.Context, r *http.Request) (interface{}, error) { //这个函数决定了使用哪个request结构体来请求
        if r.URL.Query().Get("uid") != "" {
            uid, _ := strconv.Atoi(r.URL.Query().Get("uid"))
            return UserRequest{Uid: uid}, nil
        }
        return nil,errors.New("参数错误")/
    }
    
    func EncodeUserResponse(ctx context.Context,w http.ResponseWriter,response interface{}) error{
        w.Header().Set("Content-type","application/json") //设置响应格式为json,这样客户端接收到的值就是json,就是把我们设置的UserResponse给json化了
    
        return json.NewEncoder(w).Encode(response)//判断响应格式是否正确
    }

    一般是三层架构三个文件夹,我这里演示方便把三层的东西都放到了一个中





  • 相关阅读:
    LINUX系统运行查看
    MySQL数据库中tinyint类型字段读取数据为true和false (MySQL的boolean和tinyint(1))
    mysql DATE_FORMAT 年月日时分秒格式化
    fastJson泛型如何转换
    查找java程序进程快速指令jps
    vim快捷键
    mysql全库搜索指定字符串
    mysql一次性删除所有表而不删除数据库
    一键安装Docker图形化管理界面-Shipyard
    hadoop性能测试
  • 原文地址:https://www.cnblogs.com/hualou/p/12076155.html
Copyright © 2011-2022 走看看