一段javascript转PHP的encrypt加密算法

简介: javascript 常用函数转换成PHP代码处理

javascript 常用函数转换成PHP代码处理

对应的javascript代码如下:

classjs2php{
publicstaticfunctiondetect_encoding($text){
$charsets=array(“UTF-8,“GB2312”,“GBK”,“BIG5”,“ASCII”,“EUC-JP”,‘KOI8-R’,“Shift_JIS”,“CP936”,“ISO-8859-1,“JIS”,“eucjp-win”,“sjis-win”);
encode= ( mbdetectencoding ( encode= (mb_detect_encoding(encode=(mbdetectencoding(text, $charsets));
return$encode;
}
publicstaticfunctionstrlen()
{
staticfunc=null ; if ( isnull ( func=null; if (is_null(func=null;if(isnull(func)) {
$func=‘strlen’;
if (function_exists(‘mb_strlen’)) {
$func=‘mb_strlen’;
}elseif (function_exists(‘iconv_strlen’)) {
$func=‘iconv_strlen’;
}
}
$args=func_get_args();
encode=self : : detectencoding ( encode=self::detect_encoding(encode=self::detectencoding(args[0]);
$args[1] =$encode;
returncall_user_func_array($func, $args);
}
publicstaticfunctionsubstr()
{
staticfunc=null ; if ( isnull ( func=null; if (is_null(func=null;if(isnull(func)) {
$func=‘substr’;
if (function_exists(‘mb_substr’)) {
$func=‘mb_substr’;
}elseif (function_exists(‘iconv_substr’)) {
$func=‘iconv_substr’;
}
}
$args=func_get_args();
encode=self : : detectencoding ( encode=self::detect_encoding(encode=self::detectencoding(args[0]);
$args[3] =$encode;
returncall_user_func_array($func, KaTeXparseerror: Expected'EOF', got'}'atposition8: args); }̲publicstatic…str, KaTeXparseerror: Expected'}', got'EOF'atendofinput: =false) { if (!offset) offset=0 ; returnself : : ordutf8 ( offset=0; returnself::ordutf8(offset=0;returnself::ordutf8(str, KaTeXparseerror: Expected'EOF', got'}'atposition10: offset); }̲privatestatic…string, &$offset)
{
code=ord ( substr ( code=ord(substr(code=ord(substr(string, offset , 1 ) ) ; if ( offset,1)); if (offset,1));if(code>=128) { //otherwise 0xxxxxxxif ($code<224) bytesnumber=2 ; / /110xxxxxelseif ( bytesnumber=2; //110xxxxx else if (bytesnumber=2;//110xxxxxelseif(code < 240) b y t e s n u m b e r = 3 ; / / 1110 x x x x e l s e i f ( bytesnumber = 3; //1110xxxx else if (bytesnumber=3;//1110xxxxelseif(code < 248) $bytesnumber = 4; //11110xxx$codetemp=code192 ( code-192- (code−192−(bytesnumber>2?32 : 0) - (bytesnumber>3?16 : 0 ) ; for ( bytesnumber>3?16 : 0); for (bytesnumber>3?16:0);for(i=2; $i<=$bytesnumber; $i++) {
$offset++;
code2=ord ( substr ( code2=ord(substr(code2=ord(substr(string, $offset, 1)) -128; //10xxxxxx$codetemp=$codetemp*64+$code2;
}
$code=$codetemp;
}
offset+=1 ; if ( offset+=1; if (offset+=1;if(offset>=strlen($string)) $offset=-1;
returnKaTeXparseerror: Expected'EOF', got'}'atposition7: code; }̲publicstatic…a, $b)
{
return (
$a>=0?$a>>b : ( ( b : ((b:((a&0x7fffffff) >>b )  ( 0x40000000>> ( b) | (0x40000000>> (b)(0x40000000>>(b-1))
);
}
publicstaticfunctioncharAt(a , a,a,i)
{
returnself::substr(a , a,a,i,1);
}
publicstaticfunctionhex_md5(KaTeXparseerror: Expected'}', got'EOF'atendofinput: …r){ returnmd5(str);
}
publicstaticfunctiontoString(str , str,str,dec=null){
if(dec==16 ) returndechex ( dec==16)returndechex(dec==16)returndechex(str);
return (string)$str;
}
publicstaticfunctionreverse(KaTeXparseerror: Expected'}', got'EOF'atendofinput: array_reverse(arr);
}
publicstaticfunctionstring_lenght($string) {
returnstrlen(iconv(‘UTF-8, ‘UTF-16LE’, $string)) /2;
}
publicstaticfunctioncharCodeAt($str, $index){
//not working!char=mbsubstr ( char=mb_substr(char=mbsubstr(str, index , 1 , UTF8 ) ; if ( mbcheckencoding ( index, 1, 'UTF-8'); if (mb_check_encoding(index,1, 
UTF−8 );if(mbcheckencoding(char, ‘UTF-8))
{
ret=mbconvertencoding ( ret=mb_convert_encoding(ret=mbconvertencoding(char, ‘UTF-32BE’, ‘UTF-8);
returnhexdec(bin2hex($ret));
} else {
returnnull;
}
}
}
//一段由js代码转换而来的加密算法<?phpclassmmb_d{ static$zero=array("0", "00", "000", "0000", "00000", "000000", "0000000", "00000000"); static$chars=array('0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'); staticpublicfunctionstrReverse($a) { $b='';$c=array(); for ($b=0, $l=strlen($a); $b<$l; $b++) $c[] =$a{$b}; returnimplode('',array_reverse($c)); } staticpublicfunctionencrypt($a, $b, $e) { $a1=static::shuzi($a); $a2=static::zimu($a); $a=$a2 . $a1; $f=''; $g=array(); for ($f=0, $l=strlen($a); $f<$l; $f++) $g[] =static::to(js2php::charCodeAt($a,$f), $b); returnstatic::rnd($e?static::strReverse(implode("",$g)) : implode("",$g), 4); } staticpublicfunctionto($a, $c) { $e="" . js2php::toString(static::round($a+88, $c),16); $f=$c-strlen($e); return$f>0?static::$zero{$f-1} . $e : $e; } staticpublicfunctionround($a, $b) { $c=1<<4*$b; return0>$a?$a%$c+$c : $a%$c; } staticpublicfunctionshuzi($a) { returnpreg_replace('/[^0-9]+/i', "",$a); } staticpublicfunctionzimu($a) { returnpreg_replace('/[^a-zA-Z]+/i', "",preg_replace('/https/', "http",strtolower($a))); } staticpublicfunctionrnd($a, $b) { returnstatic::rd($b) . js2php::hex_md5($a) . static::rd(ceil(('0.'.mt_rand()) *10)); } staticpublicfunctionrd($a) { $res=""; for ( $i=0; $i<$a; $i++) { $res .=static::$chars[ceil(('0.'.mt_rand()) *35)]; } return$res; } } ?>


相关文章
|
1月前
|
Linux PHP 数据安全/隐私保护
2024授权加密系统PHP网站源码
2024授权加密系统PHP网站源码
118 58
|
2天前
|
JavaScript 算法 安全
深度剖析:共享文件怎么设置密码和权限的 Node.js 进阶算法
在数字化时代,共享文件的安全性至关重要。本文聚焦Node.js环境,介绍如何通过JavaScript对象字面量构建数据结构管理文件安全信息,包括使用`bcryptjs`库加密密码和权限校验算法,确保高效且安全的文件共享。通过实例代码展示加密与权限验证过程,帮助各行业实现严格的信息资产管理与协作。
|
17天前
|
存储 监控 算法
局域网网络管控里 Node.js 红黑树算法的绝妙运用
在数字化办公中,局域网网络管控至关重要。红黑树作为一种自平衡二叉搜索树,凭借其高效的数据管理和平衡机制,在局域网设备状态管理中大放异彩。通过Node.js实现红黑树算法,可快速插入、查找和更新设备信息(如IP地址、带宽等),确保网络管理员实时监控和优化网络资源,提升局域网的稳定性和安全性。未来,随着技术融合,红黑树将在网络管控中持续进化,助力构建高效、安全的局域网络生态。
40 9
|
23天前
|
监控 算法 JavaScript
基于 Node.js Socket 算法搭建局域网屏幕监控系统
在数字化办公环境中,局域网屏幕监控系统至关重要。基于Node.js的Socket算法实现高效、稳定的实时屏幕数据传输,助力企业保障信息安全、监督工作状态和远程技术支持。通过Socket建立监控端与被监控端的数据桥梁,确保实时画面呈现。实际部署需合理分配带宽并加密传输,确保信息安全。企业在使用时应权衡利弊,遵循法规,保障员工权益。
37 7
|
21天前
|
存储 监控 JavaScript
深度探秘:运用 Node.js 哈希表算法剖析员工工作时间玩游戏现象
在现代企业运营中,确保员工工作时间高效专注至关重要。为应对员工工作时间玩游戏的问题,本文聚焦Node.js环境下的哈希表算法,展示其如何通过快速查找和高效记录员工游戏行为,帮助企业精准监测与分析,遏制此类现象。哈希表以IP地址等为键,存储游戏网址、时长等信息,结合冲突处理与动态更新机制,确保数据完整性和时效性,助力企业管理层优化工作效率。
29 3
|
2月前
|
资源调度 前端开发 JavaScript
vite3+vue3 实现前端部署加密混淆 javascript-obfuscator
【11月更文挑战第10天】本文介绍了在 Vite 3 + Vue 3 项目中使用 `javascript-obfuscator` 实现前端代码加密混淆的详细步骤,包括安装依赖、创建混淆脚本、修改 `package.json` 脚本命令、构建项目并执行混淆,以及在 HTML 文件中引用混淆后的文件。通过这些步骤,可以有效提高代码的安全性。
218 2
|
4月前
|
前端开发 数据安全/隐私保护
JS-RSA超长加密
JS-RSA超长加密
146 62
|
3月前
|
JavaScript Java PHP
快速对比:Django、Spring Boot、Node.js 和 PHP
快速对比:Django、Spring Boot、Node.js 和 PHP
148 7
|
2月前
|
前端开发 JavaScript 安全
vite3+vue3 实现前端部署加密混淆 javascript-obfuscator
【11月更文挑战第7天】本文介绍了在 Vite 3 + Vue 3 项目中使用 `javascript-obfuscator` 实现前端代码加密混淆的详细步骤。包括项目准备、安装 `javascript-obfuscator`、配置 Vite 构建以应用混淆,以及最终构建项目进行混淆。通过这些步骤,可以有效提升前端代码的安全性,防止被他人轻易分析和盗用。
569 0
|
4月前
|
JavaScript 前端开发 安全
js逆向实战之烯牛数据请求参数加密和返回数据解密
【9月更文挑战第20天】在JavaScript逆向工程中,处理烯牛数据的请求参数加密和返回数据解密颇具挑战。本文详细分析了这一过程,包括网络请求监测、代码分析、加密算法推测及解密逻辑研究,并提供了实战步骤,如确定加密入口点、逆向分析算法及模拟加密解密过程。此外,还强调了法律合规性和安全性的重要性,帮助读者合法且安全地进行逆向工程。
127 11

热门文章

最新文章