package rigger import ( "math/rand" "net/http" "ciyon/web/admin" . "ciyon/zciyon" ) func funcslow_setwhere(post *CiyPost) (map[string]any, *CiySQL) { query := post.Getobj("query") csql := NewCiySQL("zc_funcslow") csql.Where_daterange("addtimes", Getstr(query, "addtimes")) csql.Where_numrange("ms", Getstr(query, "ms_1"), Getstr(query, "ms_2"), 1) csql.Where("uri like", Getstr(query, "uri")) csql.Where("posts like", Getstr(query, "posts")) order := Getstr(query, "order", "id desc") csql.Order(order) query["order"] = order return query, csql } func Funcslow_init(w http.ResponseWriter, r *http.Request) bool { post := NewCiyPost(w, r) _, userid := admin.Verifyfast(CiyDB, post) if userid == 0 { return false } where, csql := funcslow_setwhere(post) pageno := post.Getint("pageno", 1) pagecount := post.Getint("pagecount", 10) csql.Limit(pageno, pagecount) rows, mainrowcount, err := CiyDB.Get(csql, post.Getint("count")) if err != nil { return ErrJSON(w, "读取错误", err) } ret := map[string]any{} ret["where"] = where ret["pageno"] = pageno ret["pagecount"] = pagecount ret["count"] = mainrowcount ret["list"] = rows if post.Getbool("field") { field, fshow := CiyDB.GetField(csql) FieldAdd(&field, &fshow, 0, "_btn", "操作") field["ms"]["thwidth"] = "5em" field["ms"]["order"] = true ret["fshow"] = fshow ret["field"] = field } if post.Getbool("once") { once := map[string]any{} input := make([]map[string]any, 0) input = append(input, map[string]any{ "form": "addtimes", "type": "daterange", "name": "记录时间", }) input = append(input, map[string]any{ "form": "ms", "type": "num", "name": "用时", "prop": ` style="width:4em;"`, }) input = append(input, map[string]any{ "form": "uri", "type": "input", "name": "请求源", "prop": ` style="width:8em;"`, }) input = append(input, map[string]any{ "form": "posts", "type": "input", "name": "参数", "prop": ` style="width:8em;"`, }) once["input"] = input ret["once"] = once } return SuccJSON(w, ret) } func Funcslow_del(w http.ResponseWriter, r *http.Request) bool { post := NewCiyPost(w, r) _, userid := admin.Verifyfast(CiyDB, post) if userid == 0 { return false } if admin.Nopower(CiyDB, userid, "p555d") { return ErrJSON(w, "您未被授权操作") } ids := post.Get("ids") if ids == "" { return ErrJSON(w, "请选择至少一条") } csql := NewCiySQL("zc_funcslow") csql.Where("id in", ids) rows, _, err := CiyDB.Get(csql) if err != nil { return ErrJSON(w, "读取数据错误", err) } vids := make([]int, 0) err = CiyDB.Tran(func() error { for _, row := range rows { delid := Toint(row["id"]) Delme(CiyDB, delid, "zc_funcslow") admin.SaveLogDB(CiyDB, "zc_funcslow", row, nil) vids = append(vids, delid) } return nil }) if err != nil { return ErrJSON(w, "事务"+err.Error()) } ret := map[string]any{} ret["ids"] = vids return SuccJSON(w, ret) } func Funcslow_exportxls(w http.ResponseWriter, r *http.Request) bool { post := NewCiyPost(w, r) _, userid := admin.Verifyfast(CiyDB, post) if userid == 0 { return false } if admin.Nopower(CiyDB, userid, "p555e") { return ErrJSON(w, "您未被授权操作") } _, csql := funcslow_setwhere(post) rows, _, err := CiyDB.Get(csql) if err != nil { return ErrJSON(w, "读取错误", err) } if len(rows) > 10000 { return ErrJSON(w, "将导出"+Tostr(len(rows))+"条,不建议超过1万条,请筛选缩小范围", err) } fields := []map[string]string{} fields = append(fields, map[string]string{"style": "c", "width": "60", "field": "id", "name": "行码"}) fields = append(fields, map[string]string{"style": "c", "width": "100", "field": "addtimes", "name": "记录时间"}) fields = append(fields, map[string]string{"style": "r", "width": "60", "field": "ms", "name": "用时"}) fields = append(fields, map[string]string{"style": "l", "width": "300", "field": "uri", "name": "请求源"}) fields = append(fields, map[string]string{"style": "l", "width": "500", "field": "posts", "name": "参数"}) datas := [][]string{} for _, row := range rows { dat := make([]string, 0) for _, f := range fields { field := f["field"] if val, ok := row[field]; ok { var str string if field == "id" { str = EnID(Toint(val)) } else if field == "addtimes" { t := Toint(val) if t <= 0 { str = "--" } else { str = Todate(t, "Y-m-d H:i") } } else { str = Tostr(val) } dat = append(dat, str) } else { dat = append(dat, "") } } datas = append(datas, dat) } param := map[string]any{} param["sheetname"] = "数据报表" param["titleheight"] = "25" //列头高度 param["landscape"] = true //横向打印 param["fixtopage"] = true //打印整个工作表 param["toptitle"] = "慢请求数据报表" total := []map[string]any{} //单行统计数据 // total = append(total, map[string]any{"style": "l", "name": "合计", "merge": 5}) // total = append(total, map[string]any{"style": "r", "name": "=SUM(R[-" + Tostr(len(datas)) + "]C:R[-1]C)"}) // total = append(total, map[string]any{"style": "r", "name": "=MAX(R[-" + Tostr(len(datas)) + "]C:R[-1]C)"}) // param["rowstop"] = `众产Ciyon` // param["rowsfooter"] = `总计` str := General_excel_xml(fields, datas, param, total) filename := "/ud/tmp/" + Todate(-1, "Ymd_His") + Tostr(rand.Intn(8999)+1000) + ".xls" err = FileSave(CiyWebDir+filename, str) if err != nil { return ErrJSON(w, "导出保存文件错误:%v[%v]", err, filename) } ret := map[string]any{} ret["url"] = filename return SuccJSON(w, ret) }