Heim  >  Fragen und Antworten  >  Hauptteil

javascript - Die Qiniu-Abrufschnittstelle erfasst Ressourcen von Drittanbietern (Netzwerkbilder) und die von der JS-Ajax-Anfrage zurückgegebene Fehlermeldung lautet immer „Nicht autorisiert“.

Die Autorisierung der Abrufanforderung ist fehlgeschlagen. Ich weiß nicht, ob es sich um einen Pfadspleißfehler oder einen Fehler in der geschriebenen Ajax-Anfrage handelt.

//Anmeldeinformationen verwalten
function genManageToken(accessKey, SecretKey, pathAndQuery, body) {

var str = pathAndQuery + "\n" + body;
var hash = CryptoJS.HmacSHA1(str, secretKey);
var encodedSign = CryptoJS.enc.Base64.stringify(CryptoJS.enc.Utf8.parse(hash));
return accessKey + ":" + encodedSign;

}

var fetchImg = function(picUrl) {

// 通过fetch进行远程图片抓取
var accessKey = "AK";
var secretKey = "SK";
//网络图片picurl上传到七牛
var srcUrl = CryptoJS.enc.Base64.stringify(CryptoJS.enc.Utf8.parse(picUrl));
var bucket = CryptoJS.enc.Base64.stringify(CryptoJS.enc.Utf8.parse("bucket"));
var path = "/fetch/" + srcUrl + "/to/" + bucket;
var fetchUrl = "http://iovip.qbox.me/" + path;
mui.ajax(fetchUrl, {
    dataType: 'json', //服务器返回json格式数据
    type: 'post', //HTTP请求类型
    timeout: 10000, //超时时间设置为10秒;
    headers: {
        'Authorization': "QBox " + genManageToken(accessKey, secretKey, path, ""),
        'Content-Type': 'application/json',
    },
    success: function(data) {
        //服务器返回响应,根据响应结果,分析是否登录成功;
        data = JSON.stringify(data);
        data = eval("(" + data + ")");
        //输出响应成功key值
        console.log(data['key']);
    },
    error: function(xhr, type, errorThrown) {
        //异常处理;
        console.log(errorThrown);
    }
});

}

曾经蜡笔没有小新曾经蜡笔没有小新2712 Tage vor1538

Antworte allen(1)Ich werde antworten

  • PHP中文网

    PHP中文网2017-05-16 13:30:04

    function safe64(base64) {

    base64 = base64.replace(/\+/g, "-");
    base64 = base64.replace(/\//g, "_");
    return base64;

    }
    function genManageToken(accessKey, secretKey, pathAndQuery, body) {

    var str = pathAndQuery + "\n" + body;
    var hash = CryptoJS.HmacSHA1(str, secretKey);    
    var encodedSign = safe64(hash.toString(CryptoJS.enc.Base64));

    }
    编码问题已解决。

    Antwort
    0
  • StornierenAntwort