mirror of
https://gitee.com/johng/gf
synced 2026-06-07 02:12:11 +08:00
ghttp.Response方法完善,增加ParseTpl/ParseTplContent/TplContent方法,Template修改为Tpl方法
This commit is contained in:
@ -23,14 +23,14 @@ func NewIntBoolMap() *IntBoolMap {
|
||||
}
|
||||
|
||||
// 哈希表克隆
|
||||
func (this *IntBoolMap) Clone() *map[int]bool {
|
||||
func (this *IntBoolMap) Clone() map[int]bool {
|
||||
m := make(map[int]bool)
|
||||
this.mu.RLock()
|
||||
for k, v := range this.m {
|
||||
m[k] = v
|
||||
}
|
||||
this.mu.RUnlock()
|
||||
return &m
|
||||
return m
|
||||
}
|
||||
|
||||
// 给定回调函数对原始内容进行遍历,回调函数返回true表示继续遍历,否则停止遍历
|
||||
|
||||
@ -34,14 +34,14 @@ func (this *IntIntMap) Iterator(f func (k int, v int) bool) {
|
||||
}
|
||||
|
||||
// 哈希表克隆
|
||||
func (this *IntIntMap) Clone() *map[int]int {
|
||||
func (this *IntIntMap) Clone() map[int]int {
|
||||
m := make(map[int]int)
|
||||
this.mu.RLock()
|
||||
for k, v := range this.m {
|
||||
m[k] = v
|
||||
}
|
||||
this.mu.RUnlock()
|
||||
return &m
|
||||
return m
|
||||
}
|
||||
|
||||
// 设置键值对
|
||||
|
||||
@ -34,14 +34,14 @@ func (this *IntInterfaceMap) Iterator(f func (k int, v interface{}) bool) {
|
||||
}
|
||||
|
||||
// 哈希表克隆
|
||||
func (this *IntInterfaceMap) Clone() *map[int]interface{} {
|
||||
func (this *IntInterfaceMap) Clone() map[int]interface{} {
|
||||
m := make(map[int]interface{})
|
||||
this.mu.RLock()
|
||||
for k, v := range this.m {
|
||||
m[k] = v
|
||||
}
|
||||
this.mu.RUnlock()
|
||||
return &m
|
||||
return m
|
||||
}
|
||||
|
||||
// 设置键值对
|
||||
|
||||
@ -34,14 +34,14 @@ func (this *IntStringMap) Iterator(f func (k int, v string) bool) {
|
||||
}
|
||||
|
||||
// 哈希表克隆
|
||||
func (this *IntStringMap) Clone() *map[int]string {
|
||||
func (this *IntStringMap) Clone() map[int]string {
|
||||
m := make(map[int]string)
|
||||
this.mu.RLock()
|
||||
for k, v := range this.m {
|
||||
m[k] = v
|
||||
}
|
||||
this.mu.RUnlock()
|
||||
return &m
|
||||
return m
|
||||
}
|
||||
|
||||
// 设置键值对
|
||||
|
||||
@ -34,14 +34,14 @@ func (this *InterfaceInterfaceMap) Iterator(f func (k interface{}, v interface{}
|
||||
}
|
||||
|
||||
// 哈希表克隆
|
||||
func (this *InterfaceInterfaceMap) Clone() *map[interface{}]interface{} {
|
||||
func (this *InterfaceInterfaceMap) Clone() map[interface{}]interface{} {
|
||||
m := make(map[interface{}]interface{})
|
||||
this.mu.RLock()
|
||||
for k, v := range this.m {
|
||||
m[k] = v
|
||||
}
|
||||
this.mu.RUnlock()
|
||||
return &m
|
||||
return m
|
||||
}
|
||||
|
||||
// 设置键值对
|
||||
|
||||
@ -34,14 +34,14 @@ func (this *StringBoolMap) Iterator(f func (k string, v bool) bool) {
|
||||
}
|
||||
|
||||
// 哈希表克隆
|
||||
func (this *StringBoolMap) Clone() *map[string]bool {
|
||||
func (this *StringBoolMap) Clone() map[string]bool {
|
||||
m := make(map[string]bool)
|
||||
this.mu.RLock()
|
||||
for k, v := range this.m {
|
||||
m[k] = v
|
||||
}
|
||||
this.mu.RUnlock()
|
||||
return &m
|
||||
return m
|
||||
}
|
||||
|
||||
// 设置键值对
|
||||
|
||||
@ -34,14 +34,14 @@ func (this *StringIntMap) Iterator(f func (k string, v int) bool) {
|
||||
}
|
||||
|
||||
// 哈希表克隆
|
||||
func (this *StringIntMap) Clone() *map[string]int {
|
||||
func (this *StringIntMap) Clone() map[string]int {
|
||||
m := make(map[string]int)
|
||||
this.mu.RLock()
|
||||
for k, v := range this.m {
|
||||
m[k] = v
|
||||
}
|
||||
this.mu.RUnlock()
|
||||
return &m
|
||||
return m
|
||||
}
|
||||
|
||||
// 设置键值对
|
||||
|
||||
@ -34,14 +34,14 @@ func (this *StringInterfaceMap) Iterator(f func (k string, v interface{}) bool)
|
||||
}
|
||||
|
||||
// 哈希表克隆
|
||||
func (this *StringInterfaceMap) Clone() *map[string]interface{} {
|
||||
func (this *StringInterfaceMap) Clone() map[string]interface{} {
|
||||
m := make(map[string]interface{})
|
||||
this.mu.RLock()
|
||||
for k, v := range this.m {
|
||||
m[k] = v
|
||||
}
|
||||
this.mu.RUnlock()
|
||||
return &m
|
||||
return m
|
||||
}
|
||||
|
||||
// 设置键值对
|
||||
|
||||
@ -34,14 +34,14 @@ func (this *StringStringMap) Iterator(f func (k string, v string) bool) {
|
||||
}
|
||||
|
||||
// 哈希表克隆
|
||||
func (this *StringStringMap) Clone() *map[string]string {
|
||||
func (this *StringStringMap) Clone() map[string]string {
|
||||
m := make(map[string]string)
|
||||
this.mu.RLock()
|
||||
for k, v := range this.m {
|
||||
m[k] = v
|
||||
}
|
||||
this.mu.RUnlock()
|
||||
return &m
|
||||
return m
|
||||
}
|
||||
|
||||
// 设置键值对
|
||||
|
||||
@ -33,14 +33,14 @@ func (this *UintInterfaceMap) Iterator(f func (k uint, v interface{}) bool) {
|
||||
}
|
||||
|
||||
// 哈希表克隆
|
||||
func (this *UintInterfaceMap) Clone() *map[uint]interface{} {
|
||||
func (this *UintInterfaceMap) Clone() map[uint]interface{} {
|
||||
m := make(map[uint]interface{})
|
||||
this.mu.RLock()
|
||||
for k, v := range this.m {
|
||||
m[k] = v
|
||||
}
|
||||
this.mu.RUnlock()
|
||||
return &m
|
||||
return m
|
||||
}
|
||||
|
||||
// 设置键值对
|
||||
|
||||
@ -59,7 +59,7 @@ func (view *View) BindFunc(name string, function interface{}){
|
||||
func (view *View) Parse(file string) ([]byte, error) {
|
||||
view.mu.RLock()
|
||||
defer view.mu.RUnlock()
|
||||
buffer, err := view.view.Parse(file, view.data, view.fmap)
|
||||
buffer, err := view.response.ParseTpl(file, view.data, view.fmap)
|
||||
return buffer, err
|
||||
}
|
||||
|
||||
@ -67,7 +67,7 @@ func (view *View) Parse(file string) ([]byte, error) {
|
||||
func (view *View) ParseContent(content string) ([]byte, error) {
|
||||
view.mu.RLock()
|
||||
defer view.mu.RUnlock()
|
||||
buffer, err := view.view.ParseContent(content, view.data, view.fmap)
|
||||
buffer, err := view.response.ParseTplContent(content, view.data, view.fmap)
|
||||
return buffer, err
|
||||
}
|
||||
|
||||
|
||||
@ -13,16 +13,12 @@ import (
|
||||
)
|
||||
|
||||
// 展示模板,可以给定模板参数,及临时的自定义模板函数
|
||||
func (r *Response) Template(tpl string, params map[string]interface{}, funcmap...map[string]interface{}) error {
|
||||
func (r *Response) Tpl(tpl string, params map[string]interface{}, funcmap...map[string]interface{}) error {
|
||||
fmap := make(gview.FuncMap)
|
||||
if len(funcmap) > 0 {
|
||||
fmap = funcmap[0]
|
||||
}
|
||||
// 内置函数
|
||||
fmap["get"] = r.funcGet
|
||||
fmap["post"] = r.funcPost
|
||||
fmap["request"] = r.funcRequest
|
||||
if b, err := gins.View().Parse(tpl, params, fmap); err != nil {
|
||||
if b, err := r.ParseTpl(tpl, params, fmap); err != nil {
|
||||
r.Write("Tpl Parsing Error: " + err.Error())
|
||||
return err
|
||||
} else {
|
||||
@ -31,6 +27,54 @@ func (r *Response) Template(tpl string, params map[string]interface{}, funcmap..
|
||||
return nil
|
||||
}
|
||||
|
||||
// 展示模板内容,可以给定模板参数,及临时的自定义模板函数
|
||||
func (r *Response) TplContent(content string, params map[string]interface{}, funcmap...map[string]interface{}) error {
|
||||
fmap := make(gview.FuncMap)
|
||||
if len(funcmap) > 0 {
|
||||
fmap = funcmap[0]
|
||||
}
|
||||
if b, err := r.ParseTplContent(content, params, fmap); err != nil {
|
||||
r.Write("Tpl Parsing Error: " + err.Error())
|
||||
return err
|
||||
} else {
|
||||
r.Write(b)
|
||||
}
|
||||
return nil
|
||||
}
|
||||
|
||||
// 解析模板文件,并返回模板内容
|
||||
func (r *Response) ParseTpl(tpl string, params map[string]interface{}, funcmap...map[string]interface{}) ([]byte, error) {
|
||||
fmap := make(gview.FuncMap)
|
||||
if len(funcmap) > 0 {
|
||||
fmap = funcmap[0]
|
||||
}
|
||||
return gins.View().Parse(tpl, r.buildInParams(params), r.buildInfuncs(fmap))
|
||||
}
|
||||
|
||||
// 解析并返回模板内容
|
||||
func (r *Response) ParseTplContent(content string, params map[string]interface{}, funcmap...map[string]interface{}) ([]byte, error) {
|
||||
fmap := make(gview.FuncMap)
|
||||
if len(funcmap) > 0 {
|
||||
fmap = funcmap[0]
|
||||
}
|
||||
return gins.View().ParseContent(content, r.buildInParams(params), r.buildInfuncs(fmap))
|
||||
}
|
||||
|
||||
// 内置变量
|
||||
func (r *Response) buildInParams(params map[string]interface{}) map[string]interface{} {
|
||||
params["Cookie"] = r.request.Cookie.Map()
|
||||
params["Session"] = r.request.Session.Data()
|
||||
return params
|
||||
}
|
||||
|
||||
// 内置函数
|
||||
func (r *Response) buildInfuncs(funcmap map[string]interface{}) map[string]interface{} {
|
||||
funcmap["get"] = r.funcGet
|
||||
funcmap["post"] = r.funcPost
|
||||
funcmap["request"] = r.funcRequest
|
||||
return funcmap
|
||||
}
|
||||
|
||||
// 模板内置函数: get
|
||||
func (r *Response) funcGet(key string, def...string) gview.HTML {
|
||||
return gview.HTML(r.request.GetQueryString(key, def...))
|
||||
|
||||
@ -53,7 +53,7 @@ func (s *Session) Id() string {
|
||||
|
||||
// 获取当前session所有数据
|
||||
func (s *Session) Data () map[string]interface{} {
|
||||
return *s.data.Clone()
|
||||
return s.data.Clone()
|
||||
}
|
||||
|
||||
// 设置session
|
||||
|
||||
@ -119,7 +119,7 @@ func (l *Logger) SetPath(path string) error {
|
||||
// 检测目录权限
|
||||
if !gfile.Exists(path) {
|
||||
if err := gfile.Mkdir(path); err != nil {
|
||||
fmt.Fprintln(os.Stderr, "glog mkdir failed: " + err.Error())
|
||||
fmt.Fprintln(os.Stderr, fmt.Sprintf(`glog mkdir "%s" failed: %s`, path, err.Error()))
|
||||
return err
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user