Android——全局获取Context的技巧

本篇博客是学习《第一行代码》后做的笔记,希望大家多多支持!

目录

前言

使用方法:

原理:

使用范例:


前言

在开发程序的过程中总会需要获取当前活动的Context,而每次调用的时候传入Context又比较麻烦,那有什么简单的办法呢?这就是我们接下来要讲解的

使用方法:

1.首先创建一个MyApplication****类:

public class MyApplication extends Application {

    private static Context context;

    @Override
    public void onCreate() {
        super.onCreate();
        context = getApplicationContext();
    }
    /**
    *重写了父类的onCreate() 方法,并通过调用getApplicationContext() 方法得到了一个应用程序级别的                        
    *Context,然后又提供了一个静态的getContext() 方法,在这里将刚才获取到的Context进行返回。
    **/
    public static Context getContext() {
        return context;
    }

}

2.在AndroidMainfest.xml中进行指定,告知系统在程序刚开始的时候就初始化MyApplication

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.example.networktest"
    android:versionCode="1"
    android:versionName="1.0" >
    ...
    <application
        android:name="com.example.networktest.MyApplication"
        ...>
        ...
    </application>
</manifest>
原理:

Android提供了一个Application类,每当应用程序启动的时候,系统就会自动将这个类进行初始化。而我们可以定制一个自己的Application 类,以便于管理程序内一些全局的状态信息,比如说全局Context

使用范例:

1.创建一个工具类,在工具类中调用MyApplication.getContext()

public class ToastTool {
    public Context context;
    public static void makeToast(String message){
        Toast.makeText(MyApplication.getContext(),message,Toast.LENGTH_SHORT).show();
    }
}

2.之后在活动之直接调用以下语句就可以:

ToastTool.makeToast("不错嘛");

3.结果:

**注意:**之前在学习LitePal的时候也是指定为android:name="com.example.networktest.LitePalApplication ",那要怎么避免这两者冲突呢?

其实很简单,只要在我们自己的Application中去调用LitePal的初始化方法就可以了

public class MyApplication extends Application {

private static Context context;

@Override
public void onCreate() {
context = getApplicationContext();
LitePal.initialize(context);
}

public static Context getContext() {
return context;
}

}

本篇博客就到这里结束啦,以后也要继续努力!加油!

题外话

黑客&网络安全如何学习

今天只要你给我的文章点赞,我私藏的网安学习资料一样免费共享给你们,来看看有哪些东西。

1.学习路线图

在这里插入图片描述

攻击和防守要学的东西也不少,具体要学的东西我都写在了上面的路线图,如果你能学完它们,你去就业和接私活完全没有问题。

2.视频教程
网上虽然也有很多的学习资源,但基本上都残缺不全的,这是我自己录的网安视频教程,上面路线图的每一个知识点,我都有配套的视频讲解。

内容涵盖了网络安全法学习、网络安全运营等保测评、渗透测试基础、漏洞详解、计算机基础知识等,都是网络安全入门必知必会的学习内容。

在这里插入图片描述

(都打包成一块的了,不能一一展开,总共300多集)

因篇幅有限,仅展示部分资料,需要点击下方链接即可前往获取

🐵这些东西我都可以免费分享给大家,需要的可以点这里自取👉:网安入门到进阶资源

3.技术文档和电子书
技术文档也是我自己整理的,包括我参加大型网安行动、CTF和挖SRC漏洞的经验和技术要点,电子书也有200多本,由于内容的敏感性,我就不一一展示了。

在这里插入图片描述

因篇幅有限,仅展示部分资料,需要点击下方链接即可前往获取

🐵这些东西我都可以免费分享给大家,需要的可以点这里自取👉:网安入门到进阶资源

4.工具包、面试题和源码
“工欲善其事必先利其器”我为大家总结出了最受欢迎的几十款款黑客工具。涉及范围主要集中在 信息收集、Android黑客工具、自动化工具、网络钓鱼等,感兴趣的同学不容错过。

还有我视频里讲的案例源码和对应的工具包,需要的话也可以拿走。

🐵这些东西我都可以免费分享给大家,需要的可以点这里自取👉:网安入门到进阶资源

最后就是我这几年整理的网安方面的面试题,如果你是要找网安方面的工作,它们绝对能帮你大忙。

