首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

意图Intent

通常这是通过查看意图其他信息(操作,数据/类型和类别)并将其与可以处理它组件匹配来确定。如果设置了该属性,则不执行评估,并且完全按照原样使用该组件。...通过指定这个属性,所有其他意图属性变成可选额外-这是Bundle任何额外信息。这可以用来向组件提供扩展信息。...例如,如果我们一个发送电子邮件动作,我们也可以在这里包含额外数据以提供主题,主体等。...串 EXTRA_INITIAL_INTENTS 一个Parcelable [] Intent或者一些 LabeledIntent对象putExtra(String, Parcelable[]),当用户使用...串 EXTRA_REPLACING ACTION_PACKAGE_REMOVED 意图中用作布尔额外字段以表示这是对包替换,所以这个广播将立即跟随相同包不同版本添加广播。

92310

Android Activity间传值选择,Serializable Or Parcelable

,存储代价小很多,因为Serializable需要保存很多额外字段来保证反序列化能够成功。    ...接收对象也很简单 ? 我们再来使用Parcelable接口来传递,先定义一个类ParcelableGood ? 发送数据也很简单 ? 接收也同样类似 ?...最后我们来做一个总结,上面已经介绍了Android开发中Serializable和Parcelable用法,我们推荐使用Parcelable,理由大致有3个:1.Parcelable是Android...3.最后一个原因也是最重要原因,Parcelable要序列化哪些字段,我们完全可以控制,而且还可以在其中加入各种转换,修饰,因为写接口暴露给我们了,我们可以自由定制,而Serializable就显比较笨拙...,而且需要一些额外字节来存储类信息,当然Serializable使用起来要更简单。

1.2K30
您找到你想要的搜索结果了吗?
是的
没有找到

Android deeplink漏洞

DeepLink漏洞 0x00 DeepLink简介 Deep link是一种处理特定类型链接并直接发送到应用程序(例如特定活动)机制。...通过以下位置托管数字资产链接JSON 文件来声明网站和意图过滤器之间关系:https://domain.name/.well-known/assetlinks.json 如果系统成功验证允许应用程序打开某个...JSON 对象、字符串或字节数组来处理深度链接,这些对象、字符串或字节数组可以扩展 Serialized 和 Parcelable 对象并允许设置不安全标志。...如果这些操作不需要用户额外确认,则可以执行类似 CSRF 攻击。 例如,如果应用程序允许经过身份验证用户通过myapp://user?...email=深层链接更改其电子邮件,您可以通过让受害者访问以下页面来将受害者电子邮件更改为您自己电子邮件: <!

49140

Parcelable与Serializable

省略 } Value 写入过程,系统自己定义了一套类型映射关系,每个 Value 写入都会额外附加 4 个字节类型信息。...Parcelable 只是一个序列化规则,它向开发人员暴露 Parcel 操作对象,自行写入要序列化数据。...读取 key,紧接着 readValue 方法读取对应 value: 前面分析**序列化过程写入 value 数据时,先写入该 value 数据对应 int 类型,该类型反序列化时会用到,此时系统就是根据该...一般来说,如果需要持久化存储的话,一般还是不得不选择性能更差 Serializable 方案 虽然 Parcelable 默认不支持持久化存储,但是我们也可以通过一些取巧方式实现, Parcel.java...中 marshall 接口获取 byte 数组,然后存储文件中从而实现 Parcelable 永久存储。

1.2K20

Android 进阶6:两种序列化方式 Serializable 和 Parcelable

