JavaScript奇技淫巧:隐形字符(javascript特殊字符)
itomcoil 2025-03-20 15:42 7 浏览
JavaScript奇技淫巧:隐形字符
本文,分享一种奇特的JS编程技巧,功能是:可以使字符串“隐形”、不可见!
效果展示
如下图所示,一个字符串经物别的操作之后,其长度有621字节,但内容却是“隐形”不可见的!
功能用途
这个技术可以应用到很多领域,非常具有实用性。
比如:代码加密、数据加密、文字隐藏、内容保密、隐形水印,等等。
原理介绍
实现字符串隐形,技术原理是“零宽字符”。
什么是“零宽字符”呢?
在Unicode编码中,有一类奇怪的字符格式,它们不可见、不可打印,主要用于调整字符的显示格式。
常见零宽字符类型:
空格符:格式为U+200B,用于较长字符的换行分隔;
非断空格符:格式为U+FEFF,用于阻止特定位置的换行分隔;
连字符:格式为U+200D,用于阿拉伯文与印度语系等文字中,使不会发生连字的字符间产生连字效果;
断字符:格式为U+200C,用于阿拉伯文、德文、印度语系等文字中,阻止会发生连字的字符间的连字效果;
左至右符:格式为U+200E,用于在混合文字方向的多种语言文本中,规定排版文字书写方向为左至右;
右至左符:格式为U+200F : 用于在混合文字方向的多种语言文本中,规定排版文字书写方向为右至左;
在编程实现隐形字符功能时,先将字符串转为二进制,再将二进制中的1转换为\u200b;0转换为\u200c;空格转换为\u200d,最后使用\ufeff 零宽度非断空格符作分隔符。这几种unicode字符都是不可见的,因此最终转化完成并组合后,就会形成一个全不可见的“隐形”字符串。
功能源码
function text_2_binary(text){
return text.split('').map(function(char){ return char.charCodeAt(0).toString(2)}).join(' ');
}
function binary_2_hidden_text(binary){
return binary.split('').map(function (binary_num){
var num = parseInt(binary_num, 10);
if (num === 1) {
return '\u200b';
} else if(num===0) {
return '\u200c';
}
return '\u200d';
}).join('\ufeff')
}
var text = "jshaman是专业且强大的JS代码混淆加密工具";
var binary_text = text_2_binary(text);
var hidden_text = binary_2_hidden_text(binary_text);
console.log("原始字符串:",text);
console.log("二进制:",binary_text);
console.log("隐藏字符:",hidden_text,"隐藏字符长度:",hidden_text.length);
隐型还原
接下来介绍“隐形”后的内容如何还原。
在了解上文内容之后,知道了字符隐形的原理,再结合源代码可知:还原隐形内容,即进行逆操作:将隐形的unicode编码转化成二进制,再将二进制转成原本字符。
直接给出源码:
function hidden_text_2_binary(string){
return string.split('\ufeff').map(function(char){
if (char === '\u200b') {
return '1';
} else if(char === '\u200c') {
return '0';
}
return ' ';
}).join('')
}
function binary_2_Text(binaryStr){
var text = ""
binaryStr.split(' ').map(function(num){
text += String.fromCharCode(parseInt(num, 2));
}).join('');
return text.toString();
}
console.log("隐形字符转二进制:",hidden_text_2_binary(hidden_text));
console.log("二进制转原始字符:",binary_2_Text(hidden_text_2_binary(hidden_text)));
运行效果:
如果在代码中直接提供“隐形”字符内容,比如ajax通信时,将“隐形”字符由后端传给前端,并用以上解密方法还原,那么这种方式传递的内容会是非常隐秘的。
但还是存在一个安全问题:他人查看JS源码,能看到解密函数,这可能引起加密方法泄露、被人推导出加密、解密方法。
对此问题,可以采用JS代码混淆加密,进一步提升整体JS代码安全性。
JS代码加密
用JShaman对上面两个解密函数进行代码混淆加密。
如下图,来到JShaman网站,贴入要加密的JS代码:
使用如下配置:
得到加密的JS代码:
将代码粘贴回源文件中:
加密的JS代码,运行起来跟之前完全一样。
但此时,已不再是裸露的透明JS代码,从这混乱复杂的代码中很难看出功能逻辑。
注:“隐形字符”技术,可用于前后端JS执行环境,即可在Node.JS中执行,也可在浏览器中使用。
相关推荐
- 外婆都能学会的Python教程(二十六):Python中的函数式编程
-
前言Python是一个非常容易上手的编程语言,它的语法简单,而且功能强大,非常适合初学者学习,它的语法规则非常简单,只要按照规则写出代码,Python解释器就可以执行。下面是Python的入门教程介绍...
- [编程基础] Python lambda函数总结
-
Pythonlambda函数教程展示了如何在Python中创建匿名函数。Python中的匿名函数是使用lambda关键字创建的。文章目录1介绍1.1简单使用1.2Pythonlambda与m...
- 一文掌握Python中列表推导和 Lambda 函数
-
嵌套列表推导与嵌套列表推导式一起工作:matrix=[[jforjinrange(5)]foriinrange(3)]print(matrix)#Createsa3x5...
- python中函数详解和实践
-
少看美女多学习来吧客观:1.函数定义使用def关键字定义函数:deffunction_name(parameters):"""函数文档字符串""&...
- Python基础编程20例之七:filter过滤,筛选奇数
-
20230115星期日:list_value=[1,2,3,4,5,6,7,8,9]defis_qishu(n):ifn%2==1:returnTrue...
- Python 匿名函数Lambda的9种用法
-
简单的lambda函数x=1f=lambdax:x+1print(f(1))这个简单的lambda函数接受一个参数x,并返回x+1的结果。将lambda函数赋值给变量ad...
- python匿名函数lambda的语法特点和应用场景
-
在Python的编程过程中,有时我们会碰到一些很简单的计算,但是感觉专门为这个计算创建个函数又觉得太小题大做,这时就可以用到lambda表达式。lambda是用于创建匿名函数,也就是没有具体名称的函...
- python组合函数不允许你还不会的 10 个高效技巧
-
以下是Python中组合函数的10个高效技巧,涵盖函数串联、柯里化、装饰器链式调用等场景,助你构建灵活的数据处理流水线:一、基础组合技巧1.函数管道(Pipeline)defadd(x):...
- 刘心向学(21)Python中的迭代器与内置函数
-
分享兴趣,传播快乐,增长见闻,留下美好!亲爱的您,这里是LearningYard新学苑。今天小编为大家带来文章“刘心向学(21)Python中的迭代器与内置函数”欢迎您的访问。Share...
- Python之函数式编程:funcy,功能更加齐全的函数式编程库
-
引言通过前面的关于Python中进行函数式编程的系列文章的介绍,我们已经把函数式编程范式中的相关特性,以及Python内置的类、functools模块对函数式编程范式的支持,都介绍了一遍。今天这篇文章...
- Python高级编程技巧:深入理解函数式编程
-
引言Python是一种多范式编程语言,支持面向对象、命令式、以及函数式编程等多种编程范式。函数式编程以其简洁、高效和易于并行处理的特点,在处理大规模数据和复杂逻辑时显示出独特的优势。本文将深入探讨Py...
- Python中级篇~函数式编程的概念和原则(匿名函数和高阶函数)
-
Python的函数式编程是一种编程范式,它是基于数学中的函数概念而产生的。在函数式编程中,函数被看作是一等公民,可以像变量一样被传递和操作。函数式编程具有很多优点,包括代码的可读性、可维护性和可扩展性...
- Python函数中几个特殊又很有用的函数,一定要搞明白函数式编程
-
带你走进@机器人时代Discover点击上面蓝色文字,关注我们Python函数提供了一种表单简单的函数的方式,成为lambda表达式,我们来看看下面的例子:#常规函数写法defy(m,n)...
- Python匿名函数详解:从概念到实践
-
一、什么是匿名函数?在Python中,匿名函数(AnonymousFunction)是一种不需要显式命名的函数,通常用lambda关键字定义。与使用def定义的普通函数相比,匿名函数更简洁,适合定义...
- Python 函数进阶的10大技巧,不允许你还不会
-
函数是Python编程的核心构建块,掌握高级函数技巧可以显著提升代码质量和开发效率。以下是Python函数编程的进阶技巧:1.函数参数高级用法1.1灵活的参数处理#位置参数、默认参数、可变参数...
- 一周热门
- 最近发表
- 标签列表
-
- ps图案在哪里 (33)
- super().__init__ (33)
- python 获取日期 (34)
- 0xa (36)
- super().__init__()详解 (33)
- python安装包在哪里找 (33)
- linux查看python版本信息 (35)
- python怎么改成中文 (35)
- php文件怎么在浏览器运行 (33)
- eval在python中的意思 (33)
- python安装opencv库 (35)
- python div (34)
- sticky css (33)
- python中random.randint()函数 (34)
- python去掉字符串中的指定字符 (33)
- python入门经典100题 (34)
- anaconda安装路径 (34)
- yield和return的区别 (33)
- 1到10的阶乘之和是多少 (35)
- python安装sklearn库 (33)
- dom和bom区别 (33)
- js 替换指定位置的字符 (33)
- python判断元素是否存在 (33)
- sorted key (33)
- shutil.copy() (33)