gpt4 book ai didi

javascript - Apache 错误 : File name too long: Cannot map GET

转载 作者:数据小太阳 更新时间:2023-10-29 04:15:11 24 4
gpt4 key购买 nike

我们最近开始在我们的 Apache 日志中看到一个新错误:

[Wed Mar 16 08:32:59 2011] [error] [client 10.40.1.2] (36)File name too long: Cannot map GET /static/app/js <..lots of javascript...>

看起来好像页面中的 JavaScript 正在请求中发送到服务器。然而,尚不清楚这将如何发生。从互联网上搜索,某些 wordpress 插件似乎发生过这种情况,但没有太多其他信息。

环境注意事项:客户端使用在英国Citrix瘦客户端上运行的IE8。 Web 服务器距离 1700 公里,因此会有一点延迟。该站点大量使用 AJAX 和大型 cookie。

有人可以建议如何调试这个问题吗?

谢谢

安德鲁

最佳答案

我也明白了,PHP 框架允许 URL 格式化

index.php?controller=doohickey&id=z61

可以重写为

index.php/controller/doohickey/z61

以及框架代码中的正则表达式。

错误看起来像 (/var/log/apache/error_log):

GET /index.php/accounts_badoink/confirmaction/WUW%253DWBW%25253DV0tXPWM3Nzc1....

-> 在这种情况下,apache 将文件名解析为

/index.php/accounts_badoink/confirmaction/WUW%253DWBW%25253DV0tXPWM3Nzc1....

(我正在序列化一个对象状态并传递它)。

我必须将此(至少是带有长附加序列化对象的 URL)重写为更习惯的样式:

  GET /index.php?controller=accounts_badoink&confirmaction=WUW%253DWBW%25253DV0tXPWM3Nzc1....

-> 在这种情况下,Apache 将文件名解析为 index.php

简而言之,重写您的 URL 并尽早包含 ?,以将数据作为 CGI 样式参数而不是路径元素传递。

我为每个 Apache 进程 ID 运行 strace -p $PID &(由 pidof apache2 报告):

# pidof apache2 | tr ' ' '\n' | grep -v 21561 | sed "s|\(.*\)|strace -p \1 \&|g" | sh -

完成:

# kill -HUP `pidof strace`

并查看 apache2 进行的内核调用:

accept(3, {sa_family=AF_INET, sin_port=htons(38985), sin_addr=inet_addr("127.0.0.1")}, [16]) = 13
fcntl(13, F_GETFD) = 0
fcntl(13, F_SETFD, FD_CLOEXEC) = 0
fcntl(13, F_GETFL) = 0x2 (flags O_RDWR)
fcntl(13, F_SETFL, O_RDWR|O_NONBLOCK) = 0
read(13, "GET /newregcon/index.php/account"..., 8000) = 4949
write(2, "[Wed May 11 15:39:36 2011] [erro"..., 4451) = 4451
writev(13, [{"HTTP/1.1 403 Forbidden\r\nDate: We"..., 219}, {"<!DOCTYPE HTML PUBLIC \"-//IETF//"..., 4610}], 2) = 4829

由于这些系统调用不会返回错误(例如 ' ... = -1' ),我下载了 apache2 源代码,并发现:

“无法映射”的 Grep:

server/core.c

3489:AP_DECLARE_NONSTD(int) ap_core_translate(request_rec *r)
3490:{

3520: if ((rv = apr_filepath_merge(&r->filename, conf->ap_document_root, path,
3521: APR_FILEPATH_TRUENAME
3522: | APR_FILEPATH_SECUREROOT, r->pool))
3523: != APR_SUCCESS) {
3524: ap_log_rerror(APLOG_MARK, APLOG_ERR, rv, r,
3525: "Cannot map %s to file", r->the_request);
3526: return HTTP_FORBIDDEN;
3527: }

寻找 apr_filepath_merge ...

srclib/apr/file_io/unix/filepath.c

81:APR_DECLARE(apr_status_t) apr_filepath_merge(char **newpath,
82: const char *rootpath,
83: const char *addpath,
84: apr_int32_t flags,
85: apr_pool_t *p)
86:{
87: char *path;
88: apr_size_t rootlen; /* is the length of the src rootpath */
89: apr_size_t maxlen; /* maximum total path length */

149: rootlen = strlen(rootpath);
150: maxlen = rootlen + strlen(addpath) + 4; /* 4 for slashes at start, after
151: * root, and at end, plus trailing
152: * null */
153: if (maxlen > APR_PATH_MAX) {
154: return APR_ENAMETOOLONG;
155: }

找到 APR_PATH_MAX ...

网络软件

./srclib/apr/include/apr.hnw:424:#define APR_PATH_MAX PATH_MAX

Win32

./srclib/apr/include/apr.hw:584:#define APR_PATH_MAX 8192

./srclib/apr/include/apr.h.in

/* header files for PATH_MAX, _POSIX_PATH_MAX */
#if APR_HAVE_LIMITS_H
#include <limits.h>

/usr/src/linux-headers-2.6.35-28/include/linux/limits.h

#define PATH_MAX        4096    /* # chars in a path name including nul */

关于javascript - Apache 错误 : File name too long: Cannot map GET,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5337891/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com