登录
首页 >  Golang >  Go问答

Go 中将字符串转换为 json

来源:stackoverflow

时间:2024-04-05 17:36:31 200浏览 收藏

小伙伴们对Golang编程感兴趣吗?是否正在学习相关知识点?如果是,那么本文《Go 中将字符串转换为 json》,就很适合你,本篇文章讲解的知识点主要包括。在之后的文章中也会多多分享相关知识点,希望对大家的知识积累有所帮助!

问题内容

我是 go 新手,正在学习设置 http 服务器。 我想做的是在我的 sql 数据库中返回 10 部电影的 json 输出。但结果输出不是 json 格式。 我用在线json格式化程序检查了输出,输出是json格式的。

我尝试了 json.marshall 和 json.encode,但两者都没有给出所需的结果。

type movie_list struct {
    page int `json:"page"`
    results []movie `json:"results"`
}
type movie struct {
    id      int `json:"id"`
    title   string `json:"title"`
    language    string `json:"language"`
    release_date string `json:"release_date"`
    poster_path string `json:"poster_path"`
    background_path string `json:"background_path"`
    overview string `json:"overview"`
    genre_ids string `json:"genre_ids"`
}
rows,err:=db.query("select * from movies limit 10")

         if err!=nil{
            fmt.println(err)
         }

         var list movie_list
         var tag movie

         for rows.next(){

             err:=rows.scan(&tag.id,&tag.title,&tag.language,&tag.release_date,&tag.poster_path,&tag.background_path,&tag.overview,&tag.genre_ids)
             if err != nil {
             fmt.println(err)
            }

            list.results = append(list.results,tag)
         }

json.newencoder(w).encode(list)

邮递员的输出 -

格式化输出 -

我的整个代码如下(供参考)

package main

import (
    "fmt"
    "log"
    "net/http"
    "encoding/json"
    "database/sql"
    _ "github.com/go-sql-driver/mysql"
    "github.com/gorilla/mux"
    "github.com/davecgh/go-spew/spew"
)


func handleRequests() {
    myRouter := mux.NewRouter().StrictSlash(true)
    myRouter.HandleFunc("/", homePage)
    myRouter.HandleFunc("/movie/top_rated", returnSingleArticle)
    log.Fatal(http.ListenAndServe(":10000", myRouter))
}
type movie_list struct {
    Page int `json:"Page"`
    Results []movie `json:"Results"`
}
type movie struct {
    Id      int `json:"Id"`
    Title   string `json:"Title"`
    Language    string `json:"Language"`
    Release_date string `json:"Release_date"`
    Poster_path string `json:"Poster_path"`
    Background_path string `json:"Background_path"`
    Overview string `json:"Overview"`
    Genre_ids string `json:"Genre_ids"`
}


func homePage(w http.ResponseWriter, r *http.Request) {
    fmt.Fprintf(w, "Welcome to the HomePage!")
    fmt.Println("Endpoint Hit: homePage")
}

func returnSingleArticle(w http.ResponseWriter, r *http.Request) {
    //vars := mux.Vars(r)
    //key := vars["id"]

    db, err := sql.Open("mysql", "root:72574484@tcp(127.0.0.1:3306)/PicturePerfect")
             if err != nil {
                 fmt.Println(err)
                 }else{
                 fmt.Println("Connection Established")
             }
    rows,err:=db.Query("select * from movies limit 10")

         if err!=nil{
            fmt.Println(err)
         }

         var list movie_list
         var tag movie

         for rows.Next(){

             err:=rows.Scan(&tag.Id,&tag.Title,&tag.Language,&tag.Release_date,&tag.Poster_path,&tag.Background_path,&tag.Overview,&tag.Genre_ids)
             if err != nil {
             fmt.Println(err)
            }
            fmt.Println(tag.Id)
            s2, _ := json.Marshal(tag)
            list.Results = append(list.Results,tag)
         }

        err = rows.Err()
        if err != nil {
            fmt.Println(err)
        }

        defer db.Close()


            //fmt.Fprintf(w, "Hello, %q\n", list.Results[3])
            json.NewEncoder(w).Encode(list) 
            spew.Dump(list)
            //fmt.Fprintf(w, "given lamguage, %q\n", tag.Poster_path)



}

func main() {
    handleRequests()

}

解决方案


问题是响应内容类型标头不是 application/json。通过在写入正文之前设置标题来修复。

w.Header().Set("Content-Type", "application/json")
json.NewEncoder(w).Encode(list)

如果应用程序未指定内容类型,则 net/http 服务器会调用 http.DetectConentType 在响应标头中设置内容类型。该函数不检测 json,默认为 text/plain。

今天关于《Go 中将字符串转换为 json》的内容就介绍到这里了,是不是学起来一目了然!想要了解更多关于的内容请关注golang学习网公众号!

声明:本文转载于:stackoverflow 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>