package rigger import ( "math/rand" "net/http" "ciyon/web/admin" c "ciyon/zciyon" ) func funcslow_setwhere(post *c.CiyPost) (map[string]any, *c.CiySQL) { query := post.Getobj("query") csql := c.NewCiySQL("zc_funcslow") csql.Where_daterange("addtimes", c.Getstr(query, "addtimes")) csql.Where_numrange("ms", c.Getstr(query, "ms_1"), c.Getstr(query, "ms_2"), 1) csql.Where("uri like", c.Getstr(query, "uri")) csql.Where("posts like", c.Getstr(query, "posts")) order := c.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 := c.NewCiyPost(w, r) _, userid := admin.Verifyfast(r, c.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 := c.CiyDB.Get(csql, post.Getint("count")) if err != nil { return c.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 := c.CiyDB.GetField(csql) c.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 c.SuccJSON(w, r, ret) } func Funcslow_del(w http.ResponseWriter, r *http.Request) bool { post := c.NewCiyPost(w, r) _, userid := admin.Verifyfast(r, c.CiyDB, post) if userid == 0 { return false } if admin.Nopower(c.CiyDB, userid, "p556d") { return c.ErrJSON(w, "您未被授权操作") } ids := post.Get("ids") if ids == "" { return c.ErrJSON(w, "请选择至少一条") } csql := c.NewCiySQL("zc_funcslow") csql.Where("id in", ids) rows, _, err := c.CiyDB.Get(csql) if err != nil { return c.ErrJSON(w, "读取数据错误", err) } vids := make([]int, 0) err = c.CiyDB.Tran(func() error { for _, row := range rows { delid := c.Toint(row["id"]) c.Delme(c.CiyDB, delid, "zc_funcslow") admin.SaveLogDB(c.CiyDB, "zc_funcslow", row, nil) vids = append(vids, delid) } return nil }) if err != nil { return c.ErrJSON(w, "事务"+err.Error()) } ret := map[string]any{} ret["ids"] = vids return c.SuccJSON(w, r, ret) } func Funcslow_exportxls(w http.ResponseWriter, r *http.Request) bool { post := c.NewCiyPost(w, r) _, userid := admin.Verifyfast(r, c.CiyDB, post) if userid == 0 { return false } if admin.Nopower(c.CiyDB, userid, "p556e") { return c.ErrJSON(w, "您未被授权操作") } _, csql := funcslow_setwhere(post) rows, _, err := c.CiyDB.Get(csql) if err != nil { return c.ErrJSON(w, "读取错误", err) } if len(rows) > 10000 { return c.ErrJSON(w, "将导出"+c.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 = c.EnID(c.Toint(val)) } else if field == "addtimes" { t := c.Toint(val) if t <= 0 { str = "--" } else { str = c.Todate(t, "Y-m-d H:i") } } else { str = c.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[-" + c.Tostr(len(datas)) + "]C:R[-1]C)"}) // total = append(total, map[string]any{"style": "r", "name": "=MAX(R[-" + c.Tostr(len(datas)) + "]C:R[-1]C)"}) // param["rowstop"] = `众产Ciyon` // param["rowsfooter"] = `总计` str := c.General_excel_xml(fields, datas, param, total) filename := "/ud/tmp/" + c.Todate(-1, "Ymd_His") + c.Tostr(rand.Intn(8999)+1000) + ".xls" err = c.FileSave(c.CiyWebDir+filename, str) if err != nil { return c.ErrJSON(w, "导出保存文件错误:%v[%v]", err, filename) } ret := map[string]any{} ret["url"] = filename return c.SuccJSON(w, r, ret) }