项目中的收发信模块-PHP

php  @amazeUI  2016-11-16 15:25:07

        基于:

        1.发信,有免费发信和付费发信,免费发信则收信方需要查看信件的权利,付费发信会与收信方形成一个一对一的通道,这个通道的有效期为永久,拥有通道则可以一对一无限次免费收发信,还有一种是会员发信,会员发信免费,收信方也可以与对方免费互动信件,有效期为会员过期日。

        2.收信,更准确的来说叫拆信,有无权利看对方的来信,能看信的情况有这几种,已有通道,自己或对方是会员,自己付费看新。

        3.按照以上两点需求,为了安全起见,拆信只针对信件而不是针对人。可以得出所有每一封信件的拆信判断的依据都在于信件本身的状态,1为有权利拆,0为没权利拆。如果免费发信给对方,则状态为0,自己是会员或者有通道发出去的信的状态为1。

        基于上述1,2的功能,可以得出结论,无论是发信还是拆信,都需要判断自己是否为会员,是否有通道,本封信是否为自己付费。可以按顺序做出一个公用的方法调用。拆信只需要看来往的最后一封信件的状态是否为0。但是有几点情况,如果仅仅只基于这些逻辑,还是会有漏洞,比如用户1发出免费信件给用户2,信件状态为0,此时用户1自己能看自己发出的信件吗,当然可以看,自己看自己发的信有什么不能看,所以这里要做判断,如果最后一封信件由自己发出那就可以看。那这就会出现一个漏洞,此时用户2不拆这一封信,而是去用户列表找到用户1免费发一封信,状态也为0,基于只能判断来往的最后一封信件状态,用户2可以拆开这一封信,这样一来也就能看到所有聊天记录了。

        以上就是收发信件的核心逻辑,再有就是安全判断了,因为收发信涉及到交易,所以需要对漏洞方面多加关注,比如,如果是按最后一封信件的状态来拆信,那肯定就有信件id,那就有可能别人瞎填一个id,可能会出现不可预料的问题甚至报错,所以拆信就需要做判断,根据这封信的id信息查到此封信件的收信者是不是当前用户且是否为与当前用户的最后一封信件,因为会员是有生命周期的,如果是,再来判断是否有权力拆信。等等等等,在拆信后,还有上一封信件和下一封信件,是针对用户而不是每一封信,上一封信是上一个与我来往的且我未查看的最后一封信的id,下一封一样,这里需要做数据处理,收信箱和发信箱里的上一封下一封逻辑略有不同。基本上所有拆发信,都要经过的安全判断,是否有这一封信,这封信的发信人或收信人是否存在,拆信的时候要判断这封信是否是写给自己的,要判断这一封信的状态。经过文字的描述和总结,这个模块的结构在我脑袋里更加的清晰,我可以把这个模块再优化一下减少不必要的查询,可以让代码看起来更加简洁易懂。明天上伪代码。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,384评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,845评论 3 391
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 161,148评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,640评论 1 290
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,731评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,712评论 1 294
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,703评论 3 415
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,473评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,915评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,227评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,384评论 1 345
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,063评论 5 340
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,706评论 3 324
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,302评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,531评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,321评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,248评论 2 352

推荐阅读更多精彩内容