现代软件工程团队项目贝塔阶段_开发日志_2018.01.15-2018.01.19

现代软件工程团队项目贝塔阶段_开发日志_2018.01.15-2018.01.19


2018.01.15

已完成:

  • 1.版本上线

    • 1.1上线操作步骤

      • 1.1.1将网站整体文件夹拷贝到keqi1
      • 1.1.2修改microDefinition.php的数据库名和根目录名
      • 1.1.3修改注册界面发送验证码后直接填充功能
      • 1.1.4修改del的主id的class为hide
      • 1.1.5重新运行根目录的111.php(消除红点,也就是消除服务器返回的多余字符)
    • 1.2修复上线过程中遇到的bug 
      • 1.2.1修复注册页面邮箱密码查重异常
      • 1.2.2注册页面和完善信息页面检验信息正确性模块化
      • 1.2.3

2018.01.16

已完成

  • 1.简单的了解了sse和webSocket

    • 1.1sse

      • 1.1.1优点 
        sse具有小巧简便的特点,基于http,只需要在原先代码上作微小的改变,已尝试在页面实现。
      • 1.1.2缺点 
        半双工,浏览器向服务器发送数据较困难,前几天不知道应该如何让服务器知道我是谁,因为不知道怎么在sse的情况下向服务器发送数据,现在意识到可以使用session 
        这是今天碰巧看到的视频教学,以前验证登录状态都是使用cookies验证,迟早是要换成session的(搁置一下)http://study.163.com/course/courseLearn.htm?courseId=1003547026#/learn/video?lessonId=1004094119&courseId=1003547026 
        因为之前一直想不通要怎样在sse情况下像服务器传送信息,故了解了一下socket
    • 1.2webSocket
      • 1.2.1优点 
        socket具有全双工的特点,从浏览器像服务器发送数据非常简单,有很多成熟框架可以调用,直接使用其接口就行。现已经实现了简单的在命令行中的通信,如果要在做到webSocket需要学习workerman或swoole,有很多全面的教程
      • 1.2.2缺点 
        socket需要重新选择端口号,涉及到tcp/ip协议,较为复杂,对原先的代码改动量很大,而且比较难学,关于框架的文档很少有中文的。。。但是迟早也是要看的。
    • 1.3综合考量 
      经过这几天的考虑和查阅资料发现,websocket能做的sse都能做,对于1秒以内的反馈而言socket更加合适,而1.5秒以上的则几乎一样。websocket在企业中应用更广泛,但难于上手,sse简单易学,考虑到目前项目人手紧缺,开发周期短,于是决定使用sse。 
      不过出来混迟早是要还的,websocket该学还是要学,留着以后再说吧,尝试了一天之后发现并不是很容易…
  • 2.已实现sse的简单功能,即从数据库中实时读取并传回前端。

未完成

  • 1.html简单的两人聊天界面

    • 1.1消息呈现界面
    • 1.2消息输入框
  • 2.js
    • 2.1点击发送时

      • 2.1.1空则给出提示
      • 2.1.2非空则将我的信息显示在页面上,并通过Ajex传递给php1
    • 2.2检测服务器是否返回信息 
      • 2.2.1返回信息则显示在页面上
  • 3.php1负责把我发出的信息写到我的信息表和他的信息表
  • 4.php2负责sse部分
    • 4.1负责检查我的表里面有无新数据

      • 4.1.1检测到的数据与以前的数据不同则传送到页面(这里考虑要不要专门设置一个属性,当有新数据时更新这个属性,这样不毕每次都检查整个表,目前还不需要考虑压力部分)
      • 4.1.1检测到的数据与以前相同则不发送(目前先不考虑这一点,先都发送到前端,以后要改)

2018.1.17

已完成

  • 1.新增chatRoom.html

    • 1.1好友列表(默认为曾经发送过消息的人)显示邮箱,最后一条消息时间和最后一条消息
    • 1.2消息列表(在只有一个好友的情况下显示消息),只能显示登陆后的消息,存在bug
    • 1.3输入框以及按钮
  • 2.新增chatRoom.js 
    • 2.1登录通过friendListRead.php时填充好友列
    • 2.2sse通过chatMessageReadSSE.php检测服务器发送的消息(仅能显示登陆后的,存在bug)
    • 2.3点击发送按钮后将本人信息写到本人页面,再调用chatMessageWriteSSE.php将信息写入本人与对方聊天表
    • 2.4点击好友列表对应部分的邮箱时将消息列表的hiddenAccount置为该好友
  • 3.新增chatMessageReadSSE.php 
    • 3.1通过sse与服务器链接,接收服务器在我的消息表里toUstcEmail为我、且未读的消息
  • 4.新增chatMessageWriteSSE.php 
    • 4.1发送消息时将信息写入本人与对方聊天表
  • 5.新增friendListRead.php 
    • 5.1登录时由该文件读取好友列表

未完成

  • 1.界面美化(打算找网上已有的页面源码)
  • 2.增加好友头像,点击好友列表当前好友一整个区域时跳到该好友聊天界面,读取原有信息和新信息
  • 3.新信息在好友列表中有提示,可以用徽章来做
  • 4.ie浏览器的兼容问题