序列化期间,对象将其当前状态写入到临时或持久性存储区。以后,可以通过从存储区中读取或反序列化对象状态,重新创建该对象。...二进制序列化保持类型保真度,这对于应用程序不同调用之间保留对象状态很有用。例如,通过将对象序列化到剪贴板,可在不同应用程序之间共享对象。您可以将对象序列化到流、磁盘、内存和网络等等。...也就是说,一个类序列化时,运行时会保存它版本号,然后反序列化时检查你要反序列化成对象版本号是否一致,不一致的话就会报错:·InvalidClassException。...接口 Parcelable 是 Android 特有的序列化接口: public interface Parcelable { //writeToParcel() 方法中参数,用于标识当前对象作为返回值返回...T createFromParcel(Parcel source, ClassLoader loader); } } 实现了 Parcelable 接口序列化和反序列化时会被转换为 Parcel

1.4K50

挖洞经验 | Google Play Core Library中代码执行漏洞

在后续分析中,Oversecured专家编写漏洞利用代码成功Google Chrome APP应用中实现了文件替换和代码执行。...基于此隐患,攻击者可以创建一个实现类,如在Parcelable接口中包含进恶意代码,然后把其实例发送到存在漏洞APP应用去,这样的话,利用createFromParcel方法反序列化操作即可实现本地代码执行...APP应用后,由于未受保护消息接收器receiverGoogle Play Core library中进行了注册,3秒后,消息接收器receiver便接收到了加载已序列化对象类ClassResolver...测试指令,5秒后,攻击者通过发送对象EvilParcelable,实现了反序列化过程代码执行。...安卓应用中,当某个组件接收到一个意图指令状态后,其所有附加对象都会被执行反序列化,如Intent.hasExtra(name)方法。

1.5K20

Android编程实现全局获取Context及使用Intent传递对象方法详解

分享给大家供大家参考,具体如下: 一、全局获取 Context Android 开发中很多地方需要用到 Context,比如弹出 Toast、启动活动、发送广播、操作数据库…… 由于很多操作都是活动中进行...Parcelable方式: Parcelable 方式实现原理是将一个完整对象进行分解,而分解后每一部分都是 Intent 所支持数据类型,这样也就实现传递对象功能了。...对象进行返回,其中 name和age都是调用 Parcel readXxx()方法读取到,注意这里读取顺序一定要和写出顺序完全相同。...对象,只不过获取对象时调用是 getParcelableExtra() 方法,其他地方完全相同。...传递对象时,Serializable 和 Parcelable 方法都是可行,对比一下,Serializable 方式较为简单,但由于会把整个对象进行序列化,因此效率方面会比 Parcelable

1.9K30

已中招!Android 基础面试常常吊死在这几个问题上……

Activity 生命周期中,无论是应用程序启动时,还是Activity 被销毁然后重新创建(例如在配置更改期间)时,都会调用一次 onCreate() 方法。...它不会创建新实例,而是将意图发送给 Activity 现有实例。...SingleTask:始终将创建一个新任务,并将新实例作为根实例推送到该任务。因此,如果 Activity 已经在任务中,则该意图将被重定向到onNewIntent( ) ,否则将创建一个新实例。...应聘者:我没有太深入了解… 面试官:序列化是将对象转换为字节流以便将对象存储到内存中过程,以便可以以后时间重新创建它,同时仍保留对象原始状态和数据。...但是,当开始滚动并需要开始显示下一个视图时会发生什么?同样,一种简单方法是为需要显示每个新行创建一个新视图。

2K20

Android序列化之Parcelable和Serializable使用详解

随后对对象进行反序列化时,将创建出与原对象完全相同副本。...实现序列化必要条件 一个对象要实现序列化操作,该类就必须实现了Serializable接口或者Parcelable接口,其中Serializable接口是java中序列化抽象类,而Parcelable...接口则是android中特有的序列化接口,某些情况下,Parcelable接口实现序列化更为高效,关于它们实现案例我们后续会分析,这里只要清楚知道实现序列化操作时必须实现Serializable接口或者...Parcelable和Serializable是两个接口,它们作用是让实现了其中一个接口对象能够被序列化和反序列化。...序列化时会将这个值写入存储介质,反序列化时就校验本地类serialVersionUID和序列化介质中是否一致,不一致将抛出异常 java.io.InvalidClassException (1)若不指定

1.5K10

Android点将台:外交官

零、前言 1.本文知识点 [1].Intent简介及[隐式调用]和[显示调用] [2].对象序列化与反序列化:[Parcelable(简)]和`Serializable] [3]....只能在Android中使用 P以Ibinder作为信息载体,在内存上开销比较小,P性能方面要强于S S序列化操作时候会产生大量临时变量,(反射机制)从而导致GC频繁调用 |---Parcelable...性能要强于Serializable 在读写数据时候,Parcelable是在内存中直接进行读写 而Serializable是通过使用IO流形式将数据读写入硬盘上 Parcelable无法将数据进行持久化...(磁盘存储),Serializable可以 (不同Android版本当中,Parcelable可能会不) 五、Intent数据传递 Intent 除来一大堆对属性set之外,还有一大堆putExtra...1.解析流程 PackageManagerService启动后会扫描系统和第三方app信息, scanPackageLI方法中实例化PackageParser对象pp,使用pp对包进行解析 PackageParser

12510

Android开发几个插件和工具,提升你开发效率

以上这些问题是每个Android开发都会遇到“难处”,因为这些代码没有任何“难度”,是重复工作,而且比较容易出错。我写这篇博客意图就是分享我自己开发中使用工具和插件,解决以上“痛点”。...如果Json字符串符合规范,点OK之后会将对象字段类型和名字展示,可以修改类型和名字。 ? 继续点确定完成 这个插件还会将Get Set方法一并生成,可以说是非常方便了。 ?...1.3、Android Parcelable code generator Android中,序列化方式有两种,Parccelable和Serializable。...如果有了Android Parcelable code generator这个插件,繁琐Parcelable实现也会变得简单。...调试接口时将所有的参数传入,并可模拟各种类型请求,包括常用Post和Get。 ? Postman也可以作为Chrome插件使用。而且远远不止接口调试这些功能!

92090

Android 反序列化漏洞攻防史话

,回顾一下是 writeAligned 方法中,直接通过 memcpy 去写入数据,因此对于基础数字类型是没有额外开销,且序列化字节序就是当前机器字节序。...,如 mObjects 字段,作为内核参数记录。...Binder Android IPC 中一个重要参数类型就是回调,即客户端发送一个 IBinder 类型对象给服务端,然后服务端可以调用其 onTransact 方法实现反向异步数据传输。...the Better - Introducing Android's Safer Parcel 通过精心构造发送给 B 数据,我们可以令 B 和 C 都能正常序列化出 Bundle 对象,甚至让这两个...) 并不可行,因为 Intent 中 Bundle 会作为一个整体进行拷贝,因此 Bundle 中反序列化错误并不会影响 Intent 本身。

1.7K50

Android 最全 Intent 传递数据姿势

点击上面蓝色字体关注“IT大飞说” 置顶公众号(**ID:ITBigFly**)第一时间收到推送 作为一个 Android 开发人员,我们都是用过 Intent,用它来组件之间传递数据...1.传递序列化对象 1.1 方式一 这种方式比较简单,我们可以先将对象使用 Gson 先序列化成 Json 字符串,然后作为字符串来使用 Intent,这种方式好处是不需要实现 Sereriable...或者 Paracelable,坏处就是需要额外使用 Gson 来序列化和解析。...Serializable 和 Parcelable 接口区别: 使用内存时候,Parcelable 比 Serializable 性能高,所以推荐使用 Parcelable; Serializable...序列化时候会产生大量临时变量,从而引起频繁 GC; Parcelable 不能使用在要将数据存储磁盘上情况,因为 Parcelable 不能很好保证数据 持续性,在外界有变化情况下,

2.6K21

Java IO之对象序列化、ObjectInputStream和ObjectOutputStream类

PushbackInputStream     PushbackReader     特殊流  DataInputStream  DataOutputStream          Java是一种完全面向对象高级语言...我们有时会需要将内存中整个对象都写入到文件中去,然后适当时候再从文件中将对象还原至内存。...序列化期间,对象将其当前状态写入到临时或持久性存储区。以后,可以通过从存储区中读取或反序列化对象状态,重新创建该对象。   ...序列化目的:    1)永久保存对象,保存对象字节序列到本地文件中;    2)通过序列化对象在网络中传递对象;    3)通过序列化对象进程间传递对象。   ...接口序列化对象步骤:    1、实现Parcelable接口。

98030

Android中传值Intent与Bundle区别小结

而使用Bundle的话,B页面可以直接取出传输Bundle对象然后传输给C页面。...intent = getIntent(); bundle=intent.getBundleExtra("bundle"); 然后B页面中发送数据: Intent intent=new Intent...(BActivity.this,CActivity.class); //可以传给CActivity额外值 bundle.putBoolean("boolean",true); intent.putExtra...Bundle内部是由ArrayMap实现,ArrayMap内部实现是两个数组,一个int数组是存储对象数据对应下标,一个对象数组保存key和value,内部使用二分法对key进行排序,所以添加、删除...另外一个原因,则是Android中如果使用Intent来携带数据的话,需要数据是基本类型或者是可序列化类型,HashMap使用Serializable进行序列化,而Bundle则是使用Parcelable

1.5K20

Binder 进程通信

从Android进程架构角度分析:对于消息队列、Socket和管道来说,数据先从发送缓存区拷贝到内核开辟缓存区中,再从内核缓存区拷贝到接收方缓存区,一共两次拷贝,而对于Binder来说,数据从发送缓存区拷贝到内核缓存区...安全性高:传统Linux IPC接收方无法获得对方进程可靠UID/PID,从而无法鉴别对方身份;而Binder机制为每个进程分配了UID/PID且Binder通信时会根据UID/PID进行有效性检测...其他 AIDL 生成接口 实现 Parcelable 实体 AIDL 如何编写 AIDL 编写主要为以下三部分: 创建 AIDL 创建要操作实体类,实现 Parcelable 接口,以便序列化...Binder 对象实例,实现接口定义方法 onBind() 中返回 客户端 实现 ServiceConnection 接口,在其中拿到 AIDL 类 bindService() 调用 AIDL...AIDL接口类型,如果客户端与服务端同一个进程,返回就是服务端Stub对象本身,否则返回是系统             // 封装后Stub.proxy对象             iBookManager

82020

Art of Android Development Reading Notes 5

文件中声明小部件 下面的示例中包含了两个action,第一个action用于识别小部件单击行为,而第二个action是作为小部件必须存在action android.appwidget.action.APPWIDGET_UPDATE...(7)PendingIntent支持三种待定意图:启动Activity(getActivity),启动Service(getService),发送广播(getBroadcast)。...第二个参数requestCode是PendingIntent发送请求码,多数情况下设为0即可,另外requestCode会影响到flags效果。...PendingIntent会被更新,最终它们和最新一条通知保持完全一致,包括其中Extras,并且这些通知都是可以打开。...(6)系统将view操作封装成Action对象,Action同样实现了Parcelable接口,通过Binder传递到SystemServer进程。

52930

我也想聊聊Binder机制

Android开发中,将对象序列化到设备或者序列化后通过网络传输建议使用Serializable接口,其他情况建议是用Parcelable接口,尤其在内存序列化上。...自定义Parcelable对象和AIDL接口必须显示导入到AIDL文件中。...数据走向 Parcelable对象和AIDL接口使用前必须标明数据走向: in 客户端流向服务端 out 服务端流向客户端 inout 服务端与客户端可进行交互 示例: 1void addUser...(inout User user); 3.2 服务端实现 定义数据对象 定义一个实现了Parcelable 接口,作为客户端和服务端传输数据对象。...将字符串名字和Service对象作为参数传到BpServiceManger对象addService()函数,该方法将参数数据打包后传递给BpBidnertransact()函数。

77620

Carson带你学Android:这是一份全面 & 详细Intent组件学习指南

前言 IntentAndroid开发应用非常常见 今天我就带给大家简单讲一下Intent相关知识 & 其用法 目录 1. 定义 意图,描述是应用动作 & 其对应数据 2....使用1:指定当前组件要完成动作 该使用 分为显式 & 隐式意图: 3.1 显式意图 特点 明确指定需启动组件名 即 显式Intent不需 解析Intent 则可直接启动目标组件 具体使用 明确指定组件名方式...通过Activity类startActivity()执行该意图操作(接收一个Intent对象) // 将构建好Intent对象传入该方法就可启动目标Activity startActivity...Serializable对象Parcelable及其对应数组、CharSequence 类型 d. ArrayList,泛型参数类型为:、、、 4.3 具体使用 在当前Activity把要传递数据暂存在Intent中、新启动Activity中取出Intent

44120
领券