美文网首页
fetch response status

fetch response status

作者: 殷众 | 来源:发表于2016-02-02 16:10 被阅读1057次

错误内容:

fetch 获取的response status 在 IOS 和 Android 下不一致

背景:

  1. react SPA
  2. fetch 抓取 API
  3. Ruby On Rails

因为默认我都是需要传送 cookies
所以重写了一个 _fetch 方法,
请求头 设置成 json
默认 get 请求

偷懒只对 401 抛出异常(导致后来的错误)

export function _fetch(url, method = 'get', body) {
  return fetch(url, {
    headers: {
      'Accept': 'application/json',
      'Content-Type': 'application/json'
    },
    credentials: 'same-origin',
    method,
    body,
  })
  .then(res => {
    if (res.status == 401) {
      throw new Error(401);
    }
    return res;
  })
  .then(res => res.json());
}

BUG

上线后,不断有 Android 用户反馈 需要 验证身份 的按钮没效果.
之前在 iPhone 做测试上一直没问题的.

后台显示的错误信息是 没有匹配路由
PUT 请求 /users/sign_in (sign_in只有接受 get 请求)
403 错误

而403 我是没有处理过的
(身份验证这边的错误处理确实不完整, 如果报出一个未知错误给用户我想用户体验会好很多的)

DEBUG

出现问题的用户的共同点:

  1. Android
  2. 未注册/登录

找来台 Android 机器 测试, 发现未登陆的时候 获取的状态码 是 403

现象很明显, 就是在请求 需要验证身份的 功能时, 后台判断你未登陆会重定向到 /users/sign_in 因为之前的请求是 PUT 所以重定向的时候也是PUT 请求.
继而 报 403

Ruby On Rails 我一直有种抵触的心里, 没太多的碰过.

临时处理只能是 把 403 错误也当 401 错误抛出去

疑惑

为什么 在AndroidIOS 上会有不同的状态码? 是 fetch 的原因吗?

总结

  1. 测试还是应该做完整一点,主流的 AndroidIOS 还是应该测测的, 'WP' 相对而言暂时还可以放放.
  2. 异常错误一定要做好交互, 不然用户体验太差, 让他们手足无措, 自然用户就会关闭窗口, 留下不好的印象.
  3. 开发经验还是十分不足, 需要加油啊!

相关文章

  • fetch response status

    错误内容: fetch 获取的response status 在 IOS 和 Android 下不一致 背景: r...

  • React Native中的=>

    表达式 如: fetch(query).then(response=>response.json()).then(...

  • 初学Fetch

    什么是 Fetch API? Fetch 提供了 Request 和 Response对象(以及与网络请求有关的其...

  • Fetch API

    Fetch API 提供了用于获取资源(包括通过网络)的接口。fetch提供了request和response对象...

  • py爬虫实战-1

    response 属性及方法 1.基础了解 r.raise_for_status()与if r.status_co...

  • http响应

    1.包含 响应头、响应体、响应代码 2.response status code 3.response heade...

  • AJAX 扩展 异步请求数据的几种方法-jquery篇

    1.jquery的 load(url,data,function(response,status,xmlHttp)...

  • HTTP response status codes

    HTTP 响应状态代码指示特定HTTP请求是否已成功完成。响应分为五类: 信息响应 成功响应 重定向 客户端错误 ...

  • 使用fetch时报Uncaught (in promise) T

    先贴一下使用fetch获取数据的代码: 通过fetch中使用then来获取数据及处理response的数据时,报了...

  • ZSH中的git快捷键

    git git fetch git pull git status git add git stash git r...

网友评论

      本文标题:fetch response status

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