CKFinder3 破解与防破解 (转)

本贴最后更新于 2564 天前,其中的信息可能已经时异事殊

CKFinder3 破解与防破解

转自:http://www.petershi.net/ckfinder3-cracking-of

背景:后台开发时候频繁遇到图片选择组件,要求该组件可以选择服务器上已有的图片或者新上传一张图片,选择之后还要编辑裁切图片。

试用了下 CKFinder 功能不错,就是多个站点得 500 刀确实贵了点,试试看能不能绕过授权试试看。

下载然后本地服务器配置好之后,深深地感受到了试用版真的是很 Demo,网上流传有不少破解方法。然而这些方法对于最新版并没有什么用,因为,最新版的 js 代码已经加密。里面的 if 判断基本全是加密后的字符串。

本来事情就结束了,可是心中不服。

首先格式化 js 代码(工具),找到 function S(e){ }; 加密后的内容都是在调用这个方法解密字符串。这样子的话,貌似能试试看咯。即便是搞不定也能学个算法。

首先来个测试页面:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Document</title>
</head>
<body>
    <script>
        /*
         * 原解密函数
         */
        function S(e) {
            for (var t = "", n = e.charCodeAt(0), i = 1; i < e.length; ++i) t += String.fromCharCode(e.charCodeAt(i) ^ i + n & 127);
            return t;
        }

        // 先试两个数据找下节奏
        log_info('&N[mOFC"');
        log_info(';tXRS/');


        /*记录测试数据*/
        function log_info(words) {
            console.log('----------------');
            var s = S(words);
            console.log("words: ", words, words.length);
            console.log("After S(e): ", s, s.length);
        }
    </script>
</body>

</html>

控制台输出:

words 是解密后的字符串,After S(e)是用 S 方法解密后的数据

里面有一个细节是加密后的字符串比原字符串多了一位,尝试分别删除前后一个字符看看结果:

推测除了第一位数据后面的字母是一对一的关系,删除第一位之后后面数据全乱掉,说明,第一位应该是“标志位”。

先明确下我们的目的:找到程序中判断是否购买的的判断模块,或者是判断软件是适用版本的代码,提示信息等

现在代码被加密了,Demo 版本的提示信息显然是被加密了,要顺藤摸瓜,想想办法把提示信息找出来。代码已经写死,加密后的提示信息 通过 S 函数可以直接换还原,那么我们有没有可能推出加密算法,根据网页上显示的提示信息自己生成加密的提示信息,根据这个定位代码中哪块在判断授权。

开始正式尝试的分割线


解密算法有了,字符串结构了解了,那么接下来可以试着推一推“标志位”是怎么来的。

解密算法整理一下


function  S(e)  {

    for  (var  t  =  "",  n  =  e.charCodeAt(0),  i  =  1;  i  <  e.length;  ++i)  {

        t  +=  String.fromCharCode(e.charCodeAt(i)  ^  i  +  n  &  127);

    }

    return  t;

};

for 循环里面分别对每一个字符串进行操作,确实要解密的字符串第一个字符并没有进行转换操作,这正好解释了为什么前面发现长度差 1 位的原因

// 先拎出来第一个循环


// 涉及的变量

t=""

n=e[0];  // 标志位n : 字符串第一个字符的ASCII码对应值

i  =  1;

算法公式(A):


t  =  fromCharCode(e[i]  ^  i  +  n  &  127);

为了有效防止蒙圈,根据运算符优先级,用括号框起来便于理解


t  =  fromCharCode(e[i]  ^  (  i  +  (  n  &  127  )  )  );

拆解:
(n & 127) 目的是保证字符在 ASCII 之内,暂时忽略细节不考虑溢出,简化成 n;
e[i] 看作是密文
c = String.chaCodeAt(t);

那么 c 可看作原文得到:

c = e[i] ^ ( i + n );

用人话说就是
原文 = 密文 ^ (i + “标志位”);

根据异或的特性 IF a ^ b = c THEN a ^ c = b

密文 = 原文 ^ (i + “标志位”);

