douzhong2954 2017-06-18 04:14
浏览 205
已采纳

gin-gonic json转换输出抛出空数组

for the following golang program, i'm not able to get json output using gin-gonic library, if i do fmt.Print variable shows values, but when i convert to c.JSON (inventory) out it shows empty array, what is wrong with my code?

   package main

import (
    "database/sql"
    "os"

    "github.com/gin-gonic/gin"
    _ "github.com/go-sql-driver/mysql"
)

func index(c *gin.Context) {
    hostname, err := os.Hostname()
    checkErr(err)
    c.String(200, "v3 "+hostname)
}

func healthz(c *gin.Context) {
    c.String(200, "OK")
}

type InventoryItem struct {
    id                 int
    productID          string
    productCost        int
    productAvailabilty int
    productSubcat      string
}

func checkErr(err error) {
    if err != nil {
        panic(err)
    }
}

/*******************  MAIN Function **************/
func main() {
    app := gin.Default()
    app.GET("/", index)
    app.GET("/healthz", healthz)
    app.GET("/inventory", fetch)
    app.Run(":8000")
}

/******************* End MAIN Function **************/

func fetch(c *gin.Context) {
    var (
        invt      InventoryItem
        inventory []InventoryItem
    )
    connStr := os.Getenv("sql_user") + ":" + os.Getenv("sql_password") + "@tcp(" + os.Getenv("sql_host") + ":3306)/" + os.Getenv("sql_db")
    db, err := sql.Open("mysql", connStr)
    checkErr(err)
    defer db.Close()
    rows, err := db.Query("SELECT id,product_id as productID,product_cost as productCost,product_availabilty as productAvailabilty,product_subcat as productSubcat FROM inventory;")
    for rows.Next() {
        err = rows.Scan(&invt.id, &invt.productID, &invt.productCost, &invt.productAvailabilty, &invt.productSubcat)
        checkErr(err)
        inventory = append(inventory, invt)
    }

    checkErr(err)
    defer rows.Close()
    //fmt.Print(inventory[0].productAvailabilty)
    c.JSON(200, inventory)
}
  • 写回答

1条回答 默认 最新

  • duan1983 2017-06-18 04:30
    关注

    Issue is InventoryItem struct fields have to be exported -

    type InventoryItem struct {
       ID                 int    `json:"id"`
       ProductID          string `json:"product_id"`
       ProductCost        int    `json:"product_cost"`
       ProductAvailabilty int    `json:"product_availability"`
       ProductSubcat      string `json:"product_subact"`
    }
    

    Read more about exported and un-exported fields.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥30 关于用python写支付宝扫码付异步通知收不到的问题
  • ¥50 vue组件中无法正确接收并处理axios请求
  • ¥15 隐藏系统界面pdf的打印、下载按钮
  • ¥15 MATLAB联合adams仿真卡死如何解决(代码模型无问题)
  • ¥15 基于pso参数优化的LightGBM分类模型
  • ¥15 安装Paddleocr时报错无法解决
  • ¥15 python中transformers可以正常下载,但是没有办法使用pipeline
  • ¥50 分布式追踪trace异常问题
  • ¥15 人在外地出差,速帮一点点
  • ¥15 如何使用canvas在图片上进行如下的标注,以下代码不起作用,如何修改