如何在使用jsonp代理时发送标头?

时间:2012-12-03 10:34:43

标签: http-headers sencha-touch sencha-touch-2 jsonp

我正在尝试从我的应用程序中获取Web服务的数据以加载列表并使用pull refresh& ListPaging插件。我用flickr API尝试了这个并且它工作正常,但是当我尝试访问我们自己的服务时出现问题,因为他们期望使用Base64编码数据的“Authorization”头和“Accept”头来决定响应的格式。

这就是我定义商店的方式:

Ext.define('myshop.store.CatalogListStore',{
    extend:'Ext.data.Store',
    requires: [
        'myshop.model.CatalogListItem'
    ],
    config:{
        model:'myshop.model.CatalogListItem',
        autoLoad :true,
        proxy: {
            type: 'jsonp',
            url: 'http://192.168.23.89:7003/xxx-service/test/catalog/list',
            useDefaultXhrHeader : false,
            withCredentials:true,
            method : 'GET',
            headers: {
                'Accept': 'application/json',
                'Authorization': 'Basic YX5iOmM='
            },
            extraParams: {
                format : 'json',
                pagesize : 10
            },
            reader: {
                type: 'json',
                rootProperty: 'categories.data'
            }
        }
    }
}

这就是我在Chrome网络控制台中看到的内容:

Request URL:http://192.168.23.89:7003/xxx-service/test/catalog/list?_dc=1354529083930&format=json&pagesize=10&page=1&start=0&limit=25&callback=Ext.data.JsonP.callback2
Request Method:GET
Status Code:403 Forbidden
**Request Headers**
Accept:*/*
Accept-Charset:ISO-8859-1,utf-8;q=0.7,*;q=0.3
Accept-Encoding:gzip,deflate,sdch
Accept-Language:en-US,en;q=0.8
Connection:keep-alive
Host:192.168.23.89:7003
Referer:http://localhost/myshop/
User-Agent:Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/536.11 (KHTML, like Gecko) Ubuntu/12.04 Chromium/20.0.1132.47 Chrome/20.0.1132.47 Safari/536.11
**Query String Parameters**
_dc:1354529083930
format:json
pagesize:10
page:1
start:0
limit:25
callback:Ext.data.JsonP.callback2
Response Headersview source
Content-Length:0
Content-Type:text/xml
Date:Mon, 03 Dec 2012 10:04:40 GMT
Server:Apache-Coyote/1.1

如果我使用Poster来使用Authorization标头访问这些服务,我可以看到响应,但由于Header未在请求中传递,因此我获得“403 forbidden”状态。

如果我使用这样的标题,它可以工作:

Ext.Ajax.request({
        url: 'resources/data/templates.json',
        headers: {
            'Accept': 'application/json',
            'Authorization': 'Basic T3JkZXJSZWxlYXNlUmVmcmVzaGVyfk9yZGVyUmVsZWFzZVJlZnJlc2hlcjpPcmRlclJlbGVhc2VSZWZyZXNoZXI='
        },
        success: function(rsp){
        }
});

但我不能这样做,因为我想使用listPaging插件。

1 个答案:

答案 0 :(得分:1)

JSONP Works购买请求URL作为页面标题中的插入,如果您需要验证您的请求,您必须将其放在URL中,例如:

'http://192.168.23.89:7003/xxx-service/test/catalog/list?auth=1223456'

您确定需要使用JSONP吗?

有关详细信息,请参阅此answer