Posted on 2001-08-09
Last Modified: 2013-12-03
I am looking for any kind of information on API-Hooking. I think I know how to inject code. Actually I believe Windows-Hooks to be the most sensible approach (correct me if I'm wrong). However, yet I don't know where to go from here. I can intercept window messages but I need APIs.
It would be great if anyone could provide some simple example as far as that is possible.
Suggestions regarding web sites or even books would be nice ,too.
Since I use Visual C++ I would appreciate according examples most. No clue about delphi, sorry.
Question by:Schuhschrank
LVL 32

Expert Comment

ID: 6369355
The best treatment of this I've seen it in Jeffrey Richter's book, "Programming Applications for Windows", MS Press.  There is an entire chapter on this topic and it goes into great detail about which technique works best for a particular situation and version of Windows.
LVL 86

Expert Comment

ID: 6369501
>>I believe Windows-Hooks to be the most sensible approach

It isn't, as hooks are only useful for GUI applications.



"Detours is a library for instrumenting arbitrary Win32 functions on x86 machines. Detours intercepts Win32 functions by re-writing target function images."

Expert Comment

ID: 6370162

If you can get it working properly it is the best hook I have found. I had made my own using a similar approach but gave up after using his because I am sure I could not improve on it. I use it in conjunction with SetWindowsHook and can capture any API call not made explicitly by the kernel.
Salesforce Made Easy to Use

On-screen guidance at the moment of need enables you & your employees to focus on the core, you can now boost your adoption rates swiftly and simply with one easy tool.


Expert Comment

ID: 6373315

Askers can accept any comment made to their questions as the answer. Because of that, a lot of experts never answer a question, but post comments only.

I don't think you necessarily need to adhere to that. If an asker asks "what is 1 + 1" I can't blame the first person in when they lock the question with the answer "2". But most questions aren't as clear cut as that.

In the wonderful world of computing, there often are many different ways to "skin a cat" (as the saying goes).

A lot of times you cannot be *absolutely* sure that your suggestion is going to address the question.

Very often, other participants have already made suggestions.

If any of this is true, you should only post your suggestions as a comment.

Like any web community, Experts-Exchange has a netiquette that members adhere to. Some of this is in the form of "unwritten rules", but a lot of it is described in our member agreement. You can find that here:

Please also read our tips on comments and answers:

Thank you for your understanding, and I do expect you to be a bit less eager in the future.

To the asker:
It is in your own interest to reject a proposed answer as soon as possible if it doesn't fully address your problem. As long as a question is "locked" with a proposed answer, a lot of experts will not bother looking at it. Once you've rejected the question, it will become "open" again, which is like an invitation to experts to participate in your question.


Community Support

Expert Comment

ID: 6373459
maybe you should just remove the answer radio button all together since it has no purpose anyway.

Expert Comment

ID: 6373489
That has been argued by many people, and opinions differ.....

I can't give you an "official line" on this, although the fact that the option to post a proposed answer is still around says something about that. <smile>

Just my personal opinion though, there are some questions that *can* be answered directly. This just doesn't happen to be one of them. But for those simple questions that have only one correct answer the option to lock the question makes sense.
LVL 20

Accepted Solution

Madshi earned 100 total points
ID: 6374397
Hi guys...

Thanx, mite51 again for recommending my stuff...   :-)

Hi jhance, I've also read Jeff Richter's book, but IMHO the most important (because it is the best) API hooking method isn't even mentioned there!! It's the method that Detours is using (see jkr's link) and also the method (in slightly extended form) that my own API hooking package uses.

>> I believe Windows-Hooks to be the most sensible approach

As jkr already said, you can use Windows hooks only to inject your stuff into GUI processes. The better way is to use CreateRemoteThread - BTW, *this* is covered in Jeff Richter's book...  :-)  Normally CreateRemoteThread is available in NT only, but if you're using my package, CreateRemoteThread is also running perfectly fine in win9x based systems...

Here are some links, the documentation about my packages is for the Delphi version of my stuff. But the difference to the C++ version of my package is not very big.

Regards, Madshi.

Featured Post

Salesforce Made Easy to Use

On-screen guidance at the moment of need enables you & your employees to focus on the core, you can now boost your adoption rates swiftly and simply with one easy tool.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

This article shows a few slightly more advanced techniques for Windows 7 gadget programming, including how to save and restore user settings for your gadget and how to populate the "details" panel that is displayed in the Windows 7 gadget gallery.  …
For a while now I'v been searching for a circular progress control, much like the one you get when first starting your Silverlight application. I found a couple that were written in WPF and there were a few written in Silverlight, but all appeared o…
This is Part 3 in a 3-part series on Experts Exchange to discuss error handling in VBA code written for Excel. Part 1 of this series discussed basic error handling code using VBA.…
In an interesting question ( here at Experts Exchange, a member asked how to split a single image into multiple images. The primary usage for this is to place many photographs on a flatbed scanner…

831 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question