不完整的元标签是不专业的
tl;dr:不完整或空元标记会破坏功能和用户体验。
问题
- 标签出现在输出中
- 电子邮件文本包含人类可读文本之间的占位符
- 丢失的占位符会让用户感到困惑
- 网站呈现奇怪的字符
- 空值会触发错误
- 潜在的安全注入漏洞
解决方案
- 验证元标记
- 尽早断言完整性
- 快速失败
- 避免空值
- 抛出有意义的异常
- 自动元验证
语境
当您留下未完成的元标记(例如 {user_name} 或 {product_name})时,它们通常会潜入您的最终输出中。想象一下发送一封电子邮件,内容是:“您好 {user_name},您的 {product_name} 订单已准备就绪。”
它让人尖叫不专业并且让用户感到困惑。
空值会导致崩溃或静默故障,从而导致糟糕的用户体验或进程中断,从而使情况变得更糟。
您可以通过在渲染或发送之前断言完整性来避免这种情况。
当您的代码发现不完整的元标记或空值时,立即停止进程并抛出异常。
示例代码
错误的
<?php $emailbody = "hello {user_name}, your order for {product_name} is confirmed."; // you forget to make the replacements sendemail($emailbody);登录后复制
正确的
<?php $emailBody = "Hello {user_name}, your order for {product_name} is confirmed."; if (strpos($emailBody, '{') !== false) { throw new Exception( "Incomplete meta tags found in email body."); } sendEmail($emailBody);登录后复制
检测
[x] 自动
您可以通过自动化测试或短绒扫描未完成的占位符({} 或类似模式)来检测这种气味。
标签
- 快速失败
等级
[x] 初学者
为什么双射很重要
在使用占位符表示用户数据时,您的系统必须维护一对一的映射。
如果您的 {user_name} 占位符存在但缺少相应的真实姓名,则您将破坏此映射。
这会导致错误、混乱以及对您的应用程序失去信任。
确保双射合规性可以避免这些问题。
人工智能一代
人工智能工具有时会在生成带有占位符的模板时引入这种气味,但无法替换真实数据。
在使用输出之前,您必须验证并完成所有占位符。
人工智能检测
如果您正确配置,诸如 linter 或电子邮件渲染验证器之类的 ai 工具可以检测未完成的元标记。
使用这些工具自动进行元标记检测并减少人为错误。
尝试一下!
记住:人工智能助手会犯很多错误
without proper instructions | with specific instructions |
---|---|
chatgpt | chatgpt |
claude | claude |
perplexity | perplexity |
copilot | copilot |
gemini | gemini |
结论
不完整的元标记不仅仅是草率,而且是有害的。验证标签、断言完整性并在需要时引发异常。
仔细处理元标签可以防止错误并确保专业体验。
关系
代码气味 12 - 空
马克西·孔蒂耶里 ・2020 年 10 月 31 日
#codenewbie #教程 #哎呀code smell 139 - 用户界面中的业务代码
马克西·孔蒂耶里 ・22 年 6 月 9 日
#哎呀 #webdev #javascript #初学者code smell 97 - 没有同理心的错误消息
马克西·孔蒂耶里 ・2021 年 10 月 27 日
#开源 #ux #编程 #javascript更多信息
快速失败
马克西·孔蒂耶里 ・2020 年 12 月 6 日
#codenewbie #编程 #webdev #哎呀空:十亿美元的错误
马克西·孔蒂耶里 ・ 十一月 18 '20
#codenewbie #教程 #编程 #webdev免责声明
代码味道是我的观点。
制作人员
托马斯·马丁内斯 (tomas martinez) 在 unsplash 上拍摄的照片
最好的错误消息是永远不会出现的错误消息。
托马斯·福克斯
软件工程精彩名言
马克西·孔蒂耶里 ・ 2020 年 12 月 28 日
#codenewbie #编程 #引号 #软件本文是 codesmell 系列的一部分。
如何查找代码中的臭部分
马克西·孔蒂耶里 ・ 21 年 5 月 21 日
#codenewbie #教程 #代码质量 #初学者以上就是代码气味 - 未解析的元标签的详细内容,更多请关注慧达安全导航其它相关文章!
免责 声明
1、本网站名称:慧达安全导航
2、本站永久网址:https//www.huida178.com/
3、本站所有资源来源于网友投稿和高价购买,所有资源仅对编程人员及源代码爱好者开放下载做参考和研究及学习,本站不提供任何技术服务!
4、本站所有资源的属示图片和信息不代表本站的立场!本站只是储蓄平台及搬运
5、下载者禁止在服务器和虚拟机下进行搭建运营,本站所有资源不支持联网运行!只允许调试,参考和研究!!!!
6、未经原版权作者许可禁止用于任何商业环境,任何人不得擅作它用,下载者不得用于违反国家法律,否则发生的一切法律后果自行承担!
7、为尊重作者版权,请在下载24小时内删除!请购买原版授权作品,支持你喜欢的作者,谢谢!
8.若资源侵犯了您的合法权益,请持 您的版权证书和相关原作品信息来信通知我们!QQ:1247526623我们会及时删除,给您带来的不便,我们深表歉意!
9、如下载链接失效、广告或者压缩包问题请联系站长处理
10、如果你也有好源码或者教程,可以发布到网站,分享有金币奖励和额外收入!
11、本站资源售价只是赞助,收取费用仅维持本站的日常运营所需
12、因源码具有可复制性,一经赞助,不得以任何形式退款。
13、本文内容由网友自发贡献和站长收集,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系1247526623@qq.com
转载请注明出处: 慧达安全导航 » 代码气味 - 未解析的元标签
发表评论 取消回复