news 2026/3/27 17:38:26

公司名称打码

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
公司名称打码
/** * 公司名称打码处理函数 * 覆盖场景: * 1. 空值/非字符串处理 * 2. 1-10+字不同长度策略 * 3. 包含特殊字符/空格的名称 * 4. 中英文混合名称(按字符长度处理) * 5. 边界值处理(如刚好4字、刚好8字等) * @param {string} name 原始公司名称 * @param {Object} [options] 可选配置 * @param {string} [options.maskChar=*] 打码字符 * @param {boolean} [options.keepSpecialChar=false] 是否保留特殊字符位置(仅打码汉字/字母) * @returns {string} 打码后的名称 */ const maskCompanyName = (name, options = {}) => { // 默认配置 const { maskChar = '*', keepSpecialChar = false } = options; // 1. 空值处理:null/undefined/空字符串/非字符串类型 if (!name || typeof name !== 'string') { return ''; } // 去除首尾空格(中间空格保留) const trimmedName = name.trim(); if (trimmedName.length === 0) { return ''; } const length = trimmedName.length; let maskedName = ''; // 2. 按长度分级处理(覆盖1-10+字所有场景) if (length === 1) { // 1个字:直接打码(避免泄露) maskedName = maskChar; } else if (length === 2) { // 2个字:首字显示 + 1个打码 maskedName = trimmedName.charAt(0) + maskChar; } else if (length === 3) { // 3个字:首字 + 1个打码 + 尾字 maskedName = trimmedName.charAt(0) + maskChar + trimmedName.charAt(2); } else if (length === 4) { // 4个字:首字 + 2个打码 + 尾字(核心优化点) maskedName = trimmedName.charAt(0) + maskChar.repeat(2) + trimmedName.charAt(3); } else if (length >= 5 && length <= 8) { // 5-8字:前2字 + 3个打码 + 尾2字 const prefix = trimmedName.substring(0, 2); const suffix = trimmedName.substring(length - 2); maskedName = `${prefix}${maskChar.repeat(3)}${suffix}`; } else if (length >= 9 && length <= 12) { // 9-12字:前3字 + 4个打码 + 尾3字 const prefix = trimmedName.substring(0, 3); const suffix = trimmedName.substring(length - 3); maskedName = `${prefix}${maskChar.repeat(4)}${suffix}`; } else { // 12字以上:前4字 + 5个打码 + 尾4字(超长名称) const prefix = trimmedName.substring(0, 4); const suffix = trimmedName.substring(length - 4); maskedName = `${prefix}${maskChar.repeat(5)}${suffix}`; } // 3. 特殊处理:保留特殊字符位置(如括号、横线等) if (keepSpecialChar) { const specialCharRegex = /[^a-zA-Z0-9\u4e00-\u9fa5]/; return trimmedName.split('').map((char, index) => { // 特殊字符保留原样,其他字符用打码结果替换 return specialCharRegex.test(char) ? char : maskedName[index] || maskChar; }).join(''); } return maskedName; }; // ================ 测试用例 ================ console.log("1字:", maskCompanyName("企")); // * console.log("2字:", maskCompanyName("企业")); // 企* console.log("3字:", maskCompanyName("企业家")); // 企*家 console.log("4字:", maskCompanyName("科技有限公司")); // 科**司 console.log("5字:", maskCompanyName("北京科技有限公司")); // 北京***公司 console.log("8字:", maskCompanyName("北京中关村科技有限公司")); // 北京***公司 console.log("9字:", maskCompanyName("北京中关村科技发展有限公司")); // 北京中****限公司 console.log("13字:", maskCompanyName("北京中关村科技发展集团股份有限公司")); // 北京中关村*****份有限公司 console.log("含特殊字符:", maskCompanyName("北京(中关村)科技有限公司", { keepSpecialChar: true })); // 北*(中***)限公司 console.log("空值:", maskCompanyName(null)); // "" console.log("空格:", maskCompanyName(" 企业 ")); // 企* console.log("自定义打码符:", maskCompanyName("科技有限公司", { maskChar: '#' })); // 科##司
const maskedCompanyName = maskCompanyName(originalName); console.log(maskedCompanyName);
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/3/14 13:01:42

告别局域网束缚,FastSend+cpolar 让文件传输自由起来

文章目录前言【视频教程】1.关于FastSend2.Docker部署3.简单使用FastSend4.安装cpolar内网穿透5. 配置公网地址6. 配置固定公网地址总结FastSend 与 cpolar 的结合&#xff0c;扩展了文件传输的使用场景&#xff0c;让跨网络共享变得简单高效&#xff0c;适合需要频繁交换大文件…

作者头像 李华
网站建设 2026/3/27 13:22:57

AI如何自动生成内网通积分系统?5步实现智能管理

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个企业内网积分管理系统&#xff0c;包含以下功能&#xff1a;1.员工积分账户管理 2.积分发放/扣除规则配置 3.积分兑换商城 4.积分排行榜 5.数据可视化报表。使用React前端N…

作者头像 李华
网站建设 2026/3/14 10:20:05

Wan2.2-T2V-A14B与Stable Video对比:谁更适合商业应用

Wan2.2-T2V-A14B与Stable Video对比&#xff1a;谁更适合商业应用 你有没有试过在凌晨两点&#xff0c;盯着一个广告脚本发愁——“这段视频到底要拍多久&#xff1f;演员档期怎么协调&#xff1f;后期又要等几天&#xff1f;” &#x1f92f; 这曾是每个市场人的日常。但现在…

作者头像 李华