


Saya cuba mencipta permintaan API menggunakan Go, protobuf dan SQL Server sebagai pangkalan data saya. Pelayan HTTP saya dimulakan dengan permintaan curl, kembalikan kod: 5
Kod main.go
saya
package main import ( "context" "database/sql" "encoding/json" "fmt" "log" "net" "net/http" "github.com/grpc-ecosystem/grpc-gateway/v2/runtime" pb "github.com/myorg/nb_nb_nb/proto" "google.golang.org/grpc" "google.golang.org/grpc/credentials" _ "google.golang.org/grpc/grpclog/glogger" _ "github.com/denisenkom/go-mssqldb" ) type appServer struct { pb.UnimplementedMyAppServiceServer db *sql.DB } //mssql const ( dbserver = "windows.net" port = 1433 user = "reader" password = "mypassword" database = "dbnm" ) const sqlQuery = ` my query ` func (s *appServer) ExecuteQuery(ctx context.Context, req *pb.QueryRequest) (*pb.QueryResponseList, error) { log.Printf("received: Start Date - %v, End Date - %v", req.GetReportStartDate(), req.GetReportEndDate()) rows, err := s.db.Query(sqlQuery, req.ReportStartDate, req.ReportEndDate) if err != nil { log.Printf("Error executing query: %v", err) return nil, fmt.Errorf("failed to execute query: %v", err) } defer rows.Close() var results []*pb.QueryResponse for rows.Next() { var result pb.QueryResponse err := rows.Scan( //fields ) if err != nil { log.Printf("Error scanning rows: %v", err) return nil, fmt.Errorf("failed to scan rows: %v", err) } results = append(results, &result) } return &pb.QueryResponseList{Responses: results}, nil } func connectDB() (*sql.DB, error) { connectionString := fmt.Sprintf("server=%s;user id=%s;password=%s;port=%d;database=%s", dbserver, user, password, port, database) db, err := sql.Open("mssql", connectionString) if err != nil { return nil, fmt.Errorf("failed to connect to the database: %v", err) } if err := db.Ping(); err != nil { return nil, fmt.Errorf("database connection failed: %v", err) } fmt.Println("Database connection successful") return db, nil } func main() { defer func() { if r := recover(); r != nil { log.Println("Recovered from panic:", r) } }() db, err := connectDB() if err != nil { log.Fatalf("Failed to connect to the database: %v", err) } defer db.Close() log.Println("Starting gRPC server...") lis, err := net.Listen("tcp", ":7777") if err != nil { log.Fatalf("TCP connection failed: %v", err) } else { log.Printf("gRPC Server Listening at %v", lis.Addr()) } size := 1024 * 1024 * 50 s := grpc.NewServer(grpc.MaxRecvMsgSize(size), grpc.MaxSendMsgSize(size)) pb.RegisterMyAppServiceServer(s, &appServer{db: db}) mux := runtime.NewServeMux() opts := []grpc.DialOption{grpc.WithTransportCredentials(credentials.NewClientTLSFromCert(nil, ""))} err = pb.RegisterMyAppServiceHandlerFromEndpoint(context.Background(), mux, ":7777", opts) if err != nil { log.Fatalf("Failed to register gRPC gateway: %v", err) } else { log.Printf("Registered gRPC gateway") } http.HandleFunc("/api/query", func(w http.ResponseWriter, r *http.Request) { startDate := r.URL.Query().Get("startDate") endDate := r.URL.Query().Get("endDate") req := &pb.QueryRequest{ ReportStartDate: startDate, ReportEndDate: endDate, } fmt.Print(req) resp, err := (&appServer{db: db}).ExecuteQuery(r.Context(), req) if err != nil { log.Printf("Error executing query: %v", err) http.Error(w, "Internal Server Error", http.StatusInternalServerError) return } w.Header().Set("Content-Type", "application/json") json.NewEncoder(w).Encode(resp.Responses) }) go func() { log.Println("Starting HTTP server...") err := http.ListenAndServe(":7778", mux) if err != nil { log.Fatalf("HTTP server failed: %v", err) } else { log.Printf("HTTP server started.") } }() if err := s.Serve(lis); err != nil { log.Fatalf("gRPC server failed: %v", err) } else { log.Printf("gRPC, HTTP, and API server started.") } }
go运行server/main.go
Kembali
Database connection successful 2023/12/24 21:48:23 Starting gRPC server... 2023/12/24 21:48:23 gRPC Server Listening at [::]:7777 2023/12/24 21:48:23 Registered gRPC gateway 2023/12/24 21:48:23 Starting HTTP server...
dan permintaan curl (curl -X GET "http://localhost:7778/api/query?startDate=2023-10-01&endDate=2023-10-02"
) kembalikan:
{"code":5, "message":"Not Found", "details":[]}
Apa yang saya hilang dalam kod saya? Mengapa saya tidak boleh mengembalikan sebarang hasil? Firewall saya dimatikan.
Jawapan betul
Nampaknya laluan "/api/query" telah ditakrifkan pada ServeMux lalai, tetapi ServeMux mux digunakan semasa mendengar pada antara muka.
Atas ialah kandungan terperinci Walaupun pelayan HTTP mula menggunakan Go dan protobuf, SQL Server, permintaan itu tidak akan mengembalikan hasilnya. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Anda harus mengambil berat tentang pakej "Strings" di GO kerana ia menyediakan alat untuk mengendalikan data teks, splicing dari rentetan asas hingga pemadanan ekspresi biasa yang maju. 1) Pakej "Strings" menyediakan operasi rentetan yang cekap, seperti fungsi gabungan yang digunakan untuk meresap rentetan untuk mengelakkan masalah prestasi. 2) Ia mengandungi fungsi lanjutan, seperti fungsi ContainSany, untuk memeriksa sama ada rentetan mengandungi set aksara tertentu. 3) Fungsi ganti digunakan untuk menggantikan substrings dalam rentetan, dan perhatian harus dibayar kepada perintah penggantian dan kepekaan kes. 4) Fungsi perpecahan boleh memecah rentetan mengikut pemisah dan sering digunakan untuk pemprosesan ekspresi biasa. 5) Prestasi perlu dipertimbangkan semasa menggunakan, seperti

