You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
20 lines
943 B
20 lines
943 B
6 years ago
|
diff --git a/modules/proxy/proxy_util.c b/modules/proxy/proxy_util.c
|
||
|
index a78224b..e672e4a 100644
|
||
|
--- a/modules/proxy/proxy_util.c
|
||
|
+++ b/modules/proxy/proxy_util.c
|
||
|
@@ -2260,8 +2260,12 @@ ap_proxy_determine_connection(apr_pool_t *p, request_rec *r,
|
||
|
* The scheme handler decides if this is permanent or
|
||
|
* short living pool.
|
||
|
*/
|
||
|
- /* are we connecting directly, or via a proxy? */
|
||
|
- if (!proxyname) {
|
||
|
+ /* Unless we are connecting the backend via a (forward Proxy)Remote, we
|
||
|
+ * have to use the original form of the URI (non absolute), but this is
|
||
|
+ * also the case via a remote proxy using the CONNECT method since the
|
||
|
+ * original request (and URI) is to be embedded in the body.
|
||
|
+ */
|
||
|
+ if (!proxyname || conn->is_ssl) {
|
||
|
*url = apr_pstrcat(p, uri->path, uri->query ? "?" : "",
|
||
|
uri->query ? uri->query : "",
|
||
|
uri->fragment ? "#" : "",
|