三方登录常需要客户端和服务端共同完成,对OAuth2,客户端获取授权码,服务端用授权码换取访问凭证;对OIDC,客户端获取ID Token,服务端验证其正确性用以登录之类的场景。但两端又常非同一个开发人员,服务端逻辑写好后需要客户端配合获取授权码或ID Token作为输入进行调试验证。这样效率太过低下,协调上会有困难。
最好是服务端能够自己获取输入参数,这里介绍常见的四种登录方式的简单调试方法:微信登录、Apple ID登录、Google登录、Facebook登录。
三方登录常需要客户端和服务端共同完成,对OAuth2,客户端获取授权码,服务端用授权码换取访问凭证;对OIDC,客户端获取ID Token,服务端验证其正确性用以登录之类的场景。但两端又常非同一个开发人员,服务端逻辑写好后需要客户端配合获取授权码或ID Token作为输入进行调试验证。这样效率太过低下,协调上会有困难。
最好是服务端能够自己获取输入参数,这里介绍常见的四种登录方式的简单调试方法:微信登录、Apple ID登录、Google登录、Facebook登录。
我每篇博客的书写都是有动机的,它们或是对一段时间的工作总结、或是对某个事物的感悟。这次要写X.509的博客,是因接入IAP时,从网上搜索的各种问题发现一个惊人的事实:很多人不知道X.509证书的验证方式,当然也包括我。
灰度发布、蓝绿发布、金丝雀发布等,本质上没有区别,都是版本渐进式发布+流量管理,所以也不要去纠结自己的发布方式到底算哪一种。硬要说,灰度发布是渐进式发布的统称,蓝绿发布和金丝雀发布是渐进式发布的具体方式,详细区别,在于蓝绿发布强调蓝绿环境(即新版和旧版服务)的平等性,流量拆分粒度较粗;金丝雀发布拥有更细粒度的流量拆分。
我们到底应该如何测试?
TDD的想法是非常美好的;单元测试、集成测试、系统测试、验收测试等构成的测试金字塔是非常美好的;通过测试,尽早地将问题暴露出来的想法也是非常美好的。但测试带来的收益和成本应该如何衡量呢?大团队应该如何测试?两三个人的小团队又应该如何测试?
如果你所在的团队已经有明确的测试规范,那不用操心这些问题;但如果是专注业务的小团队,各方面尚未有明确规范,测试应该做到什么程度,会是一个值得思考的问题。
记一个卡了两天的问题
TL;DR;
2021年10月,苹果发布了StoreKit2。新API和流程看起来更加简化,但是苹果官方文档并没有让开发者接入变得简单,调试起来也是各种问题,这方面和StoreKit1一样做的不好。梳理是必要的。
文章描述由一个问题引起的解决方案思路的探究以及最终的实践,具有借鉴参考意义。
记一记k3s+rancher搭建遇到的问题,使用感受。
Infrastructure as Code,将基础设施以代码的形式管理起来,放在git仓库中。Kubernetes的清单文件就是一种
gitops = Infrastructure as Code + version control + Pull/Push Request + CI/CD流水线。即,将维护在git仓库中的基础设施代码,以git仓库的方式进行开发、权限管理,再在CI中做正确性检查,然后CD交付到具体基础设施。
此处,需要维护的基础设施,即Kubernetes。
项目开发时,会将整个项目各生命周期工作一一列出,总体规划,使得进度可控。
对个人而言,是一样的道理。凡是预则立,不预则废。想做的事很多,东一榔头西一锤子不是办法,得有规划。
最近发现之前基于notion构建的计划模板已经不够用了,于是又折腾个新版本。
总的来看,我的个人任务管理大概分为三个阶段
Kotlin与Java百分百互操作,顺理成章,Spring开发也可以用Kotlin。可以享受到Kotlin的简洁语法。二者结合的大部分特点,在尝试之后都能体会。本文列举一些实际开发中最容易遇到的问题。
是不是最佳不知道,反正它是个实践!
工欲善其事,必先利其器。写单元测试,需要三类工具
当开发语言为kotlin时,推荐JUnit5 + MockK + Assertk的组合。
很多人是不写单元测试的,无非因为性价比太低。但我始终以为,真实原因是打开方式不正确,如果花功夫系统研究一下,或许会不一样。
这不就来了,现希望相对系统第了解单元测试的理论、常用工具、实施方法。伴随会产生系列文章。初预备三部分:
- 理论:介绍单元测试需要关注的内容,从设计上如何考虑
- 工具:介绍Spring Test、JUnit、Assert、Mock技术,相关库的使用
- 实践:基于以上两个部分的学习,重构当前的一个项目,记录过程中考虑的点。并最终给出结论。
此篇为首!
这是Linux系列第二篇文章,本来觉得Shell写完就OK了。但仔细一梳理发现对很多Linux要么是一知半解,要么是忘了。既然如此,还是遇到什么就回顾什么吧。本文试图解决以下问题