文章导航PC6首页软件下载单机游戏安卓资源苹果资源

pc软件新闻网络操作系统办公工具编程服务器软件评测

安卓新闻资讯应用教程刷机教程安卓游戏攻略tv资讯深度阅读综合安卓评测

苹果ios资讯苹果手机越狱备份教程美化教程ios软件教程mac教程

单机游戏角色扮演即时战略动作射击棋牌游戏体育竞技模拟经营其它游戏游戏工具

网游cf活动dnf活动lol周免英雄lol礼包

手游最新动态手游评测手游活动新游预告手游问答

您的位置:首页技术开发ASP 学院 → ASP木马密码加密的破解方法

ASP木马密码加密的破解方法

时间:2011/2/3 12:14:16来源:本站原创作者:佚名我要评论(3)

我们手把手教你如何破解ASP木马

破解一asp木马的经过加密的登破解asp木马密码陆密码。

由于木马里没有版本说明,具体也不知道这木马叫什么名。
    破解思路:两种,用加密后的密码替换密文和利用密文及加密算法反解出密码。前者根本算不上真正的破解。
    破解目的:没事破着玩。
    如果得不到asp源代码,那么可以说对破解密码,我毫无胜算。有位华夏的朋友说他得到了一个web的权限,但是无法修改主页,发现其中已经有个asp木马,但密码是经过加密的。那么就有了这篇动画了。好了,废话太多了,那么,作好准备,这次的解说将会相当的漫长。
    asp木马登陆密码验证关键代码如下:
    if Epass(trim(request.form("password")))="q_ux624q|p" then response.cookies("password")="8811748" ...
    很明显,用的是Epass函数把输入的密码进行加密,然后将得到的密文和原密文进行比对。如果稍有点编程基础的话,特别是VB,那么Epass里的加密算法将一目了然。如果没有,那么,没关系,相信经过我的讲解,你很快就会明白。函数中,保存密码的变量是pass。pass&"zxcvbnm,./" 将pass里的内容与zxcvbnm,./相连接得到一个新的字符串。left(pass&"zxcvbnm,./",10)取前10位。StrReverse函数将得到的10位字符串次序颠倒。len(pass)获得密码的长度。下面是一个循环。将得到的字符串中的每一位的Ascii码-密码长度+取整(字符所在位*1.1),然后将得到的数值转换成字符重新连接。最后将得到的字符串中有’字符的全部替换成B,这样密文的产生了。如果我们提取加密算法用自己的密文替换原有密文,那么相映的密码也会变成你的密码。但我说过了,这并不是真正意义上的破解。
    假如我们输入的是love,加密过程如下:
    lovelovezxcvbnm,./ ’连接lovezxcvbn
    ’取前10位nbvcxzevol
    ’次序颠倒n110(ascii)-4(位数)+int(1(位置)*1.1)
    =107107的ascii码为k,依次类推,最后密文:k`ucy|hzts
    我们可以通过密文和加密算法反推出密码。从算法的最后一步开始往上推。最后一步用B替换所有’,有没必要将B替换回’呢,答案是否定的。只要我们能得到最后的密文,密码不一样也是有可能的。如果有10个B,那原密码的个数就2的10次方个,虽然原密码只有一个,但是1024个密码都是正确的。如果要完美破解的朋友,可以自己试着编写全部的组合。
    那么这步可以忽略了。
    上面的算法很清晰,
    chr(asc(mid(temppass,j,1))-templen+int(j*1.1))
    我们只要简单的将+和-换一下就可以了。
    chr(asc(mid(temppass,j,1))+templen-int(j*1.1))
    但是还有一个问题,我们事先不知道密码的长度,没关系,幸好密码在1-10位之间,不太长。
    那么我们可以用一个1到10的循环求出所有可能的密码,再将其用StrReverse函数次序颠倒。
    那么最后得到的密码我们该怎么确定哪个就是呢。可以根据pass&"zxcvbnm,./",看除密码最后是否有zxvbnm,./的前几位。
    那么这就是真正的密码。那么如果密码是10位,将是永远正确的,因为后面不存在连接。所以我们可能得到两个答案。
    以下便是我编写的解密函数:
    function Ccode(code)for templen1=1 to 10mmcode=""for j
    =1 to 10mmcode=mmcode+chr(asc(mid(code,j,1))+templen1-int(j*1.1))
    nextCcode=strReverse(mmcode)response.write
    "密码"&templen1&":"&Ccode&""if mid(Ccode,templen1+1,10-templen1)
    =left("zxcvbnm,./",10-templen1)
    and templen1<>10 thenresult
    =left(Ccode,templen1)nextresponse.write "最后密码:"&resultend function
    好了,算法可能在这么短的时间内无法完全掌握,这是正常的,那么我将在压缩包中附送说明文档和加解密的asp源代码,大家拿回去好好研究吧。同样,密码10永恒正确的。那么我们将asp里原有的密文拿过来看看,会有什么结果。好,两个密码都可以登陆。为测试我在本地假设了个iis,如果本地无法架设web服务器,可以联系本人,用其他语言编写。

相关阅读 160WiFi破解校园客户端:实现网络共享iphone5破解移动/联通4g教程 iphone5破解4g海岛大亨5联机教程 海岛大亨5破解版联机方法豌豆荚送话费活动破解方法天天炫斗辅助刷金币攻略教程 天天炫斗辅助破解版下载智能电视安装第三方软件破解教程 支持小米、乐视、爱奇艺等各大智QQ空间相册密码破解方法 超简单适用任何QQ空间版本一起玩陶艺高级内容破解方法 详细教程

文章评论
发表评论

热门文章 没有查询到任何记录。

最新文章 127.0.0.1 需要输入用Microsoft JET Databa ASP木马密码加密的破解方法Asp中文件上传,fso方法大全js报错 抛出例外解决方法-适用于ecshop 调用127.0.0.1 需要输入用户名密码的解决方法

人气排行 教你如何用ASP生成HTML静态网页127.0.0.1 需要输入用户名密码的解决方法编写简单ASP代码测试WEB服务器环境asp用户登录模块实例代码ASP保存远程文件到本地(实用版)js报错 抛出例外解决方法-适用于ecshop 调用如何调试ASP的环境ASP.NET中MVC框架模式方法如何实现分享