这些题目都是大家在面试深信服、奇安信、腾讯或者其它大厂面试时经常遇到的,如果大家有好的题目或者好的见解欢迎分享。

参考解析:深信服官网、奇安信官网、Freebuf、csdn等

内容特点:条理清晰,含图像化表示更加易懂。

内容概要:包括 内网、操作系统、协议、渗透测试、安服、漏洞、注入、XSS、CSRF、SSRF、文件上传、文件下载、文件包含、XXE、逻辑漏洞、工具、SQLmap、NMAP、BP、MSF…

在这里插入图片描述

因篇幅有限,仅展示部分资料,需要点击下方链接即可前往获取

🐵这些东西我都可以免费分享给大家,需要的可以点这里自取👉:网安入门到进阶资源
————————————————

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。

### Android 中通过 Context 获取当前用户的 ID 或相关信息 在 Android 应用开发中,`Context` 是一个非常重要的类,它提供了全局信息的访问接口。然而,标准的 `Context` 对象本身并不直接提供用于获取当前登录用户的具体方法或属性。如果要基于 `Context` 获取与当前用户相关的 ID 或其他信息,则需依赖于更高级别的框架功能或者自定义逻辑来实现。 #### 1. 使用 `AccountManager` 结合 `Context` 可以通过 `Context` 调用系统的 `AccountManager` 来查询已配置到设备上的账户列表,并从中筛选出目标类型的账户作为当前用户的信息源[^4]: ```java AccountManager manager = AccountManager.get(context); Account[] accounts = manager.getAccountsByType("com.google"); // 替换为目标账户类型 if (accounts.length > 0) { String currentUserEmail = accounts[0].name; Log.d("CurrentUser", "User Email: " + currentUserEmail); } else { Log.w("CurrentUser", "No account found."); } ``` 此代码片段展示了如何利用 `AccountManager` 查询指定类型的首个可用账户名称(通常是电子邮件地址)。注意这需要申请相应的权限 `<uses-permission android:name="android.permission.GET_ACCOUNTS"/>` 才能正常工作。 #### 2. 借助 Firebase Authentication 或者 OAuth 登录机制 当采用第三方身份验证服务时,比如 Firebase Auth、OAuth 等,可以在成功完成认证后将返回的身份令牌解析成具体的用户详情并缓存下来。下面是一个简单的例子展示如何从 Firebase Auth 中提取 UID: ```java FirebaseAuth mAuth = FirebaseAuth.getInstance(); if (mAuth.getCurrentUser() != null){ String userId = mAuth.getCurrentUser().getUid(); Log.d("FirebaseUserId", "User ID: "+userId); }else{ Log.d("FirebaseUserId","No user signed in"); } ``` 这里假设项目集成了 Firebase SDK 并完成了初始化操作。调用 `getCurrentUser()` 方法即可得到代表当前活跃状态下的用户实例,进而取得其唯一标识符 UID[^5]。 #### 3. 定制化的 Session Management 方案 对于完全自主掌控的服务而言,可能不存在现成可复用的基础架构支持自动填充这些字段值的情况。此时就需要设计一套完整的 session management 流程,在每次启动新会话的时候都将必要的参数传递进去,并妥善保管直至结束为止。 例如可以考虑把经过加密处理后的用户编号写入 SharedPreference 文件里头: ```kotlin // 存储UserID至SharedPreferences fun saveUserIdToPreferences(context: Context, userId:String){ val prefsEditor = context.getSharedPreferences("session_prefs", MODE_PRIVATE).edit() prefsEditor.putString("user_id_key", userId) prefsEditor.apply() } // 读取UserID从SharedPreferences fun getUserIdFromPreferences(context: Context):String?{ return context.getSharedPreferences("session_prefs", MODE_PRIVATE).getString("user_id_key",null) } ``` 以上 Kotlin 函数演示了基本的操作模式——先设定再检索存储起来的数据条目。只要保证整个生命周期期间都能维持一致性的话,就能够随时随地按需取出对应的记录项来进行后续加工处理。 --- 尽管存在多种途径达成目的,但具体选用哪一种还需要综合考量应用场景的实际特点以及安全性等方面的要求。务必遵循最佳实践指导原则以保障最终成果的质量水平达到预期效果之上。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值