安卓Framework wms/ams实战作业布置-千里马学框架

背景:

近来有学员朋友询问了一个现象,具体描述看如下截图:
在这里插入图片描述

简单总结一下他的疑问点:

1、在桌面最近任务里面杀死一个应用,这个应用的在层级结构树的Task,ActivityRecord,WindowState都会被移除

2、如果当前应用在后台(注意一定要在后台,不能在前台),使用adb shell 命令进行kill进程发现只有应用的WindowState在结构树被移除,其他的ActivityRecord,Task就没有被移除。

哈哈,确实平时没注意这个现象,看到他描述的这个结果有点意外,主要不影响上面运行,属于安卓自己设计机制,所以与我们想象的一旦进程都被杀了,那么层级结构树肯定不可以残留相关的Task和ActivityRecord。

实际aosp验证该现象:

正常情况下

在这里插入图片描述

在这里插入图片描述
可以看到层级结构树有短信和短信Task = 968

多任务中移除短信或者直接前台kill:

多任务上划移动删除
在这里插入图片描述
移除后看看层级结构树树:
在这里插入图片描述看到了只剩下桌面的task和ActivityRecord

短信退到后台kill:
test@test:~/disk2/aosp14$ adb shell ps -A |grep mess
u0_a95        2521   285   13884820 159132 do_epoll_wait       0 S com.android.messaging
test@test:~/disk2/aosp14$ adb shell kill 2521
test@test:~/disk2/aosp14$ adb shell ps -A |grep mess

操作kill com.android.messaging进程后再看看层级结构树:
在这里插入图片描述
这里可以看到还有短信的Task和ActivityRecord,但是没有了对应的WindowState

作业布置:

作业目标:
1、多任务移除进程和进程后台直接命令kill移除各自是怎么触发的移除操作,请各自通过堆栈打印分析出差别

2、进程前台移除和进程后台移除有啥区别,同样通过堆栈展示差别
作业要求产物:
请给出详细的流程图,和相关的堆栈日志

上面两个点就是给大家学员朋友们的实战作业,属于一类实战检验自己对代码差异的分析能力,自己堆栈打印分析能力的锻炼,希望广大学员积极交作业,作业完成好的有奖励哈

本文章更多详细代码和资料需要购买课程获取
hal+perfetto+surfaceflinger
https://mp.weixin.qq.com/s/LbVLnu1udqExHVKxd74ILg
在这里插入图片描述

获取优惠下面公众号

其他课程七件套专题:在这里插入图片描述
点击这里
https://mp.weixin.qq.com/s/Qv8zjgQ0CkalKmvi8tMGaw

视频试看:
https://www.bilibili.com/video/BV1wc41117L4/

### 解决Spring Boot API 401 Unauthorized 认证失败 当遇到`/api/wms/receiptOrder/add-or-update`接口返回401未授权错误时,通常意味着客户端未能提供有效的身份验证凭证或权限不足。为了排查并解决问题,可以从以下几个方面入手: #### 配置安全设置 确保应用程序的安全配置正确无误。如果使用的是基于角色的访问控制(RBAC),则需确认当前用户具有执行此操作所需的适当角色。 对于Spring Security,默认情况下会保护所有端点,并要求通过HTTP Basic Auth或其他方式验证每个传入请求的身份。可以通过自定义SecurityConfig类来调整这些默认行为[^1]。 ```java @EnableWebSecurity public class SecurityConfig extends WebSecurityConfigurerAdapter { @Override protected void configure(HttpSecurity http) throws Exception { http.csrf().disable() .authorizeRequests() .antMatchers("/api/**").authenticated() // 确保API路径受保护 .anyRequest().permitAll(); // 添加其他必要的配置... } } ``` #### 检查认证头 发送到服务器的每一个RESTful调用都应携带正确的认证信息。这通常是通过在HTTP头部中加入Authorization字段完成的。例如,在Postman工具里测试API时,应该指定Bearer Token作为认证机制的一部分[^2]。 ```bash curl -X POST https://example.com/api/wms/receiptOrder/add-or-update \ -H "Content-Type: application/json" \ -H "Authorization: Bearer YOUR_ACCESS_TOKEN_HERE" \ -d '{"key":"value"}' ``` #### 日志记录与调试 启用详细的日志可以帮助诊断具体原因。可以在application.properties文件中增加如下属性以便获取更多关于认证过程的信息[^3]: ```properties logging.level.org.springframework.security=DEBUG ``` 这样可以查看完整的握手流程以及任何潜在异常堆栈跟踪,从而更容易定位问题所在。 #### 测试Token有效性 最后一步是验证所使用的OAuth令牌是否仍然有效且尚未过期。尝试刷新token或者重新登录以获得新的access token后再试一次请求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值