进一步分析:i 在密文和原文之间,存在一对一的偏移关系,举例说:i=3, 密文[3] => 明文[3] ,因此暂且认为 (i+ “标志位”) 是个定值。
从源代码中找了两段字符,测试了下输出结果,参照下图,注意看 offset,和 offset+i,

加密字符串为 &N[mOFC" 开头字母 & 的 ASCII 值就是 38,原文就是异或了这个 offseti 的值得出 c1,原文的 ASCII 值 比如 N(78) 偏移 (39) 得到 i(105) 。

那么到此我们是有望推导出加密算法的。

显然第一个“标志位”是随机的,那么就意味着我们加密后的结果也是会非常多的。

当然好消息是要破解这个加密,找到我们想找的加密信息,不用算法也可以,因为我们已经确认了密文的结构。

比如说:密文是:This(ASCII 值:84,104,105,115)。甭管标志位怎么随机,把密文每个字符转成 ASCII 值[x1,x2,x3,x4,x5]。总有:x3-x2=104-84+1=21; x4-x3=105-104+1=2。

写个脚本穷举一下就出来了。


但是,但是,我想要加密算法。

那么就接着推吧

首先要来一个“标志位”。
ASCII 中有不少控制字符是显示不出来的,还有双引号什么的,所以不要直接和 ASCII 码死磕,把他们先撇过去,挑一些正常的。

var  charset  =  [

"!",  "#",  "$",  "%",  "&",  "'",  "(",  ")",  "*",  "+",  ",",  "-",

".",  "/",  "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",  "[",  "\\",  "]",

"^",  "_",  "`",  "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",  "{",  "|",  "}",  "~",

];

// 第一步先随机一个字符串

var  rand  =  Math.ceil(Math.random()  *  (0  -  charset.length  +  1)  +  charset.length  -  1);

// 接下来逆推公式

var  t  =  charset[rand];

var  n  =  t.charCodeAt(0);

for  (var  i  =  0;  i  <  e.length;  ++i)  {

var  a1  =  e.charCodeAt(i);  //把字母拿出来

var  a2  =  (i  +  1)  +  n  &  127;  // 偏移量加 1

var  b1  =  a1  ^  a2;  // a^b=c => a=b^c;

t  +=  String.fromCharCode(b1);

}

return  t;

找几个数据试试看:


        log_info_all("Hello World!");

        log_info_all("This is a demo");

结果:

然后就看到了这两句话:

好的吧。

那我就不搞了。

  • Mac

    Mac 是苹果公司自 1984 年起以“Macintosh”开始开发的个人消费型计算机,如:iMac、Mac mini、Macbook Air、Macbook Pro、Macbook、Mac Pro 等计算机。

    166 引用 • 595 回帖 • 1 关注
  • CKFinder
    1 引用
  • 破解
    21 引用 • 41 回帖 • 2 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • 倾城之链
    23 引用 • 66 回帖 • 137 关注
  • Postman

    Postman 是一款简单好用的 HTTP API 调试工具。

    4 引用 • 3 回帖 • 3 关注
  • 又拍云

    又拍云是国内领先的 CDN 服务提供商,国家工信部认证通过的“可信云”,乌云众测平台认证的“安全云”,为移动时代的创业者提供新一代的 CDN 加速服务。

    21 引用 • 37 回帖 • 545 关注
  • Git

    Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

    209 引用 • 358 回帖
  • Facebook

    Facebook 是一个联系朋友的社交工具。大家可以通过它和朋友、同事、同学以及周围的人保持互动交流,分享无限上传的图片,发布链接和视频,更可以增进对朋友的了解。

    4 引用 • 15 回帖 • 453 关注
  • API

    应用程序编程接口(Application Programming Interface)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。

    77 引用 • 430 回帖 • 2 关注
  • 单点登录

    单点登录(Single Sign On)是目前比较流行的企业业务整合的解决方案之一。SSO 的定义是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统。

    9 引用 • 25 回帖
  • WiFiDog

    WiFiDog 是一套开源的无线热点认证管理工具,主要功能包括:位置相关的内容递送;用户认证和授权;集中式网络监控。

    1 引用 • 7 回帖 • 587 关注
  • OAuth

    OAuth 协议为用户资源的授权提供了一个安全的、开放而又简易的标准。与以往的授权方式不同之处是 oAuth 的授权不会使第三方触及到用户的帐号信息(如用户名与密码),即第三方无需使用用户的用户名与密码就可以申请获得该用户资源的授权,因此 oAuth 是安全的。oAuth 是 Open Authorization 的简写。

    36 引用 • 103 回帖 • 9 关注
  • V2Ray
    1 引用 • 15 回帖 • 1 关注
  • golang

    Go 语言是 Google 推出的一种全新的编程语言,可以在不损失应用程序性能的情况下降低代码的复杂性。谷歌首席软件工程师罗布派克(Rob Pike)说:我们之所以开发 Go,是因为过去 10 多年间软件开发的难度令人沮丧。Go 是谷歌 2009 发布的第二款编程语言。

    497 引用 • 1387 回帖 • 283 关注
  • 旅游

    希望你我能在旅途中找到人生的下一站。

    90 引用 • 899 回帖
  • 周末

    星期六到星期天晚,实行五天工作制后,指每周的最后两天。再过几年可能就是三天了。

    14 引用 • 297 回帖
  • 心情

    心是产生任何想法的源泉,心本体会陷入到对自己本体不能理解的状态中,因为心能产生任何想法,不能分出对错,不能分出自己。

    59 引用 • 369 回帖
  • 房星科技

    房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

    6 引用 • 141 回帖 • 585 关注
  • 链书

    链书(Chainbook)是 B3log 开源社区提供的区块链纸质书交易平台,通过 B3T 实现共享激励与价值链。可将你的闲置书籍上架到链书,我们共同构建这个全新的交易平台,让闲置书籍继续发挥它的价值。

    链书社

    链书目前已经下线,也许以后还有计划重制上线。

    14 引用 • 257 回帖
  • V2EX

    V2EX 是创意工作者们的社区。这里目前汇聚了超过 400,000 名主要来自互联网行业、游戏行业和媒体行业的创意工作者。V2EX 希望能够成为创意工作者们的生活和事业的一部分。

    17 引用 • 236 回帖 • 325 关注
  • SSL

    SSL(Secure Sockets Layer 安全套接层),及其继任者传输层安全(Transport Layer Security,TLS)是为网络通信提供安全及数据完整性的一种安全协议。TLS 与 SSL 在传输层对网络连接进行加密。

    70 引用 • 193 回帖 • 432 关注
  • C

    C 语言是一门通用计算机编程语言,应用广泛。C 语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。

    85 引用 • 165 回帖 • 1 关注
  • Latke

    Latke 是一款以 JSON 为主的 Java Web 框架。

    71 引用 • 535 回帖 • 786 关注
  • Kafka

    Kafka 是一种高吞吐量的分布式发布订阅消息系统,它可以处理消费者规模的网站中的所有动作流数据。 这种动作(网页浏览,搜索和其他用户的行动)是现代系统中许多功能的基础。 这些数据通常是由于吞吐量的要求而通过处理日志和日志聚合来解决。

    36 引用 • 35 回帖
  • CloudFoundry

    Cloud Foundry 是 VMware 推出的业界第一个开源 PaaS 云平台,它支持多种框架、语言、运行时环境、云平台及应用服务,使开发人员能够在几秒钟内进行应用程序的部署和扩展,无需担心任何基础架构的问题。

    5 引用 • 18 回帖 • 167 关注
  • ngrok

    ngrok 是一个反向代理,通过在公共的端点和本地运行的 Web 服务器之间建立一个安全的通道。

    7 引用 • 63 回帖 • 624 关注
  • 创业

    你比 99% 的人都优秀么?

    84 引用 • 1399 回帖 • 1 关注
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3187 引用 • 8213 回帖
  • Lute

    Lute 是一款结构化的 Markdown 引擎,支持 Go 和 JavaScript。

    25 引用 • 191 回帖 • 16 关注
  • TextBundle

    TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

    1 引用 • 2 回帖 • 47 关注