在SkyDrive上创建文件

时间:2012-04-03 22:30:05

标签: javascript rest onedrive

我正在尝试使用JavaScript在SkyDrive上创建一个新文件。

到目前为止,我最接近的是创建一个文件,但没有任何内容。

function upload() {
            WL.api({
                path: "me/skydrive/files/testfile8.txt",
                method: "PUT",
                body: "Some file content"
            }, function (response) {onError(response) });

                function onError(response) {

                $("#status").html(response.error) 
                }

        }

是否有人知道如何在SkyDrive上创建新文件并传递字符串作为文件内容。

我也尝试过使用Ajax

  $.ajax({                   
                type : "PUT",
                url: "https://apis.live.net/v5.0/me/skydrive/files/HelloWorld.txt?access_token=" + ACCESS_TOKEN,
                data: "SOMEDATA",                    
                processData: false,                                        
                success: function() { alert('Success!' );},
                error: function(a,b,c) { alert('Error!' + a + b + c); }
            });      

这只会返回一个内部服务器错误,让我很无奈:)

任何人

1 个答案:

答案 0 :(得分:0)

很抱歉回复旧帖。

以下代码怎么样?

它创建一个名为'hello.txt'的文件,其中包含字符串'Hello,world!'在你的SkyDrive文件夹中。

var CLIENT_ID = '!!!!!!!!CLIENT ID!!!!!!!!';
var REDIRECT_URI = '!!!!!!!REDIRECT URI!!!!!!!';
var filename = 'hello.txt';
var content = 'Hello, world!';
var access_token = '';
WL.init({
    client_id: CLIENT_ID,
    redirect_uri: REDIRECT_URI
}).then(function (response) {
    return WL.login({scope: ['wl.signin', 'wl.skydrive', 'wl.skydrive_update']});
}).then(function (response) {
    access_token = response.session.access_token;
    return WL.api({path: 'me/skydrive'});
}).then(function (response) {
    var url = response.upload_location + filename + '?access_token=' + access_token;
    var xhr = new XMLHttpRequest();
    xhr.open('PUT', url);
    xhr.onload = function () {
        alert('success:', xhr.responseText);
    };
    xhr.onerror = function (error) {
        alert('XHR error:', xhr.responseText);
    };
    xhr.send(new Blob([content]));
}, function (error) {
    alert('error:', error);
});

BTW,This thread也可以帮助你。