%1在Apache服务器上不是有效的Win32应用程序

问题描述:

我有在Windows 7 x64上运行的Apache 2.2 32位服务器。我需要使用perl,所以我已经安装了草莓5.12.3 32位并配置了Apache,所以我有2个位置: primary - cgi only和secondary - 使用mod_perl。我的问题是,我可以运行没有任何问题从次级位置的网页和脚本,而主要位置生成500错误和错误日志条目说:%1在Apache服务器上不是有效的Win32应用程序

[Wed Dec 12 09:13:10 2012] [error] [client 127.0.0.1] (OS 193)%1 is not a valid win32 application. : couldn't create child process: 720193: login.pl 

在Windows事件日志我有错误的脚本7001在控制台中运行精细。你知道什么是错的吗?

这里是我的Apache的httpd.conf

ServerRoot "C:/Apache2_2" 

PerlSetEnv NO_CACHE 1 
PerlSetEnv DEBUG_SQL 1 
Listen 80 

LoadModule actions_module modules/mod_actions.so 
LoadModule alias_module modules/mod_alias.so 
LoadModule asis_module modules/mod_asis.so 
LoadModule auth_basic_module modules/mod_auth_basic.so 
LoadModule authn_default_module modules/mod_authn_default.so 
LoadModule authn_file_module modules/mod_authn_file.so 
LoadModule authz_default_module modules/mod_authz_default.so 
LoadModule authz_groupfile_module modules/mod_authz_groupfile.so 
LoadModule authz_host_module modules/mod_authz_host.so 
LoadModule authz_user_module modules/mod_authz_user.so 
LoadModule autoindex_module modules/mod_autoindex.so 
LoadModule cgi_module modules/mod_cgi.so 
LoadModule dir_module modules/mod_dir.so 
LoadModule env_module modules/mod_env.so 
LoadModule include_module modules/mod_include.so 
LoadModule isapi_module modules/mod_isapi.so 
LoadModule log_config_module modules/mod_log_config.so 
LoadModule mime_module modules/mod_mime.so 
LoadModule negotiation_module modules/mod_negotiation.so 
LoadModule setenvif_module modules/mod_setenvif.so 
LoadModule ssl_module modules/mod_ssl.so 
LoadModule perl_module modules/mod_perl.so 
LoadFile "C:/strawberry/perl/bin/perl512.dll" 

PerlSwitches -wT -IC:/home/kks/srv/bin 

<IfModule !mpm_netware_module> 
    <IfModule !mpm_winnt_module> 
     User daemon 
     Group daemon 
    </IfModule> 
</IfModule> 
ThreadsPerChild 20 
ServerAdmin [email protected] 
DocumentRoot "C:/Apache2_2/htdocs" 
ErrorLog "|perl bin/pipedLogClient.pl -e" 
LogLevel warn 

SetEnv PERLDB_OPTS "RemotePort=localhost:9000" 
SetEnv DBGP_IDEKEY "kks" 

<IfModule log_config_module> 
    LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\"" combined 
    LogFormat "%h %l %u %t \"%r\" %>s %b" common 
<IfModule logio_module> 
     LogFormat "%h %l %u %t \"%r\" %>s %b \"%{Referer}i\" \"%{User-Agent}i\" %I %O" combinedio 
</IfModule> 
    CustomLog "|perl bin/pipedLogClient.pl -a" common 
</IfModule> 

<IfModule alias_module> 
    Alias /primary/static/ "C:/home/kks/srv/bin/static/" 
    ScriptAlias /primary/ "C:/home/kks/srv/bin/" 

#=== primary ===# 

<Location "/primary/"> 
     AllowOverride None 
     Options FollowSymLinks 
     Order allow,deny 
     Allow from all 
</Location> 
<Location "/primary/static/"> 
     SetHandler default-handler 
     AllowOverride None 
     Options None 
     Order allow,deny 
     Allow from all 
</Location> 

Alias /secondary/static/ "C:/home/kks/srv/bin/static/" 
ScriptAlias /secondary/ "C:/home/kks/srv/bin/" 

<Location "/secondary/"> 
     SetHandler perl-script 
     PerlResponseHandler ModPerl::Registry 
     PerlOptions +ParseHeaders 
     PerlCleanupHandler owf_cleanup 
     Options FollowSymLinks 
     Options +ExecCGI 
     Order allow,deny 
     Allow from all 
</Location> 

<Location "/secondary/static/"> 
     SetHandler default-handler 
     Options None 
     Order allow,deny 
     Allow from all 
</Location> 

</IfModule> 
+0

我的猜测路径:错误消息指出您正尝试通过调用一个奇怪的可执行文件来创建一个进程。但是,您没有名为'%1'的可执行文件。打开'login.pl',然后在'open','system','exec','qx()'中搜索该文件,反向查看是否有错误。你可能只是忘记用一个值或其他东西来替换一个占位符。与此无关,错误7001被描述[这里](http://support.microsoft.com/kb/278658/en-us),并指向网络问题。 – amon

+0

不是这样 - 任何脚本都会发生同样的情况 - 事件最简单。 – karex

+0

另一个有希望的链接:[启动服务的问题](https://social.technet.microsoft.com/wiki/contents/articles/1452.event-id-7001-service-start-operations.aspx)。 – amon

入住login.pl shebang行,并确保perl的有指向您已经安装了草莓