fetch response status

错误内容:

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. 开发经验还是十分不足, 需要加油啊!
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 175,447评论 25 709
  • @转自GitHub 介绍js的基本数据类型。Undefined、Null、Boolean、Number、Strin...
    YT_Zou阅读 4,937评论 0 0
  • 韩国电影,煽情类型的喜剧电影。喜剧的核心往往是悲剧,苦中作乐的场景往往是这类影片的主要表达方式。 不论是智障爸爸,...
    Nameless要事情阅读 2,656评论 0 0
  • 一个人,享受着孤独 孤独,给人的是寂寞 孤独,有时是一种无奈 孤独,可以拯救一个人 孤独,也可以毁掉一个人 一个人...
    风中蓝荷阅读 1,007评论 0 2
  • 虽然不想承认,但这的确是事实。我变成了曾经鄙视的那些人的模样。虽然不想承认,我现在居然在啃老,居然把希望寄托在...
    帝_江阅读 2,885评论 1 0