2

我有以下代码,我在其中使用名为sleepy的 Go 的 RESTful 框架。

我可以在以下位置成功启动服务:http://localhost:3000,但是当我尝试访问http://localhost:3000/temperature时,我希望我的SparkCore函数dht能够执行。

我正在使用Gobot.io Spark 平台基于此示例执行此功能,该示例已在我自己的代码中实现。

问题是代码没有通过函数gobot.Start()内部的方法,Get()所以我实际上无法返回result数据。

我正在设置data值,希望我能做到:

return 200, data, http.Header{"Content-type": {"application/json"}}

但它永远不会被调用,因为gobot.Start().

我对 Go 很陌生,因此非常感谢任何帮助。

package main

import (
    "net/url"
    "net/http"
    "fmt"
    "github.com/dougblack/sleepy"
    "github.com/hybridgroup/gobot"
    "github.com/hybridgroup/gobot/platforms/spark"
)

var gbot = gobot.NewGobot()
var sparkCore = spark.NewSparkCoreAdaptor("spark", "device_id", "auth_token")

type Temperature struct {}
func (temperature Temperature) Get(values url.Values, headers http.Header) (int, interface{}, http.Header) {
    work := func() {
        if result, err := sparkCore.Function("dht", ""); err != nil {
            fmt.Println(err)
        } else {
            data := map[string]string{"Temperature": result}
            fmt.Println("result from \"dht\":", result)
        }
    }

    robot := gobot.NewRobot("spark",
        []gobot.Connection{sparkCore},
        work,
    )

    gbot.AddRobot(robot)
    gbot.Start()

    return 200, data, http.Header{"Content-type": {"application/json"}}
}

func main() {
    api := sleepy.NewAPI()

    temperatureResource := new(Temperature)
    api.AddResource(temperatureResource, "/temperature")

    fmt.Println("Listening on http://localhost:3000/")
    api.Start(3000)
}
4

1 回答 1

2

gbot.Start()是阻塞调用。

在这种情况下,您应该将其称为:

go gbot.Start() 

这将在 goroutine(思考线程)中启动它,然后让您的应用程序继续。

当您查看gobot 示例应用程序时,它们不会在后台运行,因为它是主要功能。如果 main 在后台运行所有内容并且不等待任何内容,则应用程序会立即退出而没有明显效果。

于 2015-03-25T11:42:16.430 回答