chengjf 发布的文章

我的blog使用了cloudflare的https,在typecho里也开始https后,初看一切正常,但是登录后台时,返回302,重定向到了登录页。

我在网上搜索了好久,记录下解决方案。

修改typecho下的这个文件:

config.inc.php

增加如下代码:

define('__TYPECHO_SECURE__', true);

上篇文章提到了生成唯一的短字符串,应用在给每个用户生成一个唯一的邀请码,这个可以扩展到给每个商品生成一个唯一的编号,给每个地点生成一个唯一的标识等等。

但是,唯一的短字符串还有另外一个场景,就是靓号,比如说QQ靓号,直播间的房间号,这些场景下,如果随机生成一些字符串可能并不如人意,需要将某些靓号整理出来,专门给运营发放。

最先想到的就是把靓号全部找出来,存储起来,然后还是按照原来的算法生成唯一短字符串,只是当随机到这些靓号的时候,重新生成,也就是要多查一次而已。

相对的,可以把非靓号存储起来,生成的时候从非靓号里取,这样避免了一次查询,这个方案的关键就是非靓号的存储,非靓号可比靓号数目大得多,使用redis还是rds需要权衡一下。(如果使用redis,可以使用set这个数据结构,使用spop进行处理)

最近有这么一个需求,要给每个用户生成一个唯一的邀请码,用户可以将这个邀请码分享出去,当新用户使用这个邀请码注册登录的时候,就会给邀请者和被邀请者双方发放奖励。

常见的方法有如下几种:

  1. 直接使用用户uid做邀请码,简单直接,就好像其他app中填入邀请者的手机号一样
  2. 对uid做hash生成一串字符串做邀请码,这个主要是为了避免用户的uid泄露,但是要保存用户uid和邀请码的对应关系
  3. 采用对称加密算法加密uid,这样直接根据邀请码就可以解出用户uid,不需要保存uid和邀请码的对应关系了

我们这边的用户uid是纯数字的,共有13位,给这13位uid生成hash或加密的话,结果会较长,不方便用户分享和填写,产品经理限制邀请码长度为6位,同时生成的邀请码中不能要oO1ILl等容易混淆的字符。

- 阅读剩余部分 -

这个小而精,在软件领域,也有其他类似的叫法,比如内聚、解耦,再比如SRP-单一职责原则等,大家都非常推崇或建议这个风格、规范、原则。

而这个大而全,一看就是大锅绘,一锅端这种类型,在软件领域是大家都非常不建议使用的。

但是,在现代软件架构中,往往架构层次或模块较多,如果在每个地方都是用小而精可能有一些其他方面的问题。

就举个我前两天的一个例子说明下。

运营要在端内搞个一个活动,为了和日本那边的新年元旦红白歌会相呼应。活动是这样设计的:

  1. 每个人可以加入红、白这两支队伍中的一个队伍
  2. 每个人可以做活动给自己的队伍增加年糕数目,年糕数目最多的队伍获胜

对于个人的数据,就包括自己是哪个队伍的,自己获得的年糕数目,在己方队伍中的排名等。

底层的存储采用的是redis,自己的队伍采用string的get、set(依赖用户id),排行榜直接用zset,这样年糕数目用zscore(依赖用户id和队伍id),排名用zrank(依赖用户id和队伍id),这样这三个数目在数据层就是三个操作。

到了service层,我也对应的写了三个方法。

到了web层,我也写了三个对应的接口。

- 阅读剩余部分 -

重要的话说三遍都不为过。

永远不要动老接口,无论这个接口是别人写的,还是你写的。
永远不要动老接口,无论这个接口有人用,还是没人用。
永远不要动老接口,无论是什么样的理由。

可能要动这个接口的理由很多:

  1. 这个接口代码写的太烂,要优化一下
  2. 这个接口现在没人用了,注释掉或删了吧
  3. 底层实现修改了,这个接口的参数或返回值也要修改
  4. ……

亦或是你自己对自己的修改信心满满:

  1. 我知道哪些地方调用了这个接口,不会有任何影响
  2. 我只是稍微优化了下代码逻辑,保证接口行为同原来一致
  3. ……

真的,有时候连我自己都说服自己要下手了……



- 阅读剩余部分 -