有懂 Uniapp 的亲,进来请教下问题

221 天前
 tlerbao

非前端刚接触 Uniapp ,一片空白,问题可能比较初级

  1. 当整个小程序必须登录才能使用的时候,这个自动 OAuth 登录的逻辑写在哪里比较好,app.vue 的 onLaunch 算不算好的选择。

  2. 拦截器拦截 switchTab 在小程序那边不行,Uniapp 文档让在鉴权的 tabbar 页面的 onShow 处理,我尝试在 onShow 添加如下代码会有一个问题,页面内容会先显示出来再跳转到 login 页面,正确的姿势应该是怎么样的?

<script lang="ts" setup>
import { useUserStore } from '@/store'
const userStore = useUserStore()
onShow(() => {
  if (!userStore.isLogin) {
    uni.redirectTo({
      url: '/pages/login/index',
    })
  }
})
1861 次点击
所在节点    前端开发
20 条回复
4ark
221 天前
1. onLaunch 没毛病
2. tab 页是否可分享?不可分享则自定义 tab 组件,点击事件拦截;可分享则分享的时候路径取 login/index + 某个特定参数,登录过了再重定向到 tab 页
eratpfus7
221 天前
在跳转前加判断
tlerbao
221 天前
@4ark
2 里的点击事件拦截明白了,可分享的话 小程序内容用户点击 tab 切换怎么弄呢?没太听明白
tlerbao
221 天前
@eratpfus7 您说的跳转前加判断能详细点吗?
4ark
221 天前
@tlerbao 可分享的话,就同时做点击事件拦截和分享进入拦截
ChangJingli
221 天前
可以用 uniapp 自带的拦截器实现:

官方文档: https://zh.uniapp.dcloud.io/api/interceptor.html
大致实现方案: https://blog.csdn.net/qq_37906822/article/details/122704299
tlerbao
221 天前
@4ark #5 意思是可分享页用自定义 tabbar 组件是吗?
tlerbao
221 天前
@ChangJingli 我已经写了类似的拦截器,但是发现拦截器拦截 switchTab 在小程序端不行的下面是官方原话

“注意:拦截 uni.switchTab 本身没有问题。但是在微信小程序端点击 tabbar 的底层逻辑并不是触发 uni.switchTab 。所以误认为拦截无效,此类场景的解决方案是在 tabbar 页面的页面生命周期 onShow 中处理。”
notproblem
221 天前
小程序一般是这样,用户点击某个按钮或者功能的时候弹出登录弹窗,最好不要放到 onShow 之类的,微信小程序有可能审核不过。
PoorBe
221 天前
小程序只能通过点击某个功能的时候才能提示需要登录吧,要不然审核不过的
ChangJingli
221 天前
@tlerbao 小程序强制登录的话,/login 页面放在 pages 数组第一行,就不会存在 switchTab 的问题呢。

这时候的流程是:
小程序启动->进入登录页->有 token->进首页
->无 token->留在登录页
tlerbao
221 天前
@ChangJingli #11 不强都登录,个别 tabbar 页面需要登录,这个路由鉴权就不行了
tlerbao
221 天前
@notproblem
@PoorBe 还有审核不过的说法?

那我整个小程序必须先登录才能使用,还非要在页面整个按钮哈哈?
ChangJingli
221 天前
@tlerbao 建议细化需求描述,因为第一条写明了:当整个小程序必须登录才能使用的时候
youknowsomething
221 天前
小程序不是必须有未登录页面才能过审吗?必须登录才能使用的小程序过不了审,反正我这边是没成功过
moonbeama
221 天前
我之前有过类似需求,我照着微信小程序社区的方法重写了生命周期,即每次进入小程序都会登录刷新 token ,拿到 token 之后再去请求接口,不会存在登录接口响应延迟而先执行其它接口报 401 的情况

https://developers.weixin.qq.com/community/develop/article/doc/00002ac57208f0e7335d111f156013
moonbeama
221 天前
@moonbeama 我做的这个业务是没有登录页的,是静默登录
Ashore
221 天前
我是这么做的:
1. 在 onLaunch 的时候判断有无 token,没 token 直接跳转到登录页面。
2. 没有 token 的时候,判断当前页面是不是 login 页,是 login 页的话不跳转。
3. 有 token 的时候。去请求用户信息接口。如果后端返回 401 跳转到登录页。
Ashore
221 天前
还有个问题就是,微信小程序是支持静默登录的。你可以通过 openid 和 Unionid (如果有 Unionid 的话)来给用户创建一个账户。等到必须申请用户信息的时候你再跳转到信息授权页面让用户授权手机号和头像。

否则的话小程序的审核会被拒绝。去年的时候我们就整改过。
dbaazz
221 天前
@moonbeama #16 写了个支持 vue3 composition api 的,有兴趣可以看下
https://www.npmjs.com/package/custom-hooks-plus

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/1042189

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX