package main import ( "context" "fmt" pb "github.com/go-kratos/kratos/examples/helloworld/helloworld" "github.com/go-kratos/kratos/v2/errors" "github.com/go-kratos/kratos/v2/log" "github.com/go-kratos/kratos/v2/middleware" "github.com/go-kratos/kratos/v2/middleware/logging" "github.com/go-kratos/kratos/v2/middleware/recovery" transgrpc "github.com/go-kratos/kratos/v2/transport/grpc" transhttp "github.com/go-kratos/kratos/v2/transport/http" ) func main() { callHTTP() callGRPC() } func callHTTP() { logger := log.DefaultLogger conn, err := transhttp.NewClient( context.Background(), transhttp.WithMiddleware( recovery.Recovery(), logging.Client(logger), ), transhttp.WithEndpoint("127.0.0.1:8000"), ) if err != nil { panic(err) } client := pb.NewGreeterHTTPClient(conn) reply, err := client.SayHello(context.Background(), &pb.HelloRequest{Name: "kratos"}) if err != nil { panic(err) } logger.Log(log.LevelInfo, "msg", fmt.Sprintf("[http] SayHello %s\n", reply.Message)) // returns error reply, err = client.SayHello(context.Background(), &pb.HelloRequest{Name: "error"}) if err != nil { logger.Log(log.LevelInfo, "msg", fmt.Sprintf("[http] SayHello error: %v\n", err)) } if errors.IsBadRequest(err) { logger.Log(log.LevelInfo, "msg", fmt.Sprintf("[http] SayHello error is invalid argument: %v\n", err)) } } func callGRPC() { logger := log.DefaultLogger conn, err := transgrpc.DialInsecure( context.Background(), transgrpc.WithEndpoint("127.0.0.1:9000"), transgrpc.WithMiddleware( middleware.Chain( recovery.Recovery(), logging.Client(logger), ), ), ) if err != nil { panic(err) } client := pb.NewGreeterClient(conn) reply, err := client.SayHello(context.Background(), &pb.HelloRequest{Name: "kratos"}) if err != nil { panic(err) } logger.Log(log.LevelInfo, "msg", fmt.Sprintf("[grpc] SayHello %+v", reply)) // returns error _, err = client.SayHello(context.Background(), &pb.HelloRequest{Name: "error"}) if err != nil { logger.Log(log.LevelInfo, "msg", fmt.Sprintf("[grpc] SayHello error: %v", err)) } if errors.IsBadRequest(err) { logger.Log(log.LevelInfo, "msg", fmt.Sprintf("[grpc] SayHello error is invalid argument: %v", err)) } }