0

我已经被困了一段时间了。我在这里有ajax请求:

$.ajax({
    url: UPDATE_USER_INFO_URL ,
    type: "POST",
    dataType: "json",
    contentType: "application/json",
    data: JSON.stringify({user:'user'}),
    success: function (data, textStatus) {
        if(data["statusCode"] && data["statusCode"] == 1) {
            _callback(1,data);
        }
        else {
            _callback(0,data);
        }
    },
    error: function (jqXHR, textStatus){
        _callback(0, {});
    }           
});

如果我设置UPDATE_USER_INFO_URL为特定的 URL,提琴手在正文中不显示任何内容。如果我设置UPDATE_USER_INFO_URL为其他内容(甚至是无效的 URL),它确实会放入{user:'user'}提琴手​​的正文中。

使用原始 UPDATE_USER_INFO_URL:

POST http://10.35.50.26:8080/SelfServiceWs/user/session/upduserinfo HTTP/1.1
Accept: application/json, text/javascript, ; q=0.01
Content-Type: application/json
X-Requested-With: XMLHttpRequest
Referer: http://10.35.50.26:8080/SelfService/
Accept-Language: en-us
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; WOW64; Trident/5.0)
Host: 10.35.50.26:8080
Connection: Keep-Alive
Pragma: no-cache
Cookie: JSESSIONID=0BF9D9CCCE9030E60AB0BCE5F6562CD8
Authorization: Negotiate TlRMTVNTUAABAAAAl4II4gAAAAAAAAAAAAAAAAAAAAAGAbAdAAAADw==
Content-Length: 0

将 url 更改为 /SelfServiceWs/abcdef

POST http://10.35.50.26:8080/SelfServiceWs/abcdef HTTP/1.1
Accept: application/json, text/javascript; q=0.01
Content-Type: application/json
X-Requested-With: XMLHttpRequest
Referer: http://10.35.50.26:8080/SelfService/
Accept-Language: en-us
Accept-Encoding: gzip, deflate
User-Agent: Mozilla/5.0 (compatible; MSIE 9.0; Windows NT 6.1; WOW64; Trident/5.0)
Host: 10.35.50.26:8080
Content-Length: 15
Connection: Keep-Alive
Pragma: no-cache
Cookie: JSESSIONID=9E79779805579A7964E03AAD76DF043B

{"user":"user"}

我有许多其他 ajax 调用,都按预期工作。

我想念的东西一定是小事。

4

2 回答 2

1

我想通了。

我有一个到 url /user/ssoauth 的身份验证 servlet 过滤器,出乎意料地(对我而言),它对 /user 路径下的 URL(包括 /user/session/upduserinfo)进行了一切调用以发送授权标头。将过滤器移至 /user/auth/ssoauth 停止客户端以在调用 user/session/upduserinfo 时发送授权标头并修复问题。

<filter-mapping>
  <filter-name>SecurityFilter</filter-name>
  <url-pattern>/user/ssoauth</url-pattern>
</filter-mapping>

导致 /user 发送授权标头之后的每个客户端调用 URL。

我今天学了些新东西!

于 2013-03-04T18:14:26.543 回答
0

试试这个

data: JSON.stringify({'user':'user'}),
于 2013-03-02T04:09:59.230 回答