Bill,

Did these changes make it into 1.3.32 -- I noticed a lot of changes in the log for mod_rewrite, but not these ones.....

Philip

William A. Rowe, Jr. wrote:

At 12:17 PM 6/21/2004, Philip Gladstone wrote:


Hi,

I discovered that (on Windows) mod_rewrite.c invokes CreateProcess when creating an 
external program to handle rewriting requests. It calls CreateProcess and passes 
'environ' to be the environment of the called process.

Unfortunately, environ is a 'char **' and the argument to CreateProcess is a sequence 
of strings of the form 'name=value\0'. This results in the invoked process getting a 
garbage environment which can cause problems.

The fix is simple -- replace environ by 0. This signals that the calling process environment is to be copied and then used by the new process.



Fix committed for 1.3.32-dev, and is not an issue for 2.0. While you are on the subject;

If you had energy to attack it, this module still needs some mutexing
to allow concurrent threads, to avoid corrupting the rewrite cache. Again,
not an issue in Apache 2.0, but if you were throwing cycles into cleaning up this module I'd be happy to review such a patch. See the ap_xxx_mutex
api's and check #ifdef MULTITHREAD to portably determine if/how we
create this protection around the rewrite cache.

Thanks,

Bill






-- Philip Gladstone 978-ZEN-TOAD (978-936-8623) Cisco Systems, Inc Boxboro, MA


Attachment: smime.p7s
Description: S/MIME Cryptographic Signature

Reply via email to