"Pengekodan/binari" PacketingoisessentialforhandlingbinaryData, menawarkanToolSforreadingandWritingBinaryDatafiently.1) itsupportsbothlittle-endianandbig-endianbyteorders, crucialforcross-sistempatibility.2) thePackAgeAlAgeAllowSworksworks

Menguasai pakej bait di GO boleh membantu meningkatkan kecekapan dan keanggunan kod anda. 1) Pakej bait adalah penting untuk parsing data binari, memproses protokol rangkaian, dan pengurusan memori. 2) Gunakan bytes.buffer untuk secara beransur -ansur membina irisan byte. 3) Pakej bait menyediakan fungsi mencari, menggantikan dan segmen kepingan byte. 4) Jenis bait. 5) Pakej Bytes berfungsi dengan kerjasama pemungut sampah Go, meningkatkan kecekapan pemprosesan data besar.

Anda boleh menggunakan pakej "Strings" dalam pergi untuk memanipulasi rentetan. 1) Gunakan rentetan.Trimspace untuk mengeluarkan aksara ruang putih di kedua -dua hujung rentetan. 2) Gunakan rentetan.split untuk memecah rentetan ke dalam kepingan mengikut pembatas yang ditentukan. 3) Gabungkan kepingan rentetan ke dalam satu rentetan melalui string.join. 4) Gunakan strings.Contains untuk memeriksa sama ada rentetan mengandungi substring tertentu. 5) Gunakan Strings.ReplaceAll untuk melakukan penggantian global. Perhatikan prestasi dan perangkap yang berpotensi apabila menggunakannya.

TheBytespackageingoishyffectiveForbytesLiceManipulation, menawarkanFunctionsforsearching, splitting, aconing, andbuffering.1) usebytes.containstosearchforbyTesequences.2) bytes.splithelpsbreakdownbytesliceslicesingdelimiter.3)

Thealternativestogo'sbytespackageincludethestringspackage, bufiopackage, andcustomstructs.1) thespackagecanbeusedforbytemanipulationbyconvertytestoStringsandback.2) theBufiopackageisidealforhandlarlarglyreamsofbysofbysoFbySoMsoMlyReMsoMsoMsoMsoMlySoMsoMlySoMsofByTreamsofByTreamsofByTreamSoMsoMsoMsofByTreamSoMsoMsoMsoMsoMsoMsoMsoMsoMsoMsoMsoMsoMsoMsoMsoMsoMsoMsoMsoMsoMsoMsOreSofBySoRAm

"Bytes" PacketingoisessentialficientlyManipulatingByteslices, CrucialForbinaryData, NetworkProtocols, danFilei/O.itoffersFunctionsLikeIndexforsearching, BufferForhandlingLargedataSets, Readerforsimulatingstreamreaming, danJoinForeShipseReading, danJoinForeFreameReading

Go'sstringspackageiscrucialforefficientstringstringManipulation, affilingToolSlikestrings.split (), strings.join (), strings.replaceall (), andstrings.contains ()


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

mPDF
mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

Penyesuai Pelayan SAP NetWeaver untuk Eclipse
Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.
