我正在Go中构建一个基本的API,在我的代码今天早些时候完美运行之后,我的端点都返回了404。我下面有一个基本的处理函数来说明。

我团队中的其他人能够成功运行此代码,因此我认为这不是实际的代码。我担心我的计算机或浏览器环境中存在某些导致404错误的信息(或者我犯了一个愚蠢的错误)。所有导入均用于其余的api功能。

两条打印行告诉我数据库连接和服务器正在运行,因此程序本身正在运行,但是在今天早上正常工作之后,端点都返回了404。

我可以在这里研究或尝试什么?

我已经重新启动计算机,清除了浏览器缓存,重新启动了服务器等。我尝试过将其关闭然后重新打开的任何版本。

package main

import (
    "database/sql"
    "fmt"
    "log"
    "net/http"
    "os"

    _ "github.com/go-sql-driver/mysql"
    "github.com/gorilla/mux"
    "github.com/joho/godotenv"
)

var port = "8080"
var db *sql.DB
var host string

func main() {
    // Getting environment variables that are secret
    host = "localhost:8080"

    err := godotenv.Load("week2.env")
    if err != nil {
        log.Fatal("Error loading .env file")
    }
    // Connecting to the MySQL database
    pw, _ := os.LookupEnv("MYSQL_ROOT_PASSWORD")
    user, _ := os.LookupEnv("MYSQL_USER")
    ds := fmt.Sprintf("%s:%s@tcp(db:3306)/google_books", user, pw)
    database, err := sql.Open("mysql", ds)
    if err != nil {
        log.Fatal(err)
    }

    fmt.Println("successfully connected to db")
    db = database
    defer db.Close()
    // Setting up a mux router
    router := mux.NewRouter()

    // Telling the server what to listen for and what to do
    router.HandleFunc("/", hello)

    // Creating the server
    fmt.Printf("listening on port %s\n", port)
    err = http.ListenAndServe(":"+port, router)
    if err != nil {
        fmt.Println(err)
    }
}
func hello(w http.ResponseWriter, r *http.Request) {
    setHeaders(w, r)
    fmt.Println("hello world this is the homepage")
}

// setHeaders sets the headers for the response
func setHeaders(w http.ResponseWriter, r *http.Request) {
    w.Header().Set("Access-Control-Allow-Origin", "*")
}

最佳答案

根据您提供的信息,我将不得不猜测一下。

您的404错误可能与数据库错误有关。
运行database, err := sql.Open("mysql", ds)时,您正在打开一个连接,但不一定要进行身份验证。

sql.Open行下方添加一个ping以对其进行测试,如下所示:

err = db.Ping()
if err != nil{
    log.Fatalf("%s", err)
}

另外,在您的请求中,请确保将更多信息添加到响应主体,以便您确切知道404的生成位置。

10-07 13:21
查看更多