最近自测后端模块时有个业务需求需要利用WebServer(我用的是Apache)将HTTP POST请求转发至后端C模块,后端处理后返回2进制加密数据。http post请求的url格式为: http://demo-domain/myuri?param1=p1¶m2=p2 由于myuri非php文件,故要借助Apache的rewrite功能将其“引流”至php脚本,由后者实现真正的代理功能。 Apache的Rewrite功能由扩展模块mod_rewrite.so实现,关于mode_rewrite的介绍,可以参考。 不得不说,对于不熟悉Apache的新手(比如我)来说,还是需要折腾一番的。好在最后终于搞定了,作为笔记,记录于此。 大体来说,要使Apache实现正常的rewrite功能并实现HTTP POST请求的代理功能,需要以下2个步骤。1. 启用Apache的mod_rewrite扩展 默认情况下,Apache的扩展模块中是包含mod_rewrite.so的,相应地,其conf/httpd.conf中也会有下面这行内容: #LoadModule rewrite_module modules/mod_rewrite.so mod_rewrite扩展默认未启用,我们只需将#注释符去掉,启用该扩展模块即可。2. 开启RewriteEngine并配置RewriteRule 在httpd.conf文件最后部分添加下面2行内容: RewriteEngine ON RewriteRule ^/myuri.*$ /myproxy.php 这样就将url的方法名为myuri的http请求rewrite至myproxy.php脚本,由后者实现http proxy功能。 需要注意的几点: 1)由于我的业务需求是在服务器级做rewrite,故只需修改httpd.conf相关配置项,无需修改<Directory /> section中的AllowOverride配置,如果要用.htaccess文件实现目录级的局部rewrtie,则为保证rewrite功能正常使用,需要设置AllowOverride选项。 关于AllowOverwrite的说明,可参考。关于何时需要利用.htaccess实现rewrite,有解释,此处不再赘述。 2)配置RewrtieRule时,提到想要实现POST数据的rewrite,必须设置P Flag,表示force proxy。但我的测试结果表明,不设置P时http post的rewrite可以正常work,相反,如果设置了P flag(在RewriteRule行尾明确指定RewriteRule flag为[P]),则需要下面的第三步设置才能正常实现post的rewrite。囧。。。 3)关于RewriteRule众多flags的含义,可参考。 经过上面2步,重启Apache后,rewrite功能就可以使用了,测试表明HTTP GET/POST请求的rewrite正常,符合预期。 不过若在RewriteRule中指定[P],则post方式的rewrite还需要启用Apache的proxy扩展,如本文第3步所述。3. 启用Apache的proxy扩展(是否需要该步设置视RewriteRule是否指定P flag而定) 在httpd.conf中启用下面2个扩展模块以实现http post的proxy功能(默认未启用,去掉#注释启用即可): LoadModule proxy_module modules/mod_proxy.so LoadModule proxy_http_module modules/mod_proxy_http.so 注:经测试,上面两个扩展缺一不可
【参考资料】1. 2. 3. 4. 5.
=============== EOF ===============