Go基础学习记录 - 编写Web应用程序 - 添加编辑和保存功能(二)

添加编辑和保存功能

继续上篇文章【Go基础学习记录 - 编写Web应用程序 - 添加编辑和保存功能(一)函数

若是将上篇文章的逻辑进行构建并运行,试图访问一个不存在的wiki,好比/view/APageThatDoesntExist,将看到包含HTML的空页面。
这是由于它忽略了loadPage的错误返回值,并继续尝试填写没有数据的模板。
相反,若是请求的页面不存在,它应该将客户端重定### 处理不存在的页面
修改下viewHandler来达到咱们的需求,以下学习

func viewHandler(w http.ResponseWriter, r *http.Request) {
    title := r.URL.Path[len("/view/"):]
    p, err := loadPage(title)
    if err != nil {
        http.Redirect(w, r, "/edit/"+title, http.StatusFound)
        return
    }

    renderTemplate(w, "view", p)
}

http.Redirect函数将HTTP状态代码http.StatusFound(302)和Location头添加到HTTP响应中。
再次构建并运行程序,访问/view/APageThatDoesntExist,会跳转到/edit/APageThatDoesntExist。ui

保存页面功能

根据上篇文章的流程,咱们来添加下saveHandler函数的处理逻辑,它将处理位于编辑页面上的表单的提交。
先在main中加入对应的逻辑,以下code

func main() {
    http.HandleFunc("/view/", viewHandler)
    http.HandleFunc("/edit/", editHandler)
    http.HandleFunc("/save/", saveHandler)
    log.Fatal(http.ListenAndServe(":8090", nil))
}

saveHandler实现处理程序以下:orm

func saveHandler(w http.ResponseWriter, r *http.Request) {
    title := r.URL.Path[len("/save/"):]
    body := r.FormValue("body")
    p := &Page{
        Title: title,
        Body:  []byte(body),
    }
    p.save()
    http.Redirect(w, r, "/view/"+title, http.StatusFound)
}

页面标题(在URL中提供)和表单的惟一字段Body存储在新页面中。
而后调用save()方法将数据写入文件,并将客户端重定向到/view/page。
FormValue返回的值是string类型。
咱们必须将该值转换为[]byte,而后才能适应Page结构。
咱们使用[]byte(body)来执行转换。blog

到这里整个的编辑和存储就都完成了,咱们能够再次进行构建程序,而后启动get

$ go build wiki.go
$ ./wiki

访问view/pageTitle,不存在则进行建立,经过表单提交进行保存,还能够继续修改并保存。string

相关文章
相关标签/搜索