使用电子访问跨源资源

时间:2017-05-26 16:03:27

标签: sharepoint-2010 cors electron

我在sharepoint上有一个列表,我在跟踪任务。

我正在尝试创建一个电子应用程序,每分钟左右ping(http get request)此列表,并显示一个包含当前用户已分配的所有任务的小窗口并突出显示新任务。

我正在使用fetch API访问列表,如下所示:

const _COLLAB_ROOT = "http://company.com/projects/team-site/_vti_bin/listdata.svc/"

export function read(list, callback) {
    const myHeaders = new Headers({
        "Accept": "application/json",
        'Authorization': 'Basic '+btoa('username:password'),
        'Access-Control-Allow-Origin': '*'
    });
    const myInit = {
        method: 'GET',
        headers: myHeaders,
        mode: 'no-cors'
    }
    fetch(_COLLAB_ROOT+list,myInit)
        .then(response => {
            if (response.ok) {
                response.json().then(data => {
                    callback(data.d);
                });
            }
            return Promise.reject(Error('error'))
        }).catch(error => {
            return Promise.reject(Error(error.message))
        })
}

其他模块:

read('listname',data => {
  console.log(data);
})

但是,当我发送此请求并填入列表名称时,我会得到以下内容: enter image description here enter image description here

现在我假设这与CORS有关。我想知道的是,有没有办法让这个工作?

在电子中似乎需要非常明显的东西。

此外,我已将we-preferences属性设置为

mainWindow = new BrowserWindow({
    width: 800,
    height: 600,
    frame: true,
    'web-preferences': {'web-security': false}
  });

这里有任何帮助。 如果不可能,我会感到非常惊讶,所以希望我是愚蠢的!

编辑:从chrome enter image description here上的Restlet客户端查询时的响应

3 个答案:

答案 0 :(得分:5)

您正在使用旧的webPreferences语法,您的构造函数应该看起来像这样:)

mainWindow = new BrowserWindow({
    width: 800,
    height: 600,
    frame: true,
    webPreferences: {
        webSecurity: false
    }
});

答案 1 :(得分:0)

仅适合开发

mainWindow = new BrowserWindow({width: 900, height: 680,webPreferences: {
nodeIntegration: true,
webSecurity: false
}});

答案 2 :(得分:0)

由于webSecurity不再控制CORS,现在似乎不可能。 (对于v9 +

webSecurity选项控制内部的网络安全性闪烁,但是 最近,CORS的控制已从眨眼中移开,因此 选项不再控制CORS。

请参见https://github.com/electron/electron/issues/23664#issuecomment-692422997