2018.1.18

已完成

  • 1.chatRoom.html

    • 1.1前端界面美化,左上角增加我的姓名,聊天界面上部为对方姓名,消息内容不再显示姓名
    • 1.2固定聊天框高度,增加竖向滑动条
  • 2.chatRoom.js 
    • 2.1聊天内容默认为第一个好友的内容
    • 2.2检测是否登录、没登录返回主页,是否有好友、没好友返回主页,是否完善了个人信息、没有完善则跳转到完善页面
    • 2.3有新消息时滑动条自动停留在下部
    • 2.4增加了填充过往消息记录功能。默认最大100条。调用previousContentRead.php完成
  • 3.friendListRead.php 
    • 3.1修复了原先没有正确读取最后一条消息的bug,但增加了时间复杂度
    • 3.2同时到improve_info表中读取了好友真实姓名,不在页面显示邮箱,全显示姓名
  • 4.previousContentRead.php 
    • 4.1点击左侧好友列表某人时显示最近100条聊天内容

未完成

  • 1.已知的bug

    • 1.1多客户端同时登陆时,消息可能会随机发送到前端

      • 【解决办法】:设置不能同时在两地登录账号
    • 1.2好友列表好友高度随消息长度不同而不同 
      • 【解决办法】:设置固定高度,设置最长显示字数
    • 1.3发送消息根据消息长度不同显示效果不同 
      • 【解决办法】:消息内容限定在固定区域中
  • 2.收到新消息时在好友列表应有提示 
    • 2.1消息条数提示
    • 2.2好友标签置顶
  • 3.收到消息时在主页提示
  • 4.sse的ie浏览器兼容问题

2018.1.19

已完成

  • 1.解决多客户端同时登陆问题

    • 【解决办法】:在account_password表中增加ip地址一列,登录时存储当前ip地址。在聊天界面的sse时刻检测当前ip地址是否与数据库一致,若不一致则提示账号在其他地点登录。
  • 2.略微美化前端页面 
    • 【解决办法】:对每一个好友标签做了高度限制
  • 3.收到新消息后 
    • 3.1好友列表对应好友标签置顶
    • 3.2若不是当前好友,则对应好友标签的徽章数量+1,最高显示99+,为0时隐藏
    • 3.3若是当前好友,则显示,徽章不变化
  • 4.发送消息后 
    • 4.1发送的消息不能为空,否则给出提示
    • 4.2对应好友标签置顶
  • 5.点击切换好友标签 
    • 5.1将该好友徽章内容设为0,并隐藏
  • 6.修复了时间显示错乱的bug 
    • 【解决办法】:后端存的13位时间戳,前端按照10位解析出现了问题
  • 7.修复了登录时不显示未读消息徽章,仅将未读消息直接显示的bug 
    • 【解决办法】:消息发送后为haveSend,下一次刷新时将haveSend全都改为没发送也没查看notView
    • status: 
      • notView:没发送也没查看
      • haveSend:发送了没查看(亚稳态,本次不用再发送、查看了下次才不用在发送、没查看下次还要再发送)
      • haveRead:已经查看了(稳定不需要再发送)
  • 8.IE等浏览器成功进行通讯 
    • 【解决办法】:引入polyfill的eventsource.min.js,无需对原本代码进行任何修改
  • 9.使用强大的测试工具BrowserStack基本完成个浏览器测试 
    • 各windows、mac、iphone、android均可以支持消息发送与接收的功能

未完成

    • 1.在主页也需要增加sse检测,检查是否有新的同意邀请等,顺道检查是否在别处登录【暂时搁置,等待后期分工】
    • 2.前端页面的继续美化,例如消息要限制在“消息气泡”内部,页面比例、整体布局等【暂时搁置,等待后期分工】
    • 3.火狐等部分浏览器在输入账号密码等信息时,提示此连接不安全【好像是因为网站没有备案,需要三个月才行】
    • 4.iphon手机端访问时,消息显示很杂乱,甚至层叠。

原文地址:https://www.cnblogs.com/klkqyfct/p/8318930.html

时间: 2024-10-17 11:08:19

现代软件工程团队项目贝塔阶段_开发日志_2018.01.15-2018.01.19的相关文章

团队项目M1阶段个人反思

郑培蕾: 作为项目的PM,我前期的工作还是有很大的缺陷的,因为没有在开发之前对项目进行一个合理的评估,所以后来分配任务的时候就很不科学, 而且任务分配的比较粗糙,没有细化到每个人每天应该做什么,这就导致我们在后来的工作中因为联网部分造成项目卡顿,这是项目最终失败一个 很重要的原因:其次是我们团队内部成员之间的交流比较少,几名主要负责开发的成员都是在自己摸索自己的那部分,没有进行良好的沟通,所以 后来我们在展示之前费了很大的功夫去修改:还有就是团队的积极性没有调动起来,有些同学没有认真地投入进去,

团队项目:二次开发

二.团队项目:二次开发 至此,我们有了初步的与人合作经验,接下来投入到更大的团队中去. 也具备了一定的个人能力,能将自己的代码进行测试.接下来尝试在别人已有的基础上进行开发. 上一界51冯美欣同学的项目:http://www.cnblogs.com/maxx/ 1.每个团队从Github上fork这个项目的源代码: https://github.com/RABITBABY/We-have-bing 2.了解.部署.运行这个项目,理解其功能及实现: 3.进行必要的测试,发现软件的bug并记录,并进

软件工程团队项目总结

一学期软件工程课结束了,这学期我们共做了三个项目,分别为个人项目.结对项目.以及团队大项目.前两者主要是拿来练手,体会一下简单的软件工程方法论,而结对项目前后历时两个多月,可以说是一次系统的软件工程锻炼,下面对两个迭代过程做一个总结. M1: 我们完成了什么:一个社团平台,给同学提供一个浏览社团活动的活动广场,给社团提供一个管理社员报名和发送通知的集成服务. 我们怎样做到的:需求分析,设想我们的产品的用户场景,建立基本的ER图模型,学习WEB开发的基本知识,做了一些DEMO,学习怎样以基于aja

[个人博客作业Week7]软件工程团队项目感想与反思

在阅读了推荐阅读的材料之后,我想了很多东西.最终还是决定,以团队项目的经历为主线,叙述我关于软件工程的一些思考与体会. 凤凰涅槃,浴火重生 如果要我来概况这几周团队项目的经历的话,那么句话是我所能想到的最贴切的一个表述.从最初的雄心壮志,到中间的困顿不堪,再到目前如重生一般的喜悦,我们整个团队经历了太多太多. 重造轮子 轮子,在软件行业中经常指那些设计好的,用于处理常见功能的库.框架或者可重用的代码.而重造轮子则是说,在已经有可用的“轮子”的情况下,自己重新实现一个自己的“轮子”.有些人经常说,

团队项目Beta阶段规划与进度

项目名称:社团管理系统 团队名单:浙江大学城市学院 朱勇, 邯郸学院 张婧,南开大学 孙永谦 姜桂飞 目录 一 Alpha阶段项目反思 二 Beta阶段任务拆解和优先级 三 Beta任务分配 四 Beta任务进度表及燃尽图 一 Alpha阶段项目反思 团队在Alpha阶段基本实现北航社团程序的优先功能及其相应的后台管理,待完善之处如下: 1)需要注重项目的进度管理以及任务拆解 2)需要完善项目的Approach 3)小程序的功能如预活动投票,角色权限管理等功能需要进一步细化 4)进一步注意前端开

软件工程 团队项目总结

团队项目是6个人一组,第一次这么多人一起做一个项目.而且在这次项目中我们不仅仅是完成的代码开发工作,还多了开发文档.用户需求分析.测试等工作.这些是我们之前课程所没有接触的而又是软件开发中必不可少的. 在团队中我主要是和王以正同学一起完成代码工作,除此之外还参与讨论了我们开发文档和需求分析的设计.感觉同学们经验不足还不能很好的把这些工作和写代码很好的结合起来,大概因为我们之前做的大多只是写代码的工作吧... 感觉在团队开发中自己还有很大的不足需要去改善,因为在以后工作中十分需要团队开发的能力.同

团队项目Alpha阶段心得感悟

软工课进行了这么久,团队项目也开展了快一个月了.这一个月以来,伴随着各种各样的考试,我们前端小组的项目开展的也磕磕绊绊.因为这周五周六连续两天有考试,我甚至忘了要写心得体会. 但是我早就想写一下这一阶段的感受了,因为这个月,可谓是雪上加霜.首先是其他各门主课的各种考试和deadline,然后是团队项目老师的步步紧逼,每天都是到很晚才睡觉.我们前端小组这个月把A版本的界面大致都做了出来,过程有点痛苦.首先是我们对于BBS界面的不熟悉,而且我们也没有设计,所以从设计到写代码都是我们自己来.我们参考了

现代软件工程_团队项目_贝塔阶段_【转载】10个免费的顶级跨浏览器测试工具_2018.01.15-2018.01.19

10个免费的顶级跨浏览器测试工具 1.Browsera Browsera 可以测试和报告在您的网站上的跨浏览器布局的差异和脚本错误. Browsera不同于其他跨浏览器测试服务.其他服务,如Litmus,Browsershots,BrowserLab,以及 SuperPreview,它们仅仅截取每一个特定的页面,你必须具体再分析才行. 2.BrowserStack BrowserStack提供实时的,基于Web的浏览器测试的能力. 可以即时访问每个桌面和移动浏览器(目前超过300个),具有在内部

团队项目第一阶段冲刺站立会议10

补昨天: 今天是第一阶段冲刺的最后一天,也是项目初次成果展示的一天,忙碌的一周终于要结束了,今天的站立会议并主要讲的是晚上去哪吃饭的问题,庆祝第一阶段的结束. 五一放假好好放松一下,等待第二个冲刺阶段的到来吧.最后附团队合照一张: