演示地址 http://gblog-revel.herokuapp.com/
1.设计Email墙页面
呀,什么是email墙啊,这,博主,随便扯了点东西把,不知到大家西部喜欢,先来做,后面看效果吧。
首先在views/App下新建Emails.html 内容:
{{set . "title" "Email list - GBlog"}} {{set . "ema" "active" }} {{template "header.html" .}} <div class="content"> <div class="email-nav" > <span class="email-tag"> <img src="http://www.gravatar.com/avatar/8b801bb6de1a876f7df749cedb8994a6?s=64" style="border-radius:32px"/> <span>jov123@163.com</span> </span> </div> </div> </div> </body> </html>其中,img的url里面那一串,是博主自己的email加密后的串。后面会教大家怎么做这个东西。
在controllers/app.go加入方法:
func (c App) Emails() revel.Result { return c.Render() }
GET /email App.Emails
ok,看看效果:
好的,现在来实现它。
2.实现email墙
首先在models下新建email.go 内容:
package models import ( "github.com/revel/revel" "labix.org/v2/mgo/bson" "time" "crypto/md5" "io" "fmt" ) type EmailObj struct{ Email string ImgUrl string CDate time.Time } func (dao *Dao) InsertEmail(emailObj *EmailObj) error { emailCollection := dao.session.DB(DbName).C(EmailCollection) emailObj.CDate = time.Now(); h := md5.New() io.WriteString(h, emailObj.Email) emailObj.ImgUrl = fmt.Sprintf("%x", h.Sum(nil)) fmt.Println(emailObj) _,err := emailCollection.Upsert(bson.M{"email": emailObj.Email}, emailObj) if err != nil { revel.WARN.Printf("Unable to save EmailObj: %v error %v", emailObj, err) } return err } func (dao *Dao) FindAllEmails() []EmailObj{ emailCollection := dao.session.DB(DbName).C(EmailCollection) emails := []EmailObj{} query := emailCollection.Find(bson.M{}).Sort("-cdate") query.All(&emails) return emails }
看一下,insert方法,里面我们为url做了md5加密,这个是go自带的东西,只需要引入即可,我这来简单的使用了一下。另外,我们的mgo的Upsert方法,以email为主,如果有这个email,我们就只做更新,如果没人,就做插入,这个策略很不错。
好,在controllers/app.go的Emails方法里面添加:
func (c App) Emails() revel.Result { dao, err := models.NewDao() if err != nil { c.Response.Status = 500 return c.RenderError(err) } defer dao.Close() emails :=dao.FindAllEmails(); return c.Render(emails) }
将views/App/Emails.html最后修改为:
{{set . "title" "Email list - GBlog"}} {{set . "ema" "active" }} {{template "header.html" .}} <div class="content"> <div class="email-nav" > {{if .emails}} {{range $email:= .emails}} <span class="email-tag"> <img src="http://www.gravatar.com/avatar/{{$email.ImgUrl}}?s=64" style="border-radius:32px"/> <span title="last update at:{{$email.CDate.Format "2006-01-02 15:04"}}">{{$email.Email}}</span> </span> {{end}} {{end}} </div> </div> </div> </body> </html>
恩,做完了吗?
当然没有,我们这里做了数据的读取,却没有插入,怎么办呢,好,还记得我们controllers下的以w开头的类吗,这就是我们的入口。
首先在wblog.go的Putup方法中,return之前添加内容:
newEmail := new(models.EmailObj); newEmail.Email = blog.Email; dao.InsertEmail(newEmail);
同样在wcomment.go的Docomment方法中,return之前添加内容:
newEmail := new(models.EmailObj); newEmail.Email = comment.Email; dao.InsertEmail(newEmail);
newEmail := new(models.EmailObj); newEmail.Email = message.Email; dao.InsertEmail(newEmail);
ok,这样,不管是发blog还是评论,还是留言都会为我们增加email。
来看看最后的效果:
nice,你做好了吗?
有疑问加站长微信联系(非本文作者)