golang 不用框架
时间:2023-05-19 11:42
golang是一门支持并发编程的静态类型编程语言。它在处理大量的web并发请求时表现非常出色,可以轻松地扩展性能。很多人在使用golang时都会使用一些常用的web框架如Beego,Gin,Martini等,但我们可以完全不使用这些框架去编写golang web程序。下面将介绍如何在golang里面实现web开发,不使用第三方框架。 golang的标准库里面已经封装了一些http相关的包,比如net/http。这个包可以用于实现http客户端和服务器。下面是一个简单的http服务器的实现: 通过 golang的标准库里面还有一个模板引擎template,是golang提供的一种模板渲染机制,他支持解析和执行行为定义在 下面是一个使用template的示例: 这个例子中,首先定义了一个模板字符串,然后定义了一个结构体表示填充模板的数据。最后通过template.New方法解析模板,填充数据并将结果输出到浏览器。 golang也可以使用原生的sql包来操作MySQL等数据库。封装了sql.DB以支持连接池和线程安全。下面是一个使用golang原生sql包的示例: 这个例子中使用 通过上述三个例子可以看出,golang也可以在不使用第三方框架的情况下完成web开发。大家可以根据需要找到需要使用的库来进行web开发。当然,在写web项目时建议使用有良好封装和文档支持的第三方框架,毕竟从过程和效率上来看,第三方框架会更加便捷和高效。 以上就是golang 不用框架的详细内容,更多请关注Gxl网其它相关文章!package mainimport ( "fmt" "net/http")func main() { http.HandleFunc("/", func(w http.ResponseWriter, req *http.Request) { fmt.Fprintf(w, "Hello World") }) http.ListenAndServe(":8080", nil)}
http.HandleFunc
方法来设置路由,参数包括访问路径和响应处理函数。线上应用需要使用TLS(Transport Layer Security)认证机制可以使用http.ListenAndServeTLS()
方法。”{{}}”
内部的动作指令。通过这种方式能够很方便的将数据填充到指定的模板里面。package mainimport ( "html/template" "net/http")func main() { http.HandleFunc("/", viewHandler) http.ListenAndServe(":8080", nil)}func viewHandler(writer http.ResponseWriter, request *http.Request) { // 首先定义一个模板字符串 const myTemplateString = ` <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>{{.Title}}</title> </head> <body> {{if .IsUser}} <h1>Hello {{.UserName}}!</h1> {{else}} <h1>Hello guest!</h1> {{end}} </body> </html>` // 定义一个结构体,用于填充模板 type MyTemplateData struct { Title string // 页面标题 IsUser bool // 是否是已经登录的用户 UserName string // 用户名 } // 填充模板 t, err := template.New("myTemplateString").Parse(myTemplateString) if err != nil { panic(err) } data := MyTemplateData{ Title: "My Awesome Page", IsUser: true, UserName: "Gopher", } t.Execute(writer, data)}
package mainimport ( "database/sql" "fmt" _ "github.com/go-sql-driver/mysql")func main() { db, err := sql.Open("mysql", "user:password@tcp(127.0.0.1:3306)/database") if err != nil { fmt.Println(err) } defer db.Close() // 查询数据库 rows, err := db.Query("SELECT * FROM users") if err != nil { fmt.Println(err) } defer rows.Close() for rows.Next() { var id int var name string err = rows.Scan(&id, &name) if err != nil { fmt.Println(err) } fmt.Printf("id: %d, name: %s", id, name) }}
sql.Open()
打开一个MySQL的链接,然后执行了一个查询语句SELECT * FROM users
,通过rows.Next()遍历查询结果集返回的多条记录。