Hooking PR_Write |
[Jun. 22nd, 2015|09:54 pm] |
static int (*old_pr_write)(void *,void *, int);
static int pr_write(void *handle, void *buffer, int length)
{
if (length > 4 && !strncmp(buffer, "POST", 4)) {
FILE *f = fopen("/tmp/debug.txt", "a+");
if (f != NULL) {
fprintf(f, "%.*s\n", length, buffer);
fclose(f);
}
}
return old_pr_write(handle, buffer, length);
}
void init(void)
{
void *h = dlopen(NULL, RTLD_LAZY);
if (h) {
void *(*mtdfn)(void) = dlsym(h, "PR_GetTCPMethods");
if (mtdfn) {
void **mtd = (void**)mtdfn();
old_pr_write = ((int (*)(void*,void*,int))mtd[3]);
mtd[3] = pr_write;
}
}
} |
|
|
Patchless hook for NSPR!PR_Write |
[Mar. 14th, 2015|09:58 pm] |
[ | Current Mood |
| | amused | ] | С вредной либой придумал вариант, в котором вообще не нужно ничего патчить. Попробую. Все отлично работает. Победная реляция пишется прямо в хакнутом броузере. :-) VirtualProtect / mprotect, memcpy Красиво. Никаких патчей. Рейс исключен в принципе. И этот кодес я пока придержу. ;-P здесь |
|
|