[go-micro实战]9 带入参调用http api

本文介绍了使用Go语言实现的微服务API,重点讲解了'/v1/prods'接口的处理,包括如何解析POST请求并调用自定义的prod_helper包生成数据。通过gin-gonic框架和consul注册服务,展示了如何在Go-Micro环境中构建和部署API。
摘要由CSDN通过智能技术生成

helper/prodHelper.go

package helper

type ProdsRequest struct {
	Size int `form:"size"`
}

prod_main.go

package main

import (
	"flag"
	"fmt"
	"gitee.com/Hind3ight/easy-go-micro/go-micro/helper"
	"gitee.com/Hind3ight/easy-go-micro/go-micro/model"
	"github.com/gin-gonic/gin"
	"github.com/micro/go-micro/registry"
	"github.com/micro/go-micro/web"
	"github.com/micro/go-plugins/registry/consul" // micro版本变迁
	"log"
)

func main() {
	consulReg := consul.NewRegistry(registry.Addrs("192.168.31.246:8500"))
	r := gin.Default()
	v1Group := r.Group("/v1")
	{
		v1Group.Handle("POST", "/prods", func(c *gin.Context) {
		var pr helper.ProdsRequest
		err := c.Bind(&pr)
			if err != nil || pr.Size <= 0 {
				pr = helper.ProdsRequest{Size: 2}
			}
			c.JSON(200, gin.H{
				"data":   model.GenFakerProdList(pr.Size),
			})
		})
	}
	server := web.NewService(
		web.Name("prodService"),
		web.Address(flagParser()),
		//web.Address(":8001"),
		web.Handler(r),
		web.Registry(consulReg),
		web.Metadata(map[string]string{"protocol" : "http"}),// 为注册的服务添加Metadata,指定请求协议为http
	)

	err := server.Run()
	if err != nil {
		log.Fatal("Server Run error: ", err)
	}
}

// simple 自定义命令行解析
func flagParser() string {
	serverAddress := flag.String("server_address", ":8080", "服务端口")
	flag.Parse()
	fmt.Println("端口号:", *serverAddress)
	return *serverAddress
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值