[package] uhttpd: redirect to same location with trailing slash appended if directories are requested
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@23952 3c298f89-4303-0410-b956-a3cf2f4a3e73master
parent
117b470805
commit
1cdac6bf95
|
@ -8,7 +8,7 @@
|
||||||
include $(TOPDIR)/rules.mk
|
include $(TOPDIR)/rules.mk
|
||||||
|
|
||||||
PKG_NAME:=uhttpd
|
PKG_NAME:=uhttpd
|
||||||
PKG_RELEASE:=18
|
PKG_RELEASE:=19
|
||||||
|
|
||||||
PKG_BUILD_DIR := $(BUILD_DIR)/$(PKG_NAME)
|
PKG_BUILD_DIR := $(BUILD_DIR)/$(PKG_NAME)
|
||||||
PKG_BUILD_DEPENDS := libcyassl liblua
|
PKG_BUILD_DEPENDS := libcyassl liblua
|
||||||
|
|
|
@ -474,6 +474,7 @@ struct path_info * uh_path_lookup(struct client *cl, const char *url)
|
||||||
char *docroot = cl->server->conf->docroot;
|
char *docroot = cl->server->conf->docroot;
|
||||||
char *pathptr = NULL;
|
char *pathptr = NULL;
|
||||||
|
|
||||||
|
int slash = 0;
|
||||||
int no_sym = cl->server->conf->no_symlinks;
|
int no_sym = cl->server->conf->no_symlinks;
|
||||||
int i = 0;
|
int i = 0;
|
||||||
struct stat s;
|
struct stat s;
|
||||||
|
@ -516,7 +517,7 @@ struct path_info * uh_path_lookup(struct client *cl, const char *url)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* create canon path */
|
/* create canon path */
|
||||||
for( i = strlen(buffer); i >= 0; i-- )
|
for( i = strlen(buffer), slash = (buffer[max(0, i-1)] == '/'); i >= 0; i-- )
|
||||||
{
|
{
|
||||||
if( (buffer[i] == 0) || (buffer[i] == '/') )
|
if( (buffer[i] == 0) || (buffer[i] == '/') )
|
||||||
{
|
{
|
||||||
|
@ -567,7 +568,23 @@ struct path_info * uh_path_lookup(struct client *cl, const char *url)
|
||||||
memcpy(buffer, path_phys, sizeof(buffer));
|
memcpy(buffer, path_phys, sizeof(buffer));
|
||||||
pathptr = &buffer[strlen(buffer)];
|
pathptr = &buffer[strlen(buffer)];
|
||||||
|
|
||||||
if( cl->server->conf->index_file )
|
/* if requested url resolves to a directory and a trailing slash
|
||||||
|
is missing in the request url, redirect the client to the same
|
||||||
|
url with trailing slash appended */
|
||||||
|
if( !slash )
|
||||||
|
{
|
||||||
|
uh_http_sendf(cl, NULL,
|
||||||
|
"HTTP/1.1 302 Found\r\n"
|
||||||
|
"Location: %s%s%s\r\n"
|
||||||
|
"Connection: close\r\n\r\n",
|
||||||
|
&path_phys[strlen(docroot)],
|
||||||
|
p.query ? "?" : "",
|
||||||
|
p.query ? p.query : ""
|
||||||
|
);
|
||||||
|
|
||||||
|
p.redirected = 1;
|
||||||
|
}
|
||||||
|
else if( cl->server->conf->index_file )
|
||||||
{
|
{
|
||||||
strncat(buffer, cl->server->conf->index_file, sizeof(buffer));
|
strncat(buffer, cl->server->conf->index_file, sizeof(buffer));
|
||||||
|
|
||||||
|
|
|
@ -52,6 +52,7 @@ struct path_info {
|
||||||
char *name;
|
char *name;
|
||||||
char *info;
|
char *info;
|
||||||
char *query;
|
char *query;
|
||||||
|
int redirected;
|
||||||
struct stat stat;
|
struct stat stat;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -566,7 +566,7 @@ static void uh_mainloop(struct config *conf, fd_set serv_fds, int max_fd)
|
||||||
if( (pin = uh_path_lookup(cl, req->url)) != NULL )
|
if( (pin = uh_path_lookup(cl, req->url)) != NULL )
|
||||||
{
|
{
|
||||||
/* auth ok? */
|
/* auth ok? */
|
||||||
if( uh_auth_check(cl, req, pin) )
|
if( !pin->redirected && uh_auth_check(cl, req, pin) )
|
||||||
uh_dispatch_request(cl, req, pin);
|
uh_dispatch_request(cl, req, pin);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1089,4 +1089,3 @@ int main (int argc, char **argv)
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue