Go api работает на компьютере коллеги, конечные точки возвращают 404 на моем? - PullRequest
0 голосов
/ 18 октября 2019

Я создаю базовый API в Go, и после того, как мой код заработал совершенно ранее сегодня, все мои конечные точки возвращают 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", "*")
}

1 Ответ

0 голосов
/ 20 октября 2019

С предоставленной вами информацией мне придется немного угадать.

Ваша ошибка 404 может быть связана с ошибкой базы данных. Когда вы запускаете database, err := sql.Open("mysql", ds), вы открываете соединение, но еще не обязательно проводите аутентификацию.

Добавьте для проверки ping ниже строки sql.Open, например:

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

Кроме того, в своем запросе обязательно добавьте дополнительную информацию в тело ответа, чтобы точно знать, где был создан 404.

...