cookie的淘宝api和封装(upload_img 上传图片到淘宝img2text 图片识别商品接口tbk_order_query 淘宝客订单查询item_list_weight 批量获取商

今天我们看看cookie在实际项目中的封装。

首先看下cookie都有哪些属性方法。

其实就两个,一个读取,一个写入。

一、读取

allCookies = document.cookie

我们通过document.cookie就可以获取当前域名及其子域名下的所有cookie,它是以"; "(分号+空格)作为分隔符的键值对形式字符串。

比如你在mdn网站下打开控制台输入

document.cookie

就会出现

'_ga=GA1.2.1682758841.1619014911; preferredlocale=en-US; lux_uid=164510371039082338; _gid=GA1.2.750491686.1645103711'

当然,不同电脑不一样哈。

taobao API 接入说明

  1. 参数说明

    • 通用参数说明
      • 参数不要乱传,否则不管成功失败都会扣费
      • url说明 https://api-gw.onebound.cn/平台/API类型/ 平台:淘宝,京东等, API类型:[item_search,item_get,item_search_shop等]
      • version:API版本
      • key:调用key,测试key:test_api_key
      • secret:调用secret,测试secret:(不用填写)
      • cache:[yes,no]默认yes,将调用缓存的数据,速度比较快
      • result_type:[json,xml,serialize,var_export]返回数据格式,默认为json
      • lang:[cn,en,ru] 翻译语言,默认cn简体中文
      • secret:密钥
    • API:item_search 参数说明:

      • q:搜索关键字
      • cat:分类ID
      • start_price:开始价格
      • end_price:结束价格
      • sort:排序[bid,bid,bid2,_bid2,_sale,_credit]
        (bid:总价,bid2:商品价格,sale:销量,credit信用,加
        前缀为从大到小排序)
      • page:页数
      • page_size:每页宝贝数量,默认40
      • seller_info:是否获取商家信息[yes,no],默认yes
    • API:item_get 参数说明: num_iid:宝贝ID

二、写入

document.cookie = newCookie

这里值得注意的是,newCookie也是一个字符串,它包含1+5个参数,分别是

1、由键名和键值组成的字符串,必填

“${name}=${value}”

值得注意的是value最后如果是分号或者空格的话,会被删除,我也是刚体验了一下才知道

2、path

;path=*path*

path用来确定cookie随哪个请求发出去

假设你的浏览器当前已经有了两个Cookie:

cookie1:name=name1; value=value1; path=/boyue/; cookie2:name=name2; value=value2; path=/boyue/tongxue/。

当访问http://localhost/boyue/*时,请求头中会包含cookie1,而不会包含cookie2。

当访问http://localhost/boyue/tongxue/*时,请求头中会包含上面两个。

即,在访问子路径时,会包含其父路径的Cookie,而在访问父路径时,不包含子路径的Cookie。仔细想想这点其实也挺符合逻辑的,要不然这个参数也就没意义了。

3、domain

;domain=*domain*

设置域。可能有同学觉得,我有了path为什么还需要domain这个参数,他主要是为了不同域名下共享或区分一些参数,比如a.boyue.com和b.boyue.com是不同的域名,但是他们都可以拿到boyue.com下的cookie,却不能互相拿到。记得要带个“.”不然就是设置只有域名完全一样了才能获取到这个参数。

4、max-age

;max-age=*max-age-in-seconds*

这个好理解,就是设置一个多久后失效

5、;expires=date-in-GMTString-format

设置过期时间和日期,跟上面的差不多

6、;secure

表示cookie是否只能通过https协议传输

如果是true的话,即使js获取到了对应的cookie,http请求也无法携带该参数。

三、封装

封装主要就是修改它的写入、获取方法,尤其是获取方法,毕竟我需要的一般是对应的value而不是所有的键值对。下面简单实现一下

const cookie = {
  get: function (sKey) {
  // 按照存储的规则(不同键值对用分号和空格区分,小属性用分号区分),先用“; ”进行切割,再取出里面第一个等号和第一个分号中的内容即可
    return decodeURIComponent(document.cookie.replace(new RegExp("(?:(?:^|.*;)\\s*" +       encodeURIComponent(sKey).replace(/[-.+*]/g, "\\$&") + "\\s*\\=\\s*([^;]*).*$)|^.*$"), "$1")) || null;
  },
  // 写进去就完事了,会直接覆盖原来的键值对
  set: function (sKey, sValue, vEnd, sPath, sDomain, bSecure) {
    if (!sKey || /^(?:expires|max\-age|path|domain|secure)$/i.test(sKey)) { return false; }
    var sExpires = "";
    if (vEnd) {
      switch (vEnd.constructor) {
        case Number:
          sExpires = vEnd === Infinity ? "; expires=Fri, 31 Dec 9999 23:59:59 GMT" : "; max-age=" + vEnd;
          break;
        case String:
          sExpires = "; expires=" + vEnd;
          break;
        case Date:
          sExpires = "; expires=" + vEnd.toUTCString();
          break;
      }
    }
    document.cookie = encodeURIComponent(sKey) + "=" + encodeURIComponent(sValue) + sExpires + (sDomain ? "; domain=" + sDomain : "") + (sPath ? "; path=" + sPath : "") + (bSecure ? "; secure" : "");
    return true;
  },
  // 设置对应的过期时间小于当前时间即可
  remove: function (sKey, sPath, sDomain) {
    if (!sKey || !this.hasItem(sKey)) { return false; }
    document.cookie = encodeURIComponent(sKey) + "=; expires=Thu, 01 Jan 1970 00:00:00 GMT" + ( sDomain ? "; domain=" + sDomain : "") + ( sPath ? "; path=" + sPath : "");
    return true;
  }
};

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值