美文网首页小程序媛@IT·互联网
阿里云OpenSearch的nodejs接入实现

阿里云OpenSearch的nodejs接入实现

作者: 永恒乐章 | 来源:发表于2016-08-18 15:10 被阅读119次

    阿里云OpenSearch的API  

    链接

    首先说一句,阿里的文档写的真烂

    然后说重点

    阿里OpenSearch没有nodejs的SDK,所以如果你想用node接入,就需要自己实现他们给的接口。

    接入方式就是通过一个网络请求,请求分为两部分,一部分是公共参数,一部分是搜索需要的参数。

    首先说公共参数部分,具体参数参考文档要求,一个都不能少,我主要说这个授权签名部分。

    签名步骤

    上面链接是阿里给的签名步骤,一般正常人都得看几遍才能明白什么意思,大概意思就是,把公共参数除了Signature和你搜索时候需要用的参数按照一定的排布和编码,生产一个地址,然后把这个地址通过HMAC算法进行签名,然后把这个计算得到的结果当成Signature参数的值,最终这就是你的请求地址。

    好了,看上去没啥困难,但是实际操作坑太多了。。。

    首先是时间戳,必须是utc时间,而且必须是0时区的,这个时间戳必须准确,因为阿里会验证,如果你传的时间和当前时间超过10分钟的差距,就报错。

    然后就是编码,这个应该是最大的坑。

    参数都是用 key=value的形式传递,参数之间用&进行连接。这个value必须是经过编码过的,这个编码不是nodejs简单的encodeURIComponent,还需要在这基础之上把  '   转成   %27


    function  CanonicalString(str){

    varcanonicalString=encodeURIComponent(str);

    var regS=new RegExp("'");

    canonicalString=canonicalString.replace(/\'/g,"%27");

    return canonicalString;

    }


    上面是转换的函数,可以直接用这个编码value。

    然后把公共参数和搜索参数合并在一起,并且用&连接,这个整个字符串进行一次编码,不过这次是encodeURIComponent,不需要转化特殊字符。这个编码之后的字符串,再在前面加上强求方式


    function  stringToSign(url){

    var string = 'GET&'+'%2F'+'&'+encodeURIComponent(url);

    return string;

    }


    然后这个字符串,就可以进行SHA1加密了,注意你的秘钥后面需要几个&符号

    最好得到的加密字符串,再进行一次编码,encodeURIComponent这个方法就行,然后这个值就作为了Signature的值,排到参数里面,就可以了。

    相关文章

      网友评论

        本文标题:阿里云OpenSearch的nodejs接入实现

        本文链接:https://www.haomeiwen.com/subject/jbyvsttx.html