
100种互联网热门赚钱方法
100种互联网热门赚钱方法 最新、最热的互联网赚钱项目拆解,向有结果的人拿答案
100种互联网热门赚钱方法 最新、最热的互联网赚钱项目拆解,向有结果的人拿答案
编程与 AI 编程 共 15 个小专栏:AI辅助编程高质量科普、C/C++、Java、Python、Go、Rust、k8s、前端、数据库、操作系统、网络安全、机器学习、运维、测试。
小白的AI编程提效课 小册包括六个专栏:AI编程实战、AI编程工具、AI高效办公、AI副业赚钱、AI提示词工程、AI私人助手
阿里P9右军:20年职业50个思考与洞察 20年P9老兵的职业思考:程序员成长 | 系统化思维 | 行业洞察
大模型应用开发 | API 实操 小册价值:快速入门OpenAI API,掌握核心能力:开发环境搭建、GPT原理、Chat、Tools、Assistants、Images、Audio
程序员职场避坑指南 本小册整理了程序员从求职面试、在职发展、抉择成长三个方面,在职场中会遇到的几十个核心问题,旨在总结可复制的经验,帮助你在职场之路上避坑
嵌入式千宝箱解决小白入门的1000个问题 本专栏专注于解决嵌入式新手遇到的各种疑难问题,助力解决小白入门的1000个问题
史官的游戏研发入门培训手册 本专栏着重为刚入行和想要入行的朋友们提供一些参考和思路,包含且不限于游戏研发岗位职能介绍、游戏设计思路探讨,游戏创业经验总结等等
Python 全家桶 专栏包含 Python「基础编程」和 「高级编程」,同时置顶帖赠送 爬虫开发、游戏开发、数据分析、人工智能、自动办公,旨在帮你一站式入门 Python 运用
播客小捕手 播客小捕手是一个海外播客数据库,你可以:通过搜索功能搜寻到你感兴趣的内容。查看部分精华节目的人工总结。在这个数据库里查看该播客的中文稿。
深入浅出Web3开发技术 本手册内容源自作者未完成的书籍稿件,内容包括Web3基础,智能合约技术和语言基础,智能合约开发、测试和部署,标准 Token 协议,区块链预言机,Keeper,数据索引服务 Graph,前端 Web3 框架等
小白零基础用Python量化股票分析小册 从小白的角度浅浅的介绍一下从零基础python入门,pandas库的使用,股票的数据的基本分析,可视化股票分析,以及如何写一个简单的量化策略,如何去回测你的策略
Go 语言 与 AI 提效 小册共分 7 个大专栏:Go 入门、Go 进阶、Go Web 开发、Go 微服务、Go 源码、Go 面试、AI 提效(包含 3 个小专栏)
史官的游戏人生-第1季@正义的史官 本专栏从一个游戏设计者的视角观察和理解生活,也从生活中感受和领悟游戏的精神内核。每周至少会更新一篇1500字左右文章,至少更新50篇。
Python潮流周刊 | 每周连载中 从全网挑选最值得分享的文章、教程、开源项目、软件工具、播客和视频、热门话题等丰富内容,第一时间汇聚给你阅读。
C++埋点SDK项目实战 【终身订阅】C++客户端埋点相关的SDK实战项目。适合入门和进阶C++的同学
基于 Gin 封装的高效 Web 框架 从零开始教你如何基于 Gin 框架封装自己的 Web 框架,涵盖框架设计与实现。无论你经验水平如何,都可获得实际项目开发技巧,提高开发效率。
产品经理的技术课 给产品经理讲技术,普及技术基础知识。结合具体案例循序渐进地讲解产品经理需要学习的技术知识
游火研究院 2023 每个工作日收取一篇推送,由我们的编辑团队为你筛选全球游戏行业重要新闻。支持通过微信或者邮箱阅读
游火研究院 - 2024 每个工作日收取一篇推送,由我们的编辑团队为你筛选全球游戏行业重要新闻。支持通过微信或者邮箱阅读
产品成长指北 产品通识知识库,也是产品实践手册;致力于为读者建立扎实的产品基本功
大数据技术在用户画像中的应用 大数据技术画像应用实战,从0到1,带你入门大数据技术
播客制作手册(2023版) 播客制作手册2023版。本版会在播客制作手册2020版 上进行修订,并补充品牌播客与内容生态的理解。旨在帮助更多人能够轻松了解并上手播客。你将在这里见证播客制作手册诞生的全过程,并参与讨论。
简明数据库小课「已完结,放心买」 面向产品经理的数据库小课,通过案例、原型等方式,从产品经理的视角讲解数据库知识。覆盖数据库概念、实操、案例、数据分析、如何使用AI工具、数据仓库、BI和PaaS等全方位的知识。
王建硕的 Web3 启蒙书 本专栏是关于Web3的启蒙书,适合初学者入门,内容包括Web3的基础知识、技术原理、应用场景等
人人都能读懂的技术专栏 它应该是接地气的,完全可以用非专业性术语去描绘,应该是人人都能读懂的
Chrome插件全栈开发实战 真实出海项目的实战教学课,讲解Chrome插件和Next.js端的全栈开发,教你最佳的出海技术栈组合,帮助你半个月内成为全栈出海工程师。
Java入门进阶与AI 提效 本学习手册的内容主要包括:从 Java 入门到 Java 进阶以及AI提效,介绍从Java SE、Java EE、常用框架以及AI助力编程提效等方面
硬件产品经理手册 这是在过去 几年的工作里,我关于做硬件产品经理工作的最佳实践指南。
然阿姨的成长顿悟2023-2024 主要更新内容:👉真实职场经历和总结(脱敏版)👉近期阅读推荐👉付费咨询手记(脱敏版)👉部分播客访谈脱水文字版
三爷的B端产品专家进阶之路 本专栏我希望帮助所有还在一直进行单一功能设计工作的同学进行一次全面升级,帮助每一位专栏读者构建高阶产品人所必须的技能树,进行一次维度升级,实现从简单的功能设计到更高维度的产品规划的技能突破
产品经理自由职业之路2022 作为探索了一年半自由职业的产品经理,接下来会用产品思维迭代商业IP,已经是小红书第一产品经理的我,希望和大家一起更快的成长
产品经理自由职业之路2023 作为探索了一年半自由职业的产品经理,接下来会用产品思维迭代商业IP,已经是小红书第一产品经理的我,希望和大家一起更快的成长
AI辅助软件测试 小册分为四个主题:ChatGPT辅助软件测试入门,ChatGPT辅助软件测试进阶,ChatGPT辅助软件测试面试。
前端快速入门 小册分为 5 个主题:前端入门、前端进阶、前端实战、面试经验、职场经验,一年内最少输出 30 篇心得
软测面试精选题库 为你挑选100道面试题,并附上最优解,助你轻松搞定面试!
零基础轻松入门前端:知识点加实战 深入浅出介绍前端各个知识点,同时实现一个涉及前后端的课程返现网站。适合在校学生、前端初学、后端、算法等开发人员。
AI 辅助学 Java 小册分为:AI 辅助学 Java 、AI 辅助学计算机、AI 辅助学数据库、AI 辅助学算法、AI 辅助学微服务、AI 辅助面试、AI 辅助改简历,AI 辅助编程副业
个人独立游戏开发者指南 本专栏不教你具体如何编程,如何设计游戏,但会提供一定的产品思路。对于具体编程,设计等已经有许多优秀的教程,我也会在专栏中有详细的分享
Python精选300题 精选 Python 编程300题,附答案及详细解析,夯实基础,提炼精华。
陈随易的Node.js全栈实验指南 本课程提供3种交付方式:1,小册文字版(165元包含);2,微信群问答(165元包含);3,录播视频版(单独付费,未定价)。
示例:
# 根目录下执行
go run cmd/gormgen/main.go -dsn "root:123456789@tcp(127.0.0.1:3306)/gin_api_mono?charset=utf8mb4&parseTime=True&loc=Local" -tables "admin"
具体文档:cmd/gormgen/README.md
示例:
# 根目录下执行
go run cmd/handlergen/main.go -table "admin"
具体文档:cmd/handlergen/README.md
# 根目录下执行
./scripts/swagger.sh
// 定义自动生成的路由组前缀为 /api
generatedRouterGroup := mux.Group("/api")
// 注册路由
admin.RegisterGeneratedAdminRoutes(logger, db, generatedRouterGroup)
文件地址:internal/router/router.go
项目重启后访问:http://127.0.0.1:9999/swagger/index.html 会看到生成的接口文档。
获取源码,可添加我微信 wx-xinliang 。
有启发,左下角点击“启发”告诉我呀,点我即可直接跳转到小册目录合集 。
用 Go 写了一个桌面程序:生成授权码的小工具,先看下效果。
我已经安装到 macOS 上了。
源码地址:jazr2......
可以使用以下命令进行安装:
go get go.mongodb.org/mongo-driver/mongo2. 基本连接与配置Mo......
可以使用以下命令安装:
go get github.com/go-redis/redis/v82. 基本连接你可以通过 redis.NewC......
可以通过以下命令安装:
go get github.com/go-resty/resty/v22. 创建一个简单的 HTTP 客户端通过 resty.New(......
缘起:有部分开发者提出了这样的需求:“亮哥,看了文档和源码后,我还是不知道如何下手,可以基于 gin-api-mono 集成下登录、注册和用户管理功能吗?”
于是就有它......
Context 是一个上下文对象,它提供了许多有用的方法和属性,用于处理 HTTP 请求和响应。
代码片段:
// ./internal/pkg/core/con......IRoutes 接口是定义路由组的接口。
IRoutes 接口包含了定义路由的方法,可以用于添加路由和中间件等。
代码片段:
// ./......目前可收集日志类型包括:
当前的请求日志
当前的响应日志
自定义调试日志
MySQL 操作日志
Redis 操作信息
Mongo 操作信息
请求三方 API 接口的请求与响应日志
日志收集,代码片段:
// ./internal/pkg/core/core.go
// region 记录日志
var t *trace.Trace
if x := context.Trace(); x != nil {
t = x.(*trace.Trace)
} else {
return
}
decodedURL, _ := url.QueryUnescape(ctx.Request.URL.RequestURI())
// ctx.Request.Header,精简 Header 参数
traceHeader := map[string]string{
"Content-Type": ctx.GetHeader("Content-Type"),
}
t.WithRequest(&trace.Request{
TTL: "un-limit",
Method: ctx.Request.Method,
DecodedURL: decodedURL,
Header: traceHeader,
Body: string(context.RawData()),
})
var responseBody interface{}
if response != nil {
responseBody = response
}
t.WithResponse(&trace.Response{
Header: ctx.Writer.Header(),
HttpCode: ctx.Writer.Status(),
HttpCodeMsg: http.StatusText(ctx.Writer.Status()),
BusinessCode: businessCode,
BusinessCodeMsg: businessCodeMsg,
Body: responseBody,
CostSeconds: time.Since(ts).Seconds(),
})
t.Success = !ctx.IsAborted() && (ctx.Writer.Status() == http.StatusOK)
t.CostSeconds = time.Since(ts).Seconds()
logger.Info("trace-log",
zap.Any("method", ctx.Request.Method),
zap.Any("path", decodedURL),
zap.Any("http_code", ctx.Writer.Status()),
zap.Any("business_code", businessCode),
zap.Any("success", t.Success),
zap.Any("cost_seconds", t.CostSeconds),
zap.Any("trace_id", t.Identifier),
zap.Any("trace_info", t),
zap.Error(abortErr),
)
// endregion
使用日志组件,代码片段:
// main.go
import "gin-api-mono/internal/pkg/logger"
// 将日志输出到文件
accessLogger, err := logger.NewJSONLogger(
logger.WithField("domain", fmt.Sprintf("%s[%s]", configs.ProjectName, env.Active().Value())),
logger.WithTimeLayout(timeutil.CSTLayout),
logger.WithFileP(configs.ProjectAccessLogFile),
)
// 将日志输出到文件 + 控制台
accessLogger, err := logger.NewJSONLogger(
logger.WithOutputInConsole(),
logger.WithField("domain", fmt.Sprintf("%s[%s]", configs.ProjectName, env.Active().Value())),
logger.WithTimeLayout(timeutil.CSTLayout),
logger.WithFileP(configs.ProjectAccessLogFile),
)
// 如果需要日志分割,可以使用 WithFileRotationP() 方法。
记录自定义调试日志,代码片段:
import "gin-api-mono/internal/pkg/debug"
// 示例一,记录多个数据
debug.WithContext(ctx.RequestContext()).Logger("这是调试信息A1", "这是调试信息A2")
// 示例二,记录单个数据
debug.WithContext(ctx.RequestContext()).Logger("这是调试信息B")
记录 MySQL 操作日志,代码片段:
// 查询数据,核心是使用 .WithContext() 方法
h.db.GetDbR().WithContext(ctx.RequestContext()).Where(queryWhere).Find(&resultData)
记录 Redis 操作日志,代码片段:
import "gin-api-mono/internal/repository/redis"
// get,核心是使用 ctx.RequestContext() 参数
getResult, err := redis.GetRedisClient().Get(ctx.RequestContext(), "name").Result()
记录 Mongo 操作日志,代码片段:
import "gin-api-mono/internal/repository/mongo"
// 获取 Mongo Client
client := mongo.GetMongoClient()
// 获取 Collection,例如 Database 为 gin_api_mono,Collection 为 user
collection := client.Database("gin_api_mono").Collection("user")
// 查询数据,核心是使用 ctx.RequestContext() 参数
findResult, err := collection.Find(ctx.RequestContext(), bson.D{})
记录请求三方 API 接口的日志,代码片段:
import "gin-api-mono/internal/pkg/httpclient"
// 支持在上下文记录执行日志的 httpclient
client := httpclient.GetHttpClientWithContext(ctx.RequestContext())
// 普通的 httpclient
client := httpclient.GetHttpClient()
// GET
resp, err := client.R().
SetQueryParams(map[string]string{
"page_no": "1",
"limit": "20",
"sort":"name",
"order": "asc",
"random":strconv.FormatInt(time.Now().Unix(), 10),
}).
SetHeader("Accept", "application/json").
SetAuthToken("BC594900518B4F7EAC75BD37F019E08FBC594900518B4F7EAC75BD37F019E08F").
Get("/search_result")
日志结构,代码片段:
// ./internal/pkg/trace/trace.go
// Trace 记录的参数
type Trace struct {
mux sync.Mutex
Identifier string `json:"trace_id"` // 链路ID
Request *Request `json:"request"` // 请求信息
Response *Response `json:"response"` // 返回信息
ThirdPartyRequests []*HttpLog `json:"third_party_requests"` // 调用第三方接口的信息
Debugs []*Debug `json:"debugs"` // 调试信息
SQLs []*SQL `json:"sqls"` // 执行的 SQL 信息
Redis []*Redis `json:"redis"` // 执行的 Redis 信息
Mongos []*Mongo `json:"mongos"` // 执行的 Mongo 信息
Success bool `json:"success"` // 请求结果 true or false
CostSeconds float64 `json:"cost_seconds"` // 执行时长(单位秒)
}
不同组件能够将日志记录到上下文的核心是 拦截器,具体在第三方组件集成章节详细描述,此模块有些复杂,也可以微信找我沟通。
有启发,左下角点击“启发”告诉我呀,点我即可直接跳转到小册目录合集 。
使用 IsAborted 函数来判断进行错误处理。
统一处理,代码片段:
// ./internal/pkg/core/core.go // region 发生......