现如今,大量App借助SDK实现特定功能,提供便捷服务,满足用户多样需要,但APP使用SDK也可能带来相关安全问题,包括SDK自身安全漏洞、SDK恶意行为、SDK收集使用个人信息三类。
其中,SDK恶意行为是指嵌入APP中的SDK自身产生的恶意行为。这种恶意行为将破坏使用SDK的APP的安全性,对用户权益、数据等方面造成严重威胁。典型的恶意行为如流量劫持、资费消耗、隐私窃取等。
常见SDK恶意行为
流量劫持指SDK信息拉取、上报和展示目标App提供者设定的目标不同,恶意劫持App流量,可能对App造成损害;隐私窃取指SDK在用户不知情或误导用户的情况下,隐蔽窃取用户的通讯录、短信息等个人敏感信息,隐蔽进行拍照、录音等敏感行为,并发送给恶意开发者;广告刷量指SDK在最终用户不知情的情况下,在后台模拟人工点击广告链接进行牟利。
在SDK收集使用个人信息方面,安天移动安全发现,应用接入第三方SDK引发的违规收集个人信息问题较为普遍。其中,包括用户同意隐私政策前就开始收集个人信息、隐私政策中未明确提及所接入的SDK和数据收集情况、SDK收集的个人信息范围与隐私政策不相符等。
除了上述 SDK恶意行为外,当前 App 接入的 SDK 中还存在以上风险行为类型
在对某统计类SDK检测分析时研究发现,其主要提供用户行为统计功能,并在此过程中实现用户终端数据的收集和上传。
由于该SDK 在不同App中存在模块代码和版本的不同,因此对其在不同月活范围 App 中的数据收集行为进行抽样分析,从结果上来看,该SDK 普遍存在违规收集和超范围收集个人信息的问题,并且在月活较低的 App 接入的版本中,还存在通过云控参数控制 SDK 在终端侧收集数据范围的情况,并且涉及大量用户隐私路径数据的访问。
以某知名地图 App为例,在相关检测中发现,在隐私政策中明确提到了应用内第三方 SDK所收集的个人信息类型为设备信息和 Wi-Fi 地址。而实际上传的数据中除了包含 WiFi 的BSSID名称信息外,还频繁上传用户安装应用的列表信息。
国家标准计划《信息安全技术 移动互联网应用程序(App)收集个人信息基本要求》中明确定义了不同业务场景下,应用收集个人信息范围的最小化原则。而在应用接入的 SDK 中,收集个人信息范围、频度的必要性和最小化原则同样适用于SDK的功能业务场景。
虽然部分应用接入 SDK 时明示了 SDK 所收集的个人信息范围,但其合理性和必要性存疑,例如收集个人信息范围为软件安装列表,但实际除了收集安装应用包名信息外,还收集了安装应用运行状态信息等,这就涉及超范围收集个人信息。
例如,某统计类 SDK除了应用开发者本身主动调用相关事件接口外,SDK自身还注册监听了多种广播消息,在监听到相关消息后则会触发数据的收集和上传行为。例如对解锁屏、电源连接断开事件进行监听、对用户终端安装、卸载应用行为进行监听,除此以外,还会监听应用前台、后台的切换行为从而触发数据的收集和上传。
另外,当前 App 接入的 SDK 中还存在云端控制SDK行为,热更新技术控制 SDK 行为,后台拉活、自动下载安装、误触下载等风险行为。
(监制:张宁 策划:李政葳 制作:黎梦竹)
第24届哈尔滨冰雪大世界:-30℃松花江面上开始采冰******
中新网哈尔滨12月7日电 (记者 王琳)“大雪日,挂红灯,松花江上采头冰。”7日是中国二十四节气大雪,第24届哈尔滨冰雪大世界的采冰工作全面展开,数百名采冰工人和上百辆运冰车在-30℃的松花江面上忙碌作业。
采冰人将冰块拖出江面 哈尔滨冰雪大世界供图哈尔滨位于高寒地区,拥有“冰城”美誉,采冰造景的习俗传承百年。随着气温不断下降,松花江哈尔滨段的冰层加厚,接连降雪为江面盖上了厚厚的“棉被”,采冰汉子喊着号子“出征”了。
为保证哈尔滨冰雪大世界足够的优质冰源供给,每天有数百名采冰人和上百辆运冰车参与到采冰工作中。12月份的松花江江面温度接近-30℃,冒着严寒的采冰人却热情不减。
采冰人在封冻的江面上划线 哈尔滨冰雪大世界供图采冰现场,采冰人先将冰层上的积雪、杂冰等清理干净,随后用冰锯进行划线切割,然后按照标准尺寸用“冰镩子”开冰,最后将一块块晶莹剔透的冰块缓缓拉出水面,按照固定规格切割装车,驾驶运冰车、叉车、铲车,将冰块源源不断运往验冰场。
工人将冰块装载上运冰车 哈尔滨冰雪大世界供图作为世界知名冰雪景观,哈尔滨冰雪大世界对景观建设的用冰要求极高,坚持在松花江水流最缓、水质最清、冰层透明度最高的江段采冰。从采冰、运冰、验冰到施工各个环节都需严格把控,只有洁净结实、透明度高、厚度适中的优质冰块,才能用于景观建设。
运冰车前往验冰场 哈尔滨冰雪大世界供图据悉,第24届哈尔滨冰雪大世界园区面积81万平方米,用冰量10万立方米,用雪量5万立方米,将为游客打造美轮美奂、异彩纷呈的冰雪欢乐世界。(完)
(文图:赵筱尘 巫邓炎) [责编:天天中] 阅读剩余全文() |