背景介绍:我们 APP ( react-native 写的)的用户是某船舶公司船员,需要上传各种轮船信息,然后海上的信号大家也都知道。
现在有个需求:如果上传失败,能够在网络恢复的时候自动上传。
老板的意思最好能做到网络恢复就发送,不管这个时候 APP 在前台后台,手机锁没锁屏。
让我调研下,并给出上传失败的解决方案。
我的方案是做数据缓存,下次打开的时候提示他上次失败了,点击继续发送。老板让我去沉淀沉淀,研究下后台上传数据的方案,说他已经在网上看到相关解决方案了...
老哥们,有方案吗教教我
1
Shura 34 天前
安卓,可以写个前台服务,ios 就没辙了。
|
2
chachi 34 天前
这种 app 不应该工业设备吗
|
3
NoOneNoBody 34 天前
需求是网络恢复自动发送,但不需要用“发送”这个数据来检测网络啊,只要检测到 True 就可以通过事件驱动发送任务了吧?
前台后台这个问题才是手机的事,这个不懂,但肯定有方法的 |
4
kzfile 34 天前 2
老板自己找到方法了为啥不直说,还让你沉淀沉淀?
|
5
null113 34 天前 1
"说他已经在网上看到相关解决方案了" 让他发你参考呗
|
6
HangoX 34 天前
让老板给出网上的方案,你自己参考一下
android 目前还可以,直接挂前台服务,监听网络变化 或者用账号同步服务,或者直接用 firebase 自己带的 |
7
Jed2020 OP @null113 他看到的是解决方案是 APP 申请后台常驻权限,然后监听网络信号,信号好的时候发送数据。我跟他说常驻也不是一直常驻的,而且我感觉锁屏状态下还能发送数据应该做不到吧
|
8
manami 34 天前 via Android
手机病毒为啥都可以 /思考 ing
|
9
InkStone 34 天前
挂后台必须用户手动允许 app 后台运行,不然会被系统杀进程
|
10
Jed2020 OP 老板看到的解决方案是安卓申请后台常驻权限,然后监听网络信号,信号好的时候发送数据。我没做过 APP 保活的功能,不确定能不能做到,而且就算安卓可以做到,iOS 可以做到吗,因为我们用的 RN ,业务得统一,还有一个问题就是锁屏状态下也能保活吗?
|
14
wu67 34 天前
你去看看那个短信转发工具呗. 印象中分好几步来完成后台常驻呢.
|
15
harryWebb 34 天前
参考一下流氓安卓软件的方案。。。
时不时弹出来让用户点一下,然后常驻,还有的直接更换桌面常驻 ios 是肯定做不到的,别想了,你老板要是能 ios 做到,可以把这个方案拿去卖给黑产,比你做个什么 app 值钱多了 |
16
myderr 34 天前
建立局域网服务器,连 WiFi 上传到局域网的服务器,服务器来处理数据
|
18
coderljx 34 天前
电池优化白名单,加入自启动,锁定后台。这些都需要用户参与,用在消息推送上还可以,app 能比较稳定接收到推送。
|
19
MoYi123 34 天前 1
我在安卓平板上挂的 alist, 设置了之后基本上不会被杀. 参考一下.
https://github.com/jing332/AListFlutter |
21
tool2dx 34 天前 via Android
adb 直接运行 elf 可以保活,但是需要用户手机开启开发者模式,感觉没那么通用。
|
22
capgrey 34 天前
老板的网上:拿了个套壳 GPT 随便问了一下。GPT 热情回答:当然可以!
|
23
idonttellyou 34 天前
Android 看看 WorkerManager 能不能用
|
24
noparking188 34 天前
https://github.com/aspen-cloud/triplit
这个咋样呢 Real-time Sync: Triplit provides real-time data synchronization between server and browser with incremental updates and conflict resolution. Local Caching: It includes a full-fledged client-side database for local caching, ensuring fast interactions and offline mode. |
25
noparking188 34 天前
@noparking188 Offline-mode with automatic reconnection and consistency guarantees
|
26
zihuyishi 34 天前
你参考下音乐软件怎么实现的,把自己伪装成音乐 app 常驻后台就行了。以前很多流氓 app 也是这么实现的,所以就会出现你听着歌打开这个软件歌停了
|
27
opengps 34 天前
既然允许网络恢复后再发送,那这时效性稍微推迟一下也可以允许下次打开再发送。
所以真实需求是后续补发,而不是网络恢复就补发这个伪需求 |
28
isSamle 34 天前 5
比较简单的实现方法,船上放个中间服务器,弄个树莓派估计都可以,在上面放个消息队列,手机的数据传给中间服务器,中间服务器等连上主服务器之后进行消费
|
29
baolinliu442k 34 天前
他都看到了不直接告诉你,让你沉淀
|
30
ahzjm 34 天前
微信能做到的你就能做到
|
31
Danmen123 34 天前
我只知道安卓,国产系统专治不服,后台各种杀死。如果不是国产系统的话,workManager 刚好可以解决你的需求。
|
35
ShadowPower 34 天前
Android 可以用常驻通知+Service 保持前台运行,iOS 可以通过推送唤醒后台 APP ,联网的时候就可以收到推送。
|
36
YsHaNg 34 天前
@harryWebb 不是 iOS 开发 不确定好不好用 background tasks API https://developer.apple.com/documentation/backgroundtasks https://forums.developer.apple.com/forums/thread/693337 但是使用一些类似 Google photos 群晖 photo 只要后台卡片不划掉自主备份都没问题 不用管保活拉起
|
37
yidev 34 天前
不动 ios, 用个 vpn 方式行不行?那些代理软件都可以常驻后台啊
|
38
cheng6563 34 天前
Android 让用户把 App 加入电池白名单然后开前台服务就行了。不同系统设置不同,尤其是国产系统可能要到多个地方设置。
iOS 可以用一些后台短期运行的 API 处理,这些后台时间都有限制,不过一般用来处理一些数据上传够用了。比如后台应用刷新,地理围栏之类的。 iOS 要后台常驻需要播放声音,这样用户一旦开个其他音频 App 就不行了。 |
39
lostwolfkf 34 天前
1 ,常驻后台,要求用户自己设置不杀进程。2 、保活
|
40
cwcc 34 天前
打开 App 后如果开启“在线时自动传输”的功能后,就保持应用请求开启定位服务,然后好像就能驻留后台了?(依稀记得当初 iSH 应用想要在 iOS 保活也是这么搞来着,就 cat 下/dev/location )
|
41
anjingdexiaocai 34 天前 via Android
android 的话,只有前台服务可以解决,至于电池优化,自启动开启,这些用户不一定买账。
|
42
gaobh 34 天前
不能用电脑吗哈哈,右下角最小化挂个程序就行了
|
43
AkaGhost 34 天前
这个让我想起了 WakeUp 课程表有个上课提醒功能,简单设置一下提醒就满准确的,就是会请求一个 "闹钟和提醒" 的权限。
权限描述如下: 允许设置闹钟和提醒 允许该应用设置闹钟以及安排在特定时间执行某些操作。此权限开启后,该应用将在后台运行,可能会消耗更多电量。 若关闭此权限,该应用设置的现有闹钟将不会响起,安排在特定时间执行的现有活动也不会执行。 |
44
champaulmmc 34 天前
安卓很简单,后台权限全开,后台一直播放无声背景音乐就行,会一直保活。IOS 费劲,需要一直定位或者看快捷指令,检测到网络就执行 APP 步骤,IOS17 可以默认执行不需要权限
|
45
jingrui 33 天前
Expo BackgroundFetch
试试这个吧 |
46
skyyan 33 天前
你先解决保活问题再说吧
|
47
hstdt 33 天前 via iPhone
参考长途货运 app 的司机端实现方案,iOS 用 location manager 触发上传
|
48
auhah 33 天前
android 吗?直接发送前台通知不就保活了么
|
49
HangoX 33 天前
@champaulmmc iOS 不是也可以放歌吗?放歌可以后台
|
50
HangoX 33 天前
@Jed2020 https://firebase.google.com/docs/database?hl=zh-cn firebase 的 realtime database ,自己会处理同步事件,因为被谷歌收购了,有 google play 的手机会非常容易处理同步的事情,同步会由 gp service 执行
|
51
meteora0tkvo 33 天前
可以参考流氓软件的做法,申请一个浮窗,颜色透明,大小为 1 像素
|
52
realpg 33 天前
既然是必备服务,那么直接发送失败出个浮窗提示失败等待网络恢复就好了,也不用透明,毕竟这是工作用的,有浮窗很正常吧
|