多年经验的程序员,却差点出生产事故,到底发生了啥?

前言

现如今的状态,我更看重开发过程的严谨性,随着我们在学习中,工作中,学习到的知识点越来越多,导致我们在开发过程中很多都记不清楚,或是有些知识点你其实是知道的,可是在实际开发时,你就是把相关的知识点给忘了,从而导致开发时思维逻辑不够严谨,初看或者测试都没有测试出问题,但实际上因为你漏掉了一层逻辑,最终导致线上出了生产事故。

需求背景

在项目中接入其他团队的一个抖音的聊天页面,约定方式为 iframe 接入,需要传递的参数为:

参数名称 类型 说明
dataId String 唯一Id(sm4加密)
role String 角色 0 = 组员,1 = 组长
signature String 签名,生成方式,以 keyValueKeyValue 形式拼接参数,最后拼接密钥,再以md5进行加密传输

我们来解读一下这个参数:

  • dataId: sm4 加密的唯一Id
  • role: 角色,这个简单
  • signature: 按照说明可以确定他的数据要求为:
js 复制代码
var dyHost = 'dy.xxxx.com.cn';
var key = "u3U0p9niWo0n1bL6"; // 密钥
var dataId = "3bcd76954353f3e05304251ddf5a3ee7"; // 加密后的唯一Id
var role = "1"; // 角色
var signature = `dataId${dataId}role${role}${key}`; //理想中的签名

所以我当时面临的工作就是要在 iframe 中添加地址与参数,地址啥都比较简单,参数看似还是比较简单所以很自然的快速完成任务,把地址拼接好放进src属性,齐活。

js 复制代码
// 此处引用 md5 的工具 md5.min.js 这里就不实际引用了
var signature = md5(signature);
var url = `https://${dyHost}/yunChat.html?dataId=${dataId}&role=${role}&signature=${signature}`;
$("#dy_iframe")[0].contentWindow.location.href = url;

至此感觉已经万事具备了,可以提代码了。

差一点就出了生产事故

就到此刻我一点都没有意识到问题的存在,直到上了测试环境,对接的团队给我提了一个问题,说拿不到参数,我懵逼了,反复看了他们提供的对接文档,是这么拼接的参数啊,没啥毛病啊,到此刻我都还没有意识到问题出在哪里?我只能在测试环境进行调试,调试中才发现,我拿到的 dataId 也就是后端用 sm4 加密后的 dataId 中出现了保留字符(;/?:@&=+$,),导致对接的团队拿不到参数,恍然大悟,这我才想起需要对 url 编码,但凡是测试没有用到 sm4 编码后没有特殊字符的 dataId,那么生产事故那肯定就出了啊。意识到了问题的存在,那接下来就是怎么解决这个问题。要解决保留字符的转译,这里选择用 encodeURIComponent 方法,用来编码或解码的4种URI我这里就不去详细解释,搞忘的或者感兴趣就自己去查一下。

js 复制代码
// 此处引用 md5 的工具 md5.min.js 这里就不实际引用了
var signature = md5(signature);
var url = `https://${dyHost}/yunChat.html?dataId=${encodeURIComponent(dataId)}&role=${role}&signature=${signature}`;
$("#dy_iframe")[0].contentWindow.location.href = url;

最终把问题解决了,我们先来复盘一下,为啥会出问题:

  1. 拿到需求与对接文档,对于拼接地址的知识准备不够充分,忽略了编码的问题;
  2. 对 sm4 加密的知识不了解,也没有去了解,只看到对接示例提供的dataId没有保留字符,就自认为没有保留字符;
  3. 对于编码这个知识点知道,但是开发的时候,不知道,归根到底一句话,知识点因为时间,或者发散导致的断层。

总结

这篇文章对知识的介绍比较少,主要是在介绍开发过程中的一些感悟。我们常常忽略,或者遗漏一些小细节,这些小细节不容易发现,但是它又决定着一些特殊情况的处理。我们都知道,知识是死的,用得好才是活的,用的不好,就是负担。对于具有有些经验的小伙伴,可能看到一个需求,凭着多年的开发经验就大概有了设计思路,但是俗话说水淹会水将,可能现在很多时候,大多出问题的地方都是"凭着多年的开发经验"。所以,当我们拿到需求后,还是要做比较严谨的设计,虽然我们经验还算丰富,那么就利用设计的时候,把相关的知识做一个温故,解决知识点的断层,这样两全其美的事我觉得是值得的,退一万步讲,即使要跳槽,在准备面试笔试时,都要少花好多时间。

相关推荐
卡兰芙的微笑13 分钟前
get_property --Cmakelist之中
前端·数据库·编辑器
覆水难收呀16 分钟前
三、(JS)JS中常见的表单事件
开发语言·前端·javascript
猿来如此呀23 分钟前
运行npm install 时,卡在sill idealTree buildDeps没有反应
前端·npm·node.js
hw_happy29 分钟前
解决 npm ERR! node-sass 和 gyp ERR! node-gyp 报错问题
前端·npm·sass
FHKHH33 分钟前
计算机网络第二章:作业 1: Web 服务器
服务器·前端·计算机网络
视觉小鸟1 小时前
【JVM安装MinIO】
前端·jvm·chrome
二川bro2 小时前
【已解决】Uncaught RangeError: Maximum depth reached
前端
qq22951165023 小时前
python毕业设计基于django+vue医院社区医疗挂号预约综合管理系统7918h-pycharm-flask
前端·vue.js·express
WebGIS皮卡茂3 小时前
【数据可视化】Arcgis api4.x 热力图、时间动态热力图、timeSlider时间滑块控件应用 (超详细、附免费教学数据、收藏!)
javascript·vue.js·arcgis·信息可视化
八了个戒3 小时前
Koa (下一代web框架) 【Node.js进阶】
前端·node.js