GO 中间件方式执行额外任务
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 | package main import ( "database/sql" "fmt" "mylog" "time" ) type Middleware struct {} /*如遇错误,执行额外任务*/ func (m *Middleware) Println(v interface {}) { if err, ok := v.(error); ok { mylog.Println( "执行额外任务:" , err) } mylog.Println( "正常执行原本任务:" , v) } var dblink *sql.DB /*自行补充初始化过程*/ /*如遇错误,执行额外任务*/ func (m *Middleware) Println_sendln(v ... interface {}) { for _, arg := range v { if err, ok := arg.(error); ok { mylog.Println( "错误信息:" , err) err_msg := `警告消息:` + err.Error() //错误信息里可能有单引号 dingdingmsg := `exec dingding_add_msg ?,0, 'xxk' ` // mylog.Println("sql:", dingdingmsg) dblink.Exec(dingdingmsg, err_msg) } } mylog.Println(v...) } func main() { if err := DBinit_sqlserver2(); err != nil { mylog.Println(err) fmt.Println(err) time.Sleep(5 * time.Minute) return } else { fmt.Println(`链接sqlserver2成功`) } mv := &Middleware{} mv.Println(11) mv.Println(22) mv.Println(fmt.Errorf( "自定义错误" )) mv.Println_sendln(fmt.Errorf( "测试自定义错误" ), `121`) } |
写个函数调用似乎没什么不同
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | var logFile_handel_wx, _ = os.OpenFile(`./log/`+time.Now().Format( "2006-01-02" )+`--wx_api.log`, os.O_WRONLY|os.O_CREATE|os.O_APPEND, 0666) var mylog_wx = log.New(logFile_handel_wx, "" , log.Lmicroseconds|log.Ldate) func ffmyprint(Logger *log.Logger, v ... interface {}) { for _, arg := range v { if err, ok := arg.(error); ok { Logger.Println( "ffmyprint 错误信息:" , err) } } Logger.Println(v...) } ffmyprint(mylog_wx, fmt.Errorf( "测试自定义错误" ), `121`) |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~