0

高危漏洞

6

中危漏洞

6

低危漏洞

9

警告

文件名 BBKMusic.apk
上传者 1481870389@qq.com
文件大小 34.808095932007MB
MD5 f0a0531bd311c106466313b64b44fade
包名 com.android.bbkmusic
Main Activity com.android.bbkmusic.WidgetToTrackActivity
Min SDK 21
Target SDK 28

权限列表

# 名称 说明 提示
0 android.permission.SEND_SMS 允许应用程序发送短信。恶意应用程序可能会不经您的确认就发送信息,给您带来费用。 警告
1 android.permission.ACCESS_COARSE_LOCATION 访问大概的位置源(例如蜂窝网络数据库)以确定手机的大概位置(如果可以)。恶意应用程序可借此确定您所处的大概位置。 注意
2 android.permission.ACCESS_FINE_LOCATION 访问精准的位置源,例如手机上的全球定位系统(如果有)。恶意应用程序可能会借此确定您所处的位置,并可能消耗额外的电池电量。 注意
3 android.permission.BLUETOOTH 允许应用程序查看本地蓝牙手机的配置,以及建立或接受与配对设备的连接。 注意
4 android.permission.GET_TASKS 允许应用程序检索有关当前和最近运行的任务的信息。恶意应用程序可借此发现有关其他应用程序的保密信息。 注意
5 android.permission.READ_CONTACTS 允许应用程序读取您手机上存储的所有联系人(地址)数据。恶意应用程序可借此将您的数据发送给其他人。 注意
6 android.permission.READ_PHONE_STATE 允许应用程序访问设备的手机功能。有此权限的应用程序可确定此手机的号码和序列号,是否正在通话,以及对方的号码等。 注意
7 android.permission.RECEIVE_SMS 允许应用程序接收和处理短信。恶意应用程序可借此监视您的信息,或者将信息删除而不向您显示。 注意
8 android.permission.RECORD_AUDIO 允许应用程序访问录音路径。 注意
9 android.permission.REORDER_TASKS 允许应用程序将任务移至前端和后台。恶意应用程序可借此强行进入前端,而不受您的控制。 注意
10 android.permission.SYSTEM_ALERT_WINDOW 允许应用程序显示系统警报窗口。恶意应用程序可借此掌控整个手机屏幕。 注意
11 android.permission.WRITE_SECURE_SETTINGS 允许应用程序修改系统的安全设置数据。普通应用程序不能使用此权限。 注意
12 android.permission.WRITE_SETTINGS 允许应用程序修改系统设置方面的数据。恶意应用程序可借此破坏您的系统配置。 注意
13 android.permission.WRITE_USER_DICTIONARY 允许应用程序向用户词典中写入新词。 注意
14 android.permission.ACCESS_NETWORK_STATE 允许应用程序查看所有网络的状态。 提示
15 android.permission.ACCESS_WIFI_STATE 允许应用程序查看有关WLAN状态的信息。 提示
16 android.permission.AUTHENTICATE_ACCOUNTS 允许应用程序使用AccountManager的帐户身份验证程序功能,包括创建帐户以及获取和设置其密码。 提示
17 android.permission.CHANGE_NETWORK_STATE 允许应用程序更改网络连接的状态。 提示
18 android.permission.DEVICE_POWER 允许应用程序打开或关闭手机。 提示
19 android.permission.DISABLE_KEYGUARD 允许应用程序停用键锁和任何关联的密码安全设置。例如,在手机上接听电话时停用键锁,在通话结束后重新启用键锁。 提示
20 android.permission.EXPAND_STATUS_BAR 允许应用程序展开或收拢状态栏。 提示
21 android.permission.FORCE_STOP_PACKAGES 允许应用程序强行停止其他应用程序。 提示
22 android.permission.GET_ACCOUNTS 允许应用程序获取手机已知的帐户列表。 提示
23 android.permission.INTERNAL_SYSTEM_WINDOW 允许创建专用于内部系统用户界面的窗口。普通应用程序不能使用此权限。 提示
24 android.permission.INTERNET 允许程序访问网络. 提示
25 android.permission.MANAGE_ACCOUNTS 允许应用程序执行添加、删除帐户及删除其密码之类的操作。 提示
26 android.permission.MOUNT_UNMOUNT_FILESYSTEMS 允许应用程序装载和卸载可移动存储器的文件系统。 提示
27 android.permission.READ_USER_DICTIONARY 允许应用程序读取用户在用户词典中存储的任意私有字词、名称和短语。 提示
28 android.permission.STOP_APP_SWITCHES 禁止用户切换到另一应用程序。 提示
29 android.permission.VIBRATE 允许应用程序控制振动器。 提示
30 android.permission.WAKE_LOCK 允许应用程序防止手机进入休眠状态。 提示
31 android.permission.WRITE_EXTERNAL_STORAGE 允许应用程序写入SD卡。 提示

四大组件

组件名称

com.android.bbkmusic.MusicMainActivity
com.android.bbkmusic.WidgetToTrackActivity
com.android.bbkmusic.ui.RadarRecordActivity
com.android.bbkmusic.ui.RadarHistoryActivity
com.android.bbkmusic.ui.MusicSettingActivity
com.android.bbkmusic.ui.ProductTypeActivity
com.android.bbkmusic.ui.CouponDetailActivity
com.android.bbkmusic.ui.DefaultTrialQualityActivity
com.android.bbkmusic.ui.MusicScanActivity
com.android.bbkmusic.ui.OnlineArtistDetailActivity
com.android.bbkmusic.ui.HotListDetailActivity
com.android.bbkmusic.ui.DeleteActivity
com.android.bbkmusic.ui.EditTrackInfoActivity
com.android.bbkmusic.ui.CreatePlaylistActivity
com.android.bbkmusic.ui.RenamePlaylistActivity
com.android.bbkmusic.ui.CueBrowserActivity
com.android.bbkmusic.ui.ArtistDetailActivity
com.android.bbkmusic.ui.DownloadBrowserActivity
com.android.bbkmusic.ui.PlaylistBrowserActivity
com.android.bbkmusic.ui.PlaylistDetailActivity
com.android.bbkmusic.ui.ExclusiveMusicDetailActivity
com.android.bbkmusic.ui.LyricPhotoSearchActivity
com.android.bbkmusic.ui.LocalMusicActivity
com.android.bbkmusic.ui.OnlinePlayListDetailActivity
com.android.bbkmusic.ui.OnlinePlaylistDetailInfoActivity
com.android.bbkmusic.ui.FolderDetailActivity
com.android.bbkmusic.ui.AlbumDetailActivity
com.android.bbkmusic.ui.AddSongActivity
com.android.bbkmusic.ui.FolderFiltActivity
com.android.bbkmusic.ui.SkinListActivity
com.android.bbkmusic.ui.SkinPreviewActivity
com.android.bbkmusic.ui.OnlineMusicDownLoadActivity
com.android.bbkmusic.ui.OnlineSongListEditActivity
com.android.bbkmusic.ui.OnlineSongListTagActivity
com.android.bbkmusic.ui.OnlineMvTagActivity
com.android.bbkmusic.ui.MvTopActivity
com.android.bbkmusic.ui.MvHotListActivity
com.android.bbkmusic.ui.MvChannelActivity
com.android.bbkmusic.ui.MvAllActivity
com.android.bbkmusic.ui.HiFiMusicAreaActivity
com.android.bbkmusic.ui.RadioActivity
com.android.bbkmusic.ui.OnlineSingerListActivity
com.android.bbkmusic.ui.HiFiSongListActivity
com.android.bbkmusic.ui.SongListActivity
com.android.bbkmusic.ui.HotListActivity
com.android.bbkmusic.ui.OnlineMvListActivity
com.android.bbkmusic.ui.NewSongListActivity
com.android.bbkmusic.ui.WebViewActivity
com.android.bbkmusic.ui.MusicSkinSettingActivity
com.android.bbkmusic.ui.MusicSkinPreviewActivity
com.android.bbkmusic.ui.ColorRingWebActivity
com.android.bbkmusic.ui.BlankWebViewActivity
com.android.bbkmusic.ui.MemberAgreementActivity
com.android.bbkmusic.ui.OnlineAlbumListTagActivity
com.android.bbkmusic.ui.LrcChooseActivity
com.android.bbkmusic.ui.LyricPosterComposeActivity
com.android.bbkmusic.ui.OnlineSearchActivity
com.android.bbkmusic.ui.OnlineSearchFeedbackActivity
com.android.bbkmusic.ui.LocalSearchActivity
com.android.bbkmusic.ui.EnterReceiverActivity
com.android.bbkmusic.ui.SongListAllActivity
com.android.bbkmusic.ui.MusicPicker
com.android.bbkmusic.ui.PlayActivity
com.android.bbkmusic.MediaPlaybackActivity
com.android.bbkmusic.share.wxapi.WXEntryActivity
com.android.bbkmusic.share.QQShareActivity
com.tencent.tauth.AuthActivity
com.android.bbkmusic.share.yxapi.YXEntryActivity
com.vivo.unionsdk.ui.UnionActivity
com.tencent.connect.common.AssistActivity
com.android.bbkmusic.ui.QueryBrowserActivity
com.android.bbkmusic.ui.QueryShowActivity
com.unionpay.UPPayWapActivity
com.unionpay.uppay.PayActivity
com.alipay.sdk.app.H5PayActivity
com.alipay.sdk.auth.AuthActivity
com.bbk.onlinemusic.search.Search_Activity
com.vivo.upgradelibrary.upmode.VivoUpgradeActivityDialog
com.squareup.leakcanary.internal.DisplayLeakActivity
com.android.bbkmusic.ui.EditActivity
com.android.bbkmusic.ui.PlaylistDetailEditActivity
com.android.bbkmusic.ui.DownloadEditActivity
com.android.bbkmusic.ui.SongListClassificationActivity
com.android.bbkmusic.ui.PictureDownloadActivity
com.android.bbkmusic.ui.PlaylistEditActivity
com.vivo.push.sdk.service.LinkProxyActivity
com.android.bbkmusic.ui.TimerOffActivity
com.android.bbkmusic.ui.LocalTagActivity
com.android.bbkmusic.ui.HiFiSingerActivity
com.android.bbkmusic.ui.MyFavorateActivity
com.android.bbkmusic.ui.SongListResultActivity
com.android.bbkmusic.ui.SecurityVerificationActivity
com.android.bbkmusic.ui.MusicPrivilegeIntroActivity
com.android.bbkmusic.ui.FeedbackActivity
com.android.bbkmusic.ui.SongListImport2Activity
com.android.bbkmusic.ui.MusicPriorityWebActivity
com.android.bbkmusic.ui.ExclusiveSelectionWebViewActivity
com.android.bbkmusic.ui.MvPlayActivity
com.android.bbkmusic.ui.PersonalPageActivity
com.android.bbkmusic.ui.ClipImageActivity
com.android.bbkmusic.ui.EditNameActivity
com.android.bbkmusic.ui.NewArrivalsActivity
com.android.bbkmusic.ui.AlbumDigitalActivity
com.android.bbkmusic.ui.AlbumDigitalDetailActivity
com.android.bbkmusic.ui.DailyRecommendDetailActivity
com.android.bbkmusic.ui.DailyRecommendLrcActivity
com.android.bbkmusic.ui.BoughtActicity
com.android.bbkmusic.ui.DigitalPurchaseActivity
com.android.bbkmusic.voicecontrol.VoiceShareActivity
com.sina.weibo.sdk.web.WeiboSdkWebActivity
com.sina.weibo.sdk.share.WbShareTransActivity
com.sina.weibo.sdk.share.WbShareToStoryActivity
com.android.bbkmusic.ui.ExclusiveSelectionActivity
com.android.bbkmusic.ui.AboutMusicActivity
com.android.bbkmusic.ui.AudioBookDetailActivity
com.android.bbkmusic.ui.AudioBookPaidBoutiqueActivity
com.android.bbkmusic.ui.FMActivity
com.android.bbkmusic.ui.AudioBookAllCategoryActivity
com.android.bbkmusic.ui.HotAudioBookRecommendActivity
com.android.bbkmusic.ui.MyAudioBookActivity
com.android.bbkmusic.ui.AudioBookRankingActivity
com.android.bbkmusic.ui.AudioBookChartActivity
com.android.bbkmusic.ui.AudioBookChartMoreActivity
com.android.bbkmusic.ui.AudioBookPurchaseActivity
com.android.bbkmusic.ui.AudioBookListenHistoryActivity
com.android.bbkmusic.ui.AudioBookListenHistoryEditActivity
com.vivo.adsdk.common.web.VivoADSDKWebView
com.android.bbkmusic.ui.ListenAlbumActivity
com.android.bbkmusic.ui.GuideFullscreenActivity
com.android.bbkmusic.ui.AudioBookAlbumDetailActivity
com.android.bbkmusic.ui.AudioLocalDownloadedEditActivity
com.android.bbkmusic.ui.OnlineEpisodeDownloadActivity
com.android.bbkmusic.ui.ChinaStyleActivity
com.android.bbkmusic.ui.ChinaStyleDetailActivity
com.android.bbkmusic.ui.KidsZoneActivity
com.android.bbkmusic.ui.KidsZoneAlbumListActivity
com.android.bbkmusic.ui.GiftGetFullScreenActivity
com.android.bbkmusic.ui.DJAreaActivity
com.android.bbkmusic.ui.DJAreaDetailActivity
com.android.bbkmusic.ui.PushMessageCenterActivity
com.android.bbkmusic.ui.NewCommerListenDetailActivity
com.android.bbkmusic.ui.configurableview.discountaudio.DiscountAudioActivity
com.android.bbkmusic.ui.RingMakerActivity
fm.qingting.qtsdk.auth.QTAuthActivity
fm.qingting.qtsdk.pay.QTPayActivity
com.bbk.account.oauth.activity.AuthorizeActivity

com.android.bbkmusic.service.MusicService
com.vivo.aivoice.sdk.AiVoiceCommandService
com.android.bbkmusic.mirror.MirrorMusicUrlService
com.android.bbkmusic.MediaPlaybackService
com.bbk.onlinemusic.OnLineMusicPlaybackService
com.squareup.leakcanary.internal.HeapAnalyzerService
com.squareup.leakcanary.DisplayLeakService
com.android.bbkmusic.thread.playlistsync.PlaylistUploadService
com.android.bbkmusic.thread.playlistsync.PlaylistDownloadService
com.vivo.push.core.android.service.MqttService
com.vivo.push.sdk.service.PushService
com.vivo.push.sdk.service.CommandService
fm.qingting.qtsdk.player.QTPlayerService

com.android.bbkmusic.receiver.MediaButtonIntentReceiver
com.android.bbkmusic.receiver.SleepModeReceiver
com.android.bbkmusic.receiver.OutStartMusicReceiver
com.android.bbkmusic.receiver.PushMessageReceiver
com.vivo.push.sdk.service.RegistrationReceiver

com.android.bbkmusic.provider.MusicProvider
com.vivo.upgradelibrary.utils.FileProvider
android.support.v4.content.FileProvider
fm.qingting.log.LogProvider

第三方库

# 库名 介绍
0 com.google.gson A Java serialization library that can convert Java Objects into JSON and back.
1 com.tencent.mm.sdk 微信支付
2 com.unionpay.uppay 银联支付
3 com.alipay.sdk 支付宝移动支付功能
4 org.apache.http The Apache HttpComponents™ project is responsible for creating and maintaining a toolset of low level Java components focused on HTTP and associated protocols.
5 com.unionpay.mobile 银联支付涵盖便民服务、金融服务、商旅出行、休闲娱乐、电子商城等多种应用。可轻松为手机充值、购买保险、查询银行卡余额、预订酒店机票、代购火车票和购买时令商品。随时随地提供“一站式”移动支付生活服务。

静态扫描发现风险点

风险等级 风险名称

中危

检测到1处证书弱校验漏洞。

位置: assets/music_card.apk
com.vivo.cardapk.model.MyX509TrustManager;

当移动App客户端使用https或ssl/tls进行通信时,如果不校验证书的可信性,将存在中间人攻击漏洞,可导致信息泄露,传输数据被篡改,甚至通过中间人劫持将原有信息替换成恶意链接或恶意代码程序,以达到远程控制等攻击意图。建议:
对SSL证书进行强校验,包括签名CA是否合法、证书是否是自签名、主机域名是否匹配、证书是否过期等。

参考案例:
www.wooyun.org/bugs/wooyun-2014-079358

参考资料:
http://drops.wooyun.org/tips/3296
http://wolfeye.baidu.com/blog/webview-ignore-ssl-error/
https://jaq.alibaba.com/blog.htm?id=60

中危

该app需要移除大部分日志打印代码。
经扫描该包仍存在大量打日志代码,共发现130处打日志代码.(此处扫描的日志打印代码,是指调用android.util.Log.* 打印的.)
详情如下:

位置: assets/music_card.apk
com.vivo.cardapk.utils.LogUtils;->w(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->w(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.utils.LogUtils;->i(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.musiccontrol.MusicServiceAIDL;->stopMusicService(Landroid/content/Context;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.musiccontrol.MusicService$1;->onServiceConnected(Landroid/content/ComponentName; Landroid/os/IBinder;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.utils.LogUtils;->s(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.musiccontrol.MusicServiceAIDL;->startMusicService(Landroid/content/Context;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.model.DataRequest;->doOnRequestSuccess(Ljava/lang/String; Lcom/vivo/cardapk/presenter/DetailDataRequestListener;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.utils.LogUtils;->d(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.model.DataRequest;->doOnRequestSuccess(Ljava/lang/String; Lcom/vivo/cardapk/presenter/DetailDataRequestListener;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.utils.LogUtils;->sd(Ljava/lang/String; Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.utils.LogUtils;->show(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.model.DataRequest;->doOnRequestFail(Lcom/vivo/cardapk/presenter/DetailDataRequestListener;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.utils.LogUtils;->e(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.MainActivity$17;->onClick(Landroid/view/View;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.musiccontrol.DreamMusicConfig;->()V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.musiccontrol.MusicService$1;->onServiceDisconnected(Landroid/content/ComponentName;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.utils.LogUtils;->v(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->v(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.musiccontrol.MusicService;->startMusicService(Landroid/content/Context;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.musiccontrol.MusicService;->stopMusicService(Landroid/content/Context;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.musiccontrol.MusicServiceAIDL$1;->onServiceDisconnected(Landroid/content/ComponentName;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.cardapk.musiccontrol.MusicServiceAIDL$1;->onServiceConnected(Landroid/content/ComponentName; Landroid/os/IBinder;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I

位置: assets/vivounionsdk/vivounionapk_v3.0.0_7575fa4_201711091449.vua
com.vivo.ic.fix.b.g;->a(Ljava/lang/String;)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.union.volley.ae;->驶(Ljava/lang/String; [Ljava/lang/Object;)V==>android.util.Log;->v(Ljava/lang/String; Ljava/lang/String;)I
com.token.verifysdk.VerifyCoder;->getWebView(Landroid/content/Context; Ljava/lang/String; Lcom/token/verifysdk/VerifyCoder$VerifyListener;)Landroid/webkit/WebView;==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.alipay.euler.andfix.patch.PatchManager;->deletePatch()V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.b.d;->a(Lcom/vivo/ic/fix/a/e;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.huanju.data.b.f;->示(Ljava/lang/String;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.mobile.android.pro.pboc.engine.b;->a(Landroid/os/Handler; Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.mobile.android.pboctransaction.sdapdu.a;->b(Lcom/unionpay/mobile/android/pboctransaction/d;)Ljava/util/ArrayList;==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.upgradelibrary.utils.PackageUtils;->getInstallLocation()I==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.c.d;->a(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.b.j;->a()V==>android.util.Log;->w(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.sdk.UPAgent;->setGlobalKV(Ljava/lang/String; Ljava/lang/Object;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.sdk.ay;->a(Ljava/lang/String;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.FixManager;->doRealInit(Z)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.alipay.euler.andfix.AndFixManager;->removeOptFile(Ljava/io/File;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.unionsdk.l;->示(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.tencent.mm.sdk.b.b;->f(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.security.a.b;->驶(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.unionsdk.l;->式(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->w(Ljava/lang/String; Ljava/lang/String;)I
com.union.volley.ae;->式(Ljava/lang/String; [Ljava/lang/Object;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.b.e;->a(Ljava/lang/String;)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.b.d;->a(Lcom/vivo/ic/fix/a/e;)V==>android.util.Log;->w(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.c.a;->a(Ljava/lang/String;)Lcom/vivo/ic/fix/a/a;==>android.util.Log;->w(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.upgradelibrary.utils.SystemUtils;->()V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.union.apps.widgets.MiniGrid;->驶(Landroid/view/View; I I I)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.mobile.android.pboctransaction.nfc.b$b;->a([B)Lcom/unionpay/mobile/android/pboctransaction/nfc/b$a;==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.mobile.android.utils.k;->a(I Ljava/lang/String; Ljava/lang/String;)I==>android.util.Log;->w(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.b.j;->a(Lcom/vivo/ic/fix/a/e;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.b.k;->a(Ljava/lang/String;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.FixManager;->beforeInit()V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.uppay.PayActivity;->onNewIntent(Landroid/content/Intent;)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.mobile.android.pboctransaction.nfc.a;->a(Ljava/lang/String; Ljava/util/HashMap;)Ljava/lang/String;==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.c.d;->k()V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.huanju.data.b.f;->始(Ljava/lang/String;)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.upgradelibrary.utils.SystemUtils;->getImei(Landroid/content/Context;)Ljava/lang/String;==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.upgradelibrary.utils.SystemUtils;->getImei(Landroid/content/Context;)Ljava/lang/String;==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.mobile.android.upviews.b;->handleMessage(Landroid/os/Message;)Z==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.union.volley.ae;->始(Ljava/lang/String; [Ljava/lang/Object;)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.security.a.b;->始(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.alipay.euler.andfix.AndFixManager;->checkOpt()Z==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.tencent.mm.sdk.b.b;->d(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.tencent.mm.sdk.b.b;->e(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.mobile.android.utils.k;->a(I Ljava/lang/String; Ljava/lang/String;)I==>android.util.Log;->v(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.upgradelibrary.utils.PackageUtils;->uninstallSilent(Landroid/content/Context; Ljava/lang/String; Z)I==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.upgradelibrary.utils.Device;->getDefaultDataPhoneId()Ljava/lang/String;==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.b.j;->a(Lcom/vivo/ic/fix/a/e;)V==>android.util.Log;->w(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.utils.g;->a(I Ljava/lang/String; Ljava/lang/String;)I==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.sdk.ay;->b(Ljava/lang/String;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.mobile.android.utils.k;->a(I Ljava/lang/String; Ljava/lang/String;)I==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.mobile.android.pboctransaction.simapdu.b;->a(Lcom/unionpay/mobile/android/pboctransaction/b; Landroid/content/Context;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.token.verifysdk.VerifyCoder;->getContent(Ljava/lang/String;)Ljava/lang/String;==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.upgradelibrary.utils.PackageUtils;->installSilent(Landroid/content/Context; Ljava/lang/String; Ljava/lang/String;)I==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.alipay.euler.andfix.AndFix;->initFields(Ljava/lang/Class;)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.c.a;->a(Ljava/lang/String;)Lcom/vivo/ic/fix/a/a;==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.FixManager;->addPatch(Ljava/io/File; Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->w(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.upgradelibrary.utils.SystemUtils;->()V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.mobile.android.utils.k;->a(I Ljava/lang/String; Ljava/lang/String;)I==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.mobile.android.widgets.aa;->a(Landroid/view/View;)Z==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.b.j;->a(Lcom/vivo/ic/fix/a/e;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.c.d;->b()Lcom/vivo/ic/fix/c/e;==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.c.c;->a(Ljava/lang/String;)Lcom/vivo/ic/fix/a/d;==>android.util.Log;->w(Ljava/lang/String; Ljava/lang/String;)I
com.huanju.data.b.f;->士(Ljava/lang/String;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.crashcollector.c.f;->a(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.security.a.b;->式(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->w(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.upgradelibrary.utils.ImeiHelperUtils;->getImei(Landroid/content/Context;)Ljava/lang/String;==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.union.apps.widgets.MiniGrid;->驶(Lcom/union/apps/widgets/MiniGrid$LayoutParams; I)Landroid/view/ViewGroup$LayoutParams;==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.crashcollector.c.c;->o()Ljava/lang/String;==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.crashcollector.c.f;->c(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->v(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.b.k;->a(Ljava/lang/String;)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.FixManager;->handleActionFileRecord()V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.b.d;->a()V==>android.util.Log;->w(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.utils.g;->a(I Ljava/lang/String; Ljava/lang/String;)I==>android.util.Log;->v(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.unionsdk.l;->始(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.FixManager;->doRealInit(Z)V==>android.util.Log;->w(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.sdk.c;->b()V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.alipay.euler.andfix.patch.PatchManager;->loadPatch(Ljava/lang/String;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.upgradelibrary.utils.ImeiHelperUtils;->()V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.FixManager;->loadPatch()V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.utils.g;->a(I Ljava/lang/String; Ljava/lang/String;)I==>android.util.Log;->w(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.mobile.android.pboctransaction.simapdu.b;->a(Lcom/unionpay/mobile/android/pboctransaction/d;)Ljava/util/ArrayList;==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.mobile.android.utils.k;->a(I Ljava/lang/String; Ljava/lang/String;)I==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.FixManager;->handlePrivateRecord(Z)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.upgradelibrary.utils.SystemUtils;->funtouchSDKImei(Landroid/content/Context;)Ljava/lang/String;==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.huanju.data.b.f;->式(Ljava/lang/String;)V==>android.util.Log;->w(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.unionsdk.l;->驶(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.FixManager;->init(Landroid/content/Context;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.upgradelibrary.utils.PackageUtils;->installSilent(Landroid/content/Context; Ljava/lang/String; Ljava/lang/String;)I==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.crashcollector.c.f;->e(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.a.a.y;->c(Ljava/lang/String; [Ljava/lang/Object;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.security.a.b;->示(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.crashcollector.c.f;->b(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->w(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.mobile.android.pboctransaction.samsung.h;->onTsmDisconnected()V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.FixManager;->beforeInit()V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.b.e;->a(Ljava/lang/String;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.mobile.android.pro.pboc.engine.b;->a(I)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.a.a.y;->b(Ljava/lang/String; [Ljava/lang/Object;)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.sdk.UPAgent;->removeGlobalKV(Ljava/lang/String;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.mobile.android.pboctransaction.samsung.e;->onError(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.a.a.y;->a(Ljava/lang/String; [Ljava/lang/Object;)V==>android.util.Log;->v(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.c.b;->(Ljava/lang/String;)V==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.union.apps.widgets.MiniGrid;->驶(Landroid/view/View; I I)V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.assist.web.CommandFactory;->createCommandAndExcute(Landroid/content/Context; Ljava/lang/String; Ljava/lang/String; Lcom/vivo/assist/web/BaseCommand$OnCommandExcuteCallback;)Lcom/vivo/assist/web/BaseCommand;==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.upgradelibrary.utils.ImeiHelperUtils;->()V==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.crashcollector.c.f;->d(Ljava/lang/String; Ljava/lang/String;)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.utils.g;->a(I Ljava/lang/String; Ljava/lang/String;)I==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.alipay.euler.andfix.security.SecurityChecker;->verifyApk(Ljava/io/File;)Z==>android.util.Log;->d(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.utils.g;->a(I Ljava/lang/String; Ljava/lang/String;)I==>android.util.Log;->e(Ljava/lang/String; Ljava/lang/String;)I
com.unionpay.sdk.UPAgent;->setReportUncaughtExceptions(Z)V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I
com.vivo.ic.fix.b.b;->a()V==>android.util.Log;->i(Ljava/lang/String; Ljava/lang/String;)I

中危

检测到4个WebView远程执行漏洞。

位置: assets/vivounionsdk/vivounionapk_v3.0.0_7575fa4_201711091449.vua
com.vivo.unionsdk.ui.ar;->藠()V
com.vivo.unionsdk.ui.ar;->藠()V
com.unionpay.WebViewJavascriptBridge;->(Landroid.app.Activity; Landroid.webkit.WebView; Lcom.unionpay.ab;)V
com.vivo.assist.ck;->c_()V

Android API < 17之前版本存在远程代码执行安全漏洞,该漏洞源于程序没有正确限制使用addJavaScriptInterface方法,攻击者可以通过Java反射利用该漏洞执行任意Java对象的方法,导致远程代码执行安全漏洞。
(1)API等于高于17的Android系统。出于安全考虑,为了防止Java层的函数被随意调用,Google在4.2版本之后,规定允许被调用的函数必须以@JavascriptInterface进行注解。
(2)API等于高于17的Android系统。建议不要使用addJavascriptInterface接口,以免带来不必要的安全隐患,如果一定要使用该接口,建议使用证书校验。
(3)使用removeJavascriptInterface移除Android系统内部的默认内置接口:searchBoxJavaBridge_、accessibility、accessibilityTraversal。

参考案例:
www.wooyun.org/bugs/wooyun-2015-0140708
www.wooyun.org/bugs/wooyun-2016-0188252
http://drops.wooyun.org/papers/548

参考资料:
http://jaq.alibaba.com/blog.htm?id=48
http://blog.nsfocus.net/android-webview-remote-code-execution-vulnerability-analysis
https://developer.android.com/reference/android/webkit/WebView.html

中危

检测到74条敏感明文信息,建议移除。

位置: assets/music_card.apk
'http://schemas.android.com/apk/res/android' used in: Landroid/support/v4/content/res/TypedArrayUtils;->hasAttribute(Lorg/xmlpull/v1/XmlPullParser; Ljava/lang/String;)Z
'https://music.vivo.com.cn/card/v2/detail.do' used in: Lcom/vivo/cardapk/model/DataRequest$1;->run()V

位置: assets/vivounionsdk/vivounionapk_v3.0.0_7575fa4_201711091449.vua
'10.0.0.172' used in: Lcom/huanju/data/d/l;->驶(Landroid/content/Context; Landroid/net/NetworkInfo;)V
'10.0.0.172' used in: Lcom/huanju/data/d/l;->始()V
'10.0.0.200' used in: Lcom/huanju/data/d/l;->驶(Landroid/content/Context; Landroid/net/NetworkInfo;)V
'10.0.0.200' used in: Lcom/huanju/data/d/l;->始()V
'file:///android_asset/vivounionsdk/offline.html' used in: Lcom/vivo/unionsdk/ui/ar;->始()V
'file:///android_asset/vivounionsdk/offline.html' used in: Lcom/vivo/unionsdk/ui/ax;->run()V
'file:///android_asset/vivounionsdk/offline.html' used in: Lcom/vivo/unionsdk/ui/ar;->驶(Ljava/lang/String; I)V
'http://113.98.231.125:2111/' used in: Lcom/vivo/upgradelibrary/UpgradeModleConfig;->setServerUrl()V
'http://113.98.231.125:8051/vcoin/notifyStubAction' used in: Lcom/vivo/sdkplugin/e;->onClick(Landroid/view/View;)V
'http://113.98.231.125:8051/vcoin/notifyStubAction' used in: Lcom/vivo/sdkplugin/g;->onClick(Landroid/view/View;)V
'http://140.207.168.45/g/d' used in: Lcom/unionpay/sdk/c;->()V
'http://192.168.2.233:7080/api5' used in: Lcom/vivo/upgradelibrary/UpgradeModleConfig;->setServerUrl()V
'http://192.168.2.238:2559/' used in: Lcom/vivo/upgradelibrary/UpgradeModleConfig;->setServerUrl()V
'http://192.168.2.238:2559/fixOtherApp' used in: Lcom/vivo/ic/fix/a/c;->a()V
'http://192.168.2.238:2559/fixSelfApp' used in: Lcom/vivo/ic/fix/a/c;->a()V
'http://appupgrade.vivo.com.cn/' used in: Lcom/vivo/upgradelibrary/UpgradeModleConfig;->()V
'http://appupgrade.vivo.com.cn/fixOtherApp' used in: Lcom/vivo/ic/fix/a/c;->()V
'http://appupgrade.vivo.com.cn/fixSelfApp' used in: Lcom/vivo/ic/fix/a/c;->()V
'http://comm.inner.bbk.com' used in: Lcom/vivo/unionsdk/t;->()V
'http://data.gm825.com' used in: Lcom/huanju/data/b/e;->驶()V
'http://data.gm825.com' used in: Lcom/huanju/data/b/e;->()V
'http://data.gm825.com/api/sdk/activate?' used in: Lcom/huanju/data/monitor/a/c;->驶()Ljava/lang/String;
'http://data.gm825.com/api/sdk/reportAppStartTime?' used in: Lcom/huanju/data/monitor/e/c;->驶()Ljava/lang/String;
'http://data.gm825.com/api/sdk/reportactive?' used in: Lcom/huanju/data/monitor/d/b;->驶()Ljava/lang/String;
'http://data.gm825.com/wap/' used in: Lcom/huanju/data/b/e;->()V
'http://download0.vivo.com.cn/pro/reg_pro_zh_CN.html' used in: Lcom/vivo/sdkplugin/account/ui/ej;->驶(Lcom/vivo/unionsdk/b/a;)V
'http://exappupgrade.api.vivoglobal.com/' used in: Lcom/vivo/upgradelibrary/UpgradeModleConfig;->setServerUrl()V
'http://exappupgrade.test.vivo.xyz/' used in: Lcom/vivo/upgradelibrary/UpgradeModleConfig;->setServerUrl()V
'http://f.up.vivo.com.cn' used in: Lcom/vivo/unionsdk/t;->()V
'http://floatingad.gm825.com/api/api/app_boot_report?from=%s' used in: Lcom/huanju/data/monitor/dmp/openapp/e;->驶()Ljava/lang/String;
'http://floatingad.gm825.com/api/report/applist?first_up=%d&from=%s' used in: Lcom/huanju/data/monitor/b/i;->驶()Ljava/lang/String;
'http://h5.m.taobao.com/trade/paySuccess.html?bizOrderId=$OrderId$&' used in: Lcom/alipay/sdk/data/a;->()V
'http://h5.m.taobao.com/trade/paySuccess.html?bizOrderId=$OrderId$&' used in: Lcom/alipay/sdk/data/a;->a(Ljava/lang/String;)V
'http://h5.m.taobao.com/trade/paySuccess.html?bizOrderId=$OrderId$&' used in: Lcom/alipay/sdk/data/b;->run()V
'http://h5.m.taobao.com/trade/paySuccess.html?bizOrderId=$OrderId$&' used in: Lcom/alipay/sdk/data/a;->a(Lcom/alipay/sdk/data/a; Ljava/lang/String;)V
'http://h5.m.taobao.com/trade/paySuccess.html?bizOrderId=$OrderId$&' used in: Lcom/alipay/sdk/data/a;->b(Ljava/lang/String;)V
'http://h5.m.taobao.com/trade/paySuccess.html?bizOrderId=$OrderId$&' used in: Lcom/alipay/sdk/data/a;->b()Lcom/alipay/sdk/data/a;
'http://h5.m.taobao.com/trade/paySuccess.html?bizOrderId=$OrderId$&' used in: Lcom/alipay/sdk/data/a;->d()V
'http://hf.gamecenter.vivo.com.cn' used in: Lcom/vivo/unionsdk/t;->()V
'http://m.alipay.com/?action=h5quit' used in: Lcom/alipay/sdk/util/l;->a(Landroid/webkit/WebView; Ljava/lang/String; Landroid/app/Activity;)Z
'http://mcgw.alipay.com/sdklog.do' used in: Lcom/alipay/sdk/packet/impl/c;->a(Landroid/content/Context; Ljava/lang/String;)Lcom/alipay/sdk/packet/b;
'http://mobile.unionpay.com/getclient?platform=android&type=securepayplugin' used in: Lcom/unionpay/UPPayAssistEx;->()V
'http://mobilegw-1-64.test.alipay.net/mgw.htm' used in: Lcom/alipay/apmobilesecuritysdk/b/a;->c()Ljava/lang/String;
'http://mobilegw-1-64.test.alipay.net/mgw.htm' used in: Lcom/alipay/apmobilesecuritysdk/b/a;->c()Ljava/lang/String;
'http://mobilegw.aaa.alipay.net/mgw.htm' used in: Lcom/alipay/apmobilesecuritysdk/b/a;->c()Ljava/lang/String;
'http://mobilegw.aaa.alipay.net/mgw.htm' used in: Lcom/alipay/apmobilesecuritysdk/b/a;->c()Ljava/lang/String;
'http://mobilegw.alipay.com/mgw.htm' used in: Lcom/alipay/sdk/cons/a;->()V
'http://mobilegw.stable.alipay.net/mgw.htm' used in: Lcom/alipay/apmobilesecuritysdk/b/a;->c()Ljava/lang/String;
'http://mobilegw.stable.alipay.net/mgw.htm' used in: Lcom/alipay/apmobilesecuritysdk/b/a;->c()Ljava/lang/String;
'http://ro.usdk.vivo.com.cn' used in: Lcom/vivo/unionsdk/t;->()V
'http://schemas.android.com/apk/res/android' used in: Lcom/vivo/ic/crashcollector/c/c;->a(Landroid/content/Context; Landroid/content/pm/ApplicationInfo;)Z
'http://shequ.vivo.com.cn' used in: Lcom/vivo/unionsdk/t;->()V
'http://st.appupgrade.vivo.com.cn/appSelfUpgrade?' used in: Lcom/vivo/ic/crashcollector/c/h;->a()Ljava/lang/String;
'http://st.appupgrade.vivo.com.cn/collectCrash?origin=100' used in: Lcom/vivo/ic/crashcollector/b/b;->a(Lcom/vivo/ic/crashcollector/model/CollectorInfo; Lcom/vivo/ic/crashcollector/b/e;)V
'http://st.appupgrade.vivo.com.cn/collectCrash?origin=100' used in: Lcom/vivo/ic/crashcollector/b/b;->()V
'http://st.appupgrade.vivo.com.cn/userOperationLog' used in: Lcom/vivo/upgradelibrary/network/VivoUpgradeBuriedPointHandlerThread$InnerHandler;->getBuriedUrl(Ljava/lang/Object;)Ljava/lang/String;
'http://st.eden.vivo.com.cn/contradiction' used in: Lcom/vivo/security/f;->()V
'http://sysupgrade.vivo.com.cn/api5' used in: Lcom/vivo/upgradelibrary/UpgradeModleConfig;->()V
'http://sysupgrade.vivo.com.cn/checkapp/query' used in: Lcom/vivo/upgradelibrary/UpgradeModleConfig;->()V
'http://w.usdk.vivo.com.cn' used in: Lcom/vivo/unionsdk/t;->()V
'http://xmlpull.org/v1/doc/features.html#indent-output' used in: Lcom/a/a/b/a/a;->setFeature(Ljava/lang/String; Z)V
'http://xmlpull.org/v1/doc/features.html#indent-output' used in: Lcom/a/a/b/a/i;->驶(Ljava/util/Map; Ljava/io/OutputStream;)V
'https://download0.vivo.com.cn' used in: Lcom/vivo/unionsdk/t;->()V
'https://mobilegw.alipay.com/mgw.htm' used in: Lcom/alipay/apmobilesecuritysdk/b/a;->c()Ljava/lang/String;
'https://passport.vivo.com.cn' used in: Lcom/vivo/unionsdk/t;->()V
'https://pay.vivo.com.cn' used in: Lcom/vivo/unionsdk/t;->()V
'https://usrsys.vivo.com.cn' used in: Lcom/vivo/unionsdk/t;->()V
"javascript:WebViewJavascriptBridge._handleMessageFromJava('%s');" used in: Lcom/unionpay/WebViewJavascriptBridge;->_dispatchMessage(Ljava/util/Map;)V
'javascript:changeLocalData(' used in: Lcom/huanju/data/content/raw/b/a;->驶(Landroid/webkit/WebView; Ljava/lang/String; I)V
"javascript:onAccountsUpdate('" used in: Lcom/vivo/unionsdk/ui/ar;->a_(Ljava/lang/String;)V
"javascript:syncAccountState('" used in: Lcom/vivo/unionsdk/ui/ar;->a_(Ljava/lang/String;)V
'javascript:syncInstallStatus(' used in: Lcom/vivo/unionsdk/ui/ar;->onQueryAppInstallStatus(Ljava/lang/String; Ljava/lang/String;)V

中危

检测到4处setSavePassword密码明文存储漏洞。

位置: assets/vivounionsdk/vivounionapk_v3.0.0_7575fa4_201711091449.vua
com.vivo.unionsdk.ui.ao;
com.token.verifysdk.VerifyCoder;
com.unionpay.mobile.android.upviews.b;
com.unionpay.WebViewJavascriptBridge;

webview的保存密码功能默认设置为true。Webview会明文保存网站上的密码到本地私有文件”databases/webview.db”中。对于可以被root的系统环境或者配合其他漏洞(如webview的同源绕过漏洞),攻击者可以获取到用户密码。
建议:显示设置webView.getSetting().setSavePassword(false)。

参考案例:
www.wooyun.org/bugs/wooyun-2010-021420
www.wooyun.org/bugs/wooyun-2013-020246

参考资料:
http://wolfeye.baidu.com/blog/
www.claudxiao.net/2013/03/android-webview-cache/

中危

检测到3使用全局可读写操作文件。

位置: assets/vivounionsdk/vivounionapk_v3.0.0_7575fa4_201711091449.vua
com.unionpay.a;->onReceive(Landroid.content.Context; Landroid.content.Intent;)V===>openFileOutput
com.unionpay.UPPayAssistEx;->a(Landroid.content.Context; Ljava.lang.String;)Ljava.lang.String;===>openFileOutput
com.unionpay.UPPayAssistEx;->installUPPayPlugin(Landroid.content.Context;)Z===>openFileOutput

在使用getDir、getSharedPreferences(SharedPreference)或openFileOutput时,如果设置了全局的可读权限,攻击者恶意读取文件内容,获取敏感信息。在设置文件属性时如果设置全局可写,攻击者可能会篡改、伪造内容,可以能会进行诈骗等行为,造成用户财产损失。建议:
(1)使用MODE_PRIVATE模式创建内部存储文件。
(2)加密存储敏感数据。
(3)避免在文件中存储明文和敏感信息。

参考案例:
http://wooyun.org/bugs/wooyun-2010-047172
http://wooyun.org/bugs/wooyun-2010-054438
http://wooyun.org/bugs/wooyun-2010-0151270

参考资料:
https://jaq.alibaba.com/blog.htm?id=56
https://jaq.alibaba.com/blog.htm?id=58
http://wolfeye.baidu.com/blog/global-rw-of-file
http://wolfeye.baidu.com/blog/global-rw-of-sharepreference/

低危

检测到3处使用了DES弱加密算法。

位置: assets/vivounionsdk/vivounionapk_v3.0.0_7575fa4_201711091449.vua
'DES/CBC/PKCS5Padding' used in: Lcom/unionpay/sdk/k;->a([B [B)[B
'DES/CBC/PKCS5Padding' used in: Lcom/unionpay/sdk/k;->b([B [B)[B
'DES/CBC/PKCS5Padding' used in: Lcom/unionpay/sdk/k;->c([B [B)[B

使用弱加密算法会大大增加黑客攻击的概率,黑客可能会破解隐私数据、猜解密钥、中间人攻击等,造成隐私信息的泄漏,甚至造成财产损失。建议使用AES加密算法。

参考资料:
http://drops.wooyun.org/tips/15870
https://developer.android.com/training/articles/keystore.html
http://wolfeye.baidu.com/blog/weak-encryption/
http://www.freebuf.com/articles/terminal/99868.html

低危

检测1处Intent Scheme URI漏洞。

位置: assets/vivounionsdk/vivounionapk_v3.0.0_7575fa4_201711091449.vua
Lcom/vivo/unionsdk/ui/ar;->式(Ljava/lang/String;)Z


Intent Scheme URI是一种特殊的URL格式,用来通过Web页面启动已安装应用的Activity组件,大多数主流浏览器都支持此功能。如果在app中,没有检查获取到的load_url的值,攻击者可以构造钓鱼网站,诱导用户点击加载,就可以盗取用户信息。所以,对Intent URI的处理不当时,就会导致基于Intent的攻击。建议:
如果使用了Intent.parseUri函数,获取的intent必须严格过滤,intent至少包含addCategory(“android.intent.category.BROWSABLE”),setComponent(null),setSelector(null)3个策略。

参考资料:
http://wolfeye.baidu.com/blog/intent-scheme-url/
http://drops.wooyun.org/papers/2893
http://drops.wooyun.org/mobile/15202

低危

检测到7处AES/DES弱加密风险。

位置: assets/vivounionsdk/vivounionapk_v3.0.0_7575fa4_201711091449.vua
com.vivo.sdkplugin.account.a;->驶([B [B)[B
com.vivo.sdkplugin.account.a;->始([B [B)[B
com.alipay.sdk.encrypt.b;->a(I Ljava.lang.String; Ljava.lang.String;)Ljava.lang.String;
Lcom/unionpay/mobile/android/hce/a;->a(Ljava/lang/String; Ljava/lang/String;)Ljava/lang/String;
Lcom/unionpay/utils/c;->a(I [B [B)[B
Lcom/unionpay/mobile/android/utils/e;->a(I [B [B)[B
Lcom/unionpay/mobile/android/hce/a;->b(Ljava/lang/String; Ljava/lang/String;)Ljava/lang/String;

使用AES/DES/DESede加密算法时,如果使用ECB模式,容易受到攻击风险,造成信息泄露。建议在使用AES/DES/DESede加密算法时,应显示指定使用CBC或CFB加密模式

参考资料:
http://blog.csdn.net/u013107656/article/details/51997957
https://developer.android.com/reference/javax/crypto/Cipher.html
http://drops.wooyun.org/tips/15870
https://developer.android.com/training/articles/keystore.html
http://wolfeye.baidu.com/blog/weak-encryption/
http://www.freebuf.com/articles/terminal/99868.html

低危

非debug包,需要通过打包平台proguard脚本,移除大部分系统输出代码。
经扫描该包仍存在大量系统输出代码,共发现3处系统输出代码.(此处扫描的系统输出代码,是指调用System.out.print*输出的,本应在打包平台移除的系统输出代码.)
各个bundle系统输出代码详情如下:

位置: assets/vivounionsdk/vivounionapk_v3.0.0_7575fa4_201711091449.vua
com.vivo.upgradelibrary.log.LogPrinter;
com.vivo.security.d;
com.huanju.data.a;

低危

检测到1处主机名弱校验检测漏洞。

位置: assets/vivounionsdk/vivounionapk_v3.0.0_7575fa4_201711091449.vua
com.unionpay.sdk.an;->verify(Ljava.lang.String; Ljavax.net.ssl.SSLSession;)Z

自定义HostnameVerifier类,却不实现其verify方法验证域名直接返回true,直接接受任意域名。建议:
对SSL证书进行强校验,包括签名CA是否合法、证书是否是自签名、主机域名是否匹配、证书是否过期等。

参考资料:
http://drops.wooyun.org/tips/3296
https://www.91ri.org/12534.html

低危

检测到1处地方在自定义实现的WebViewClient类在onReceivedSslError调用proceed()方法。

位置: assets/vivounionsdk/vivounionapk_v3.0.0_7575fa4_201711091449.vua
com.alipay.sdk.auth.AuthActivity$b;->onReceivedSslError(Landroid.webkit.WebView; Landroid.webkit.SslErrorHandler; Landroid.net.http.SslError;)V

Android WebView组件加载网页发生证书认证错误时,会调用WebViewClient类的onReceivedSslError方法,如果该方法实现调用了handler.proceed()来忽略该证书错误,则会受到中间人攻击的威胁,可能导致隐私泄露。建议:
当发生证书认证错误时,采用默认的处理方法handler.cancel(),停止加载问题页面当发生证书认证错误时,采用默认的处理方法handler.cancel(),停止加载问题页面。

参考案例:
http://www.wooyun.org/bugs/wooyun-2010-0109266

参考资料:
https://jaq.alibaba.com/blog.htm?id=60
http://wolfeye.baidu.com/blog/webview-ignore-ssl-error/

警告

检测到10处addFlags使用Intent.FLAG_ACTIVITY_NEW_TASK。

位置: assets/music_card.apk
com.vivo.cardapk.MainActivity;->startPrivacySettingActivity

位置: assets/vivounionsdk/vivounionapk_v3.0.0_7575fa4_201711091449.vua
com.tencent.mobileqq.openpay.api.a;->a
com.vivo.upgradelibrary.utils.PackageUtils;->installNormal
com.unionpay.a;->onReceive
com.tencent.mm.sdk.a.a;->a
com.vivo.unionsdk.cmd.JumpUtils;->reJumpToGameCenter
com.vivo.upgradelibrary.utils.PackageUtils;->uninstallNormal
com.unionpay.UPPayAssistEx;->a
com.tencent.mobileqq.openpay.api.a;->b
com.vivo.upgradelibrary.utils.PackageUtils;->startInstalledAppDetails

APP创建Intent传递数据到其他Activity,如果创建的Activity不是在同一个Task中打开,就很可能被其他的Activity劫持读取到Intent内容,跨Task的Activity通过Intent传递敏感信息是不安全的。建议:
尽量避免使用包含FLAG_ACTIVITY_NEW_TASK标志的Intent来传递敏感信息。

参考资料:
http://wolfeye.baidu.com/blog/intent-data-leak

警告

检测到25个导出的组件接收其他app的消息,这些组件会被其他app引用并导致dos攻击。

activity com.android.bbkmusic.ui.MusicSettingActivity
activity com.android.bbkmusic.ui.BlankWebViewActivity
activity com.android.bbkmusic.ui.MusicPicker
activity com.android.bbkmusic.ui.PlayActivity
activity com.android.bbkmusic.MediaPlaybackActivity
activity com.android.bbkmusic.share.wxapi.WXEntryActivity
activity com.android.bbkmusic.share.QQShareActivity
activity com.tencent.tauth.AuthActivity
activity com.android.bbkmusic.ui.QueryBrowserActivity
activity com.android.bbkmusic.ui.QueryShowActivity
activity com.bbk.onlinemusic.search.Search_Activity
activity com.android.bbkmusic.ui.SecurityVerificationActivity
activity com.android.bbkmusic.ui.ExclusiveSelectionWebViewActivity
activity com.sina.weibo.sdk.share.WbShareTransActivity
activity com.sina.weibo.sdk.share.WbShareToStoryActivity
service com.android.bbkmusic.service.MusicService
service com.android.bbkmusic.mirror.MirrorMusicUrlService
service com.android.bbkmusic.MediaPlaybackService
service com.bbk.onlinemusic.OnLineMusicPlaybackService
service com.vivo.push.sdk.service.PushService
service com.vivo.push.sdk.service.CommandService
receiver com.android.bbkmusic.receiver.MediaButtonIntentReceiver
receiver com.android.bbkmusic.receiver.OutStartMusicReceiver
receiver com.android.bbkmusic.receiver.PushMessageReceiver
receiver com.vivo.push.sdk.service.RegistrationReceiver

建议:
(1)最小化组件暴露。对不会参与跨应用调用的组件建议显示添加android:exported="false"属性。
(2)设置组件访问权限。对provider设置权限,同时将权限的protectionLevel设置为"signature"或"signatureOrSystem"。
(3)组件传输数据验证。对组件之间,特别是跨应用的组件之间的数据传入与返回做验证和增加异常处理,防止恶意调试数据传入,更要防止敏感数据返回。

参考案例:
http://www.wooyun.org/bugs/wooyun-2010-0169746
http://www.wooyun.org/bugs/wooyun-2010-0104965

参考资料:
http://jaq.alibaba.com/blog.htm?spm=0.0.0.0.Wz4OeC&id=55
《Android安全技术解密与防范》

警告

检测到3个导出的隐式Service组件。
service com.android.bbkmusic.service.MusicService
service com.android.bbkmusic.mirror.MirrorMusicUrlService
service com.vivo.push.sdk.service.PushService

建议:为了确保应用的安全性,启动Service时,请始终使用显式Intent,且不要为服务声明Intent过滤器。使用隐式Intent启动服务存在安全隐患,因为您无法确定哪些服务将响应Intent,且用户无法看到哪些服务已启动。从Android 5.0(API 级别 21)开始,如果使用隐式 Intent 调用 bindService(),系统会抛出异常。

参考资料:
https://developer.android.com/guide/components/intents-filters.html#Types

警告

检测5处組件設置了android.intent.category.BROWSABLE属性。
com.android.bbkmusic.WidgetToTrackActivity
com.android.bbkmusic.ui.BlankWebViewActivity
com.android.bbkmusic.ui.PlayActivity
com.tencent.tauth.AuthActivity
com.vivo.unionsdk.ui.UnionActivity


在AndroidManifest文件中定义了android.intent.category.BROWSABLE属性的组件,可以通过浏览器唤起,这会导致远程命令执行漏洞攻击。建议:
(1)APP中任何接收外部输入数据的地方都是潜在的攻击点,过滤检查来自网页的参数。
(2)不要通过网页传输敏感信息,有的网站为了引导已经登录的用户到APP上使用,会使用脚本动态的生成URL Scheme的参数,其中包括了用户名、密码或者登录态token等敏感信息,让用户打开APP直接就登录了。恶意应用也可以注册相同的URL Sechme来截取这些敏感信息。Android系统会让用户选择使用哪个应用打开链接,但是如果用户不注意,就会使用恶意应用打开,导致敏感信息泄露或者其他风险。

參考案例:
http://www.wooyun.org/bugs/wooyun-2014-073875
http://www.wooyun.org/bugs/wooyun-2014-067798

参考资料:
http://wolfeye.baidu.com/blog/intent-scheme-url/
http://www.jssec.org/dl/android_securecoding_en.pdf
http://drops.wooyun.org/mobile/15202
http://blog.csdn.net/l173864930/article/details/36951805
http://drops.wooyun.org/papers/2893

警告

检测到7潜在的XSS漏洞。

位置: assets/vivounionsdk/vivounionapk_v3.0.0_7575fa4_201711091449.vua
com.alipay.sdk.auth.AuthActivity;->onCreate(Landroid.os.Bundle;)V
com.alipay.sdk.util.l;->a(Landroid.app.Activity; Ljava.lang.String; Ljava.lang.String;)Landroid.webkit.WebView;
com.token.verifysdk.VerifyCoder;->getWebView(Landroid.content.Context; Ljava.lang.String; Lcom.token.verifysdk.VerifyCoder$VerifyListener;)Landroid.webkit.WebView;
com.unionpay.WebViewJavascriptBridge;->(Landroid.app.Activity; Landroid.webkit.WebView; Lcom.unionpay.ab;)V
com.unionpay.mobile.android.upviews.b;->(Landroid.content.Context; Lcom.unionpay.mobile.android.upviews.b$a;)V
com.vivo.unionsdk.ui.ao;->始()V
com.vivo.unionsdk.ui.ar;->藥()V

允许WebView执行JavaScript(setJavaScriptEnabled),有可能导致XSS攻击。建议尽量避免使用。
(1)API等于高高于17的Android系统。出于安全考虑,为了防止Java层的函数被随意调用,Google在4.2版本之后,规定允许被调用的函数必须以@JavascriptInterface进行注解。
(2)API等于高高于17的Android系统。建议不要使用addJavascriptInterface接口,以免带来不必要的安全隐患,如果一定要使用该接口,建议使用证书校验。
u(3)使用removeJavascriptInterface移除Android系统内部的默认内置接口:searchBoxJavaBridge_、accessibility、accessibilityTraversal。

参考案例:
www.wooyun.org/bugs/wooyun-2015-0140708
www.wooyun.org/bugs/wooyun-2016-0188252

参考资料:
http://jaq.alibaba.com/blog.htm?id=48
http://blog.nsfocus.net/android-webview-remote-code-execution-vulnerability-analysis

警告

检测到13处IvParameterSpec的使用。

位置: assets/vivounionsdk/vivounionapk_v3.0.0_7575fa4_201711091449.vua
com.a.a.a.a.a;->始([B [B)[B
com.a.a.a.a.a;->驶([B [B)[B
com.alipay.b.a.a.a.a.c;->a(Ljava.lang.String; Ljava.lang.String;)Ljava.lang.String;
com.alipay.b.a.a.a.a.c;->b(Ljava.lang.String; Ljava.lang.String;)Ljava.lang.String;
com.alipay.sdk.encrypt.e;->a(Ljava.lang.String; [B)[B
com.alipay.sdk.encrypt.e;->b(Ljava.lang.String; [B)[B
com.huanju.data.b.a;->始(Ljava.lang.String; Ljava.lang.String; [B)[B
com.huanju.data.b.a;->驶(Ljava.lang.String; Ljava.lang.String; [B)[B
com.unionpay.sdk.av;->a(Ljava.lang.String;)Ljava.lang.String;
com.unionpay.sdk.av;->b(Ljava.lang.String;)Ljava.lang.String;
com.unionpay.sdk.k;->a([B [B)[B
com.unionpay.sdk.k;->b([B [B)[B
com.unionpay.sdk.k;->c([B [B)[B

使用IVParameterSpec函数,如果使用了固定的初始化向量,那么密码文本可预测性高得多,容易受到字典攻击等。建议禁止使用常量初始化矢量构造IVParameterSpec,使用聚安全提供的安全组件。

参考资料:
http://drops.wooyun.org/tips/15870
https://developer.android.com/training/articles/keystore.html
http://wolfeye.baidu.com/blog/weak-encryption/
http://www.freebuf.com/articles/terminal/99868.html

警告

检测到2处provider的grantUriPermissions设置为true。
com.vivo.upgradelibrary.utils.FileProvider
android.support.v4.content.FileProvider


grant-uri-permission若设置为true,可被其它程序员通过uri访问到content provider的内容,容易造成信息泄露。

参考资料:
https://security.tencent.com/index.php/blog/msg/6

警告

检测到 6处url没有使用安全的https链接。

位置: assets/vivounionsdk/vivounionapk_v3.0.0_7575fa4_201711091449.vua
http://m.alipay.com/
http://mcgw.alipay.com/
http://mobilegw-1-64.test.alipay.net/
http://mobilegw.aaa.alipay.net/
http://mobilegw.alipay.com/
http://mobilegw.stable.alipay.net/

参考资料:
https://jaq.alibaba.com/blog.htm?id=60
https://developer.android.com/training/articles/security-ssl.html

警告

检测到16处使用了加解密算法。密钥处理不当可能会导致信息泄露。

位置: assets/vivounionsdk/vivounionapk_v3.0.0_7575fa4_201711091449.vua
com.a.a.a.a.a;->驶([B [B)[B
com.a.a.a.a.a;->始([B [B)[B
com.unionpay.mobile.android.utils.e;->a(I [B [B)[B
com.unionpay.sdk.av;->c(Ljava.lang.String;)Ljavax.crypto.spec.SecretKeySpec;
com.alipay.sdk.encrypt.b;->a(I Ljava.lang.String; Ljava.lang.String;)Ljava.lang.String;
com.vivo.sdkplugin.account.a;->驶([B [B)[B
com.alipay.sdk.encrypt.e;->a(Ljava.lang.String; [B)[B
com.huanju.data.b.a;->驶(Ljava.lang.String; Ljava.lang.String; [B)[B
com.huanju.data.b.a;->始(Ljava.lang.String; Ljava.lang.String; [B)[B
com.unionpay.utils.c;->a(I [B [B)[B
com.alipay.b.a.a.a.a.c;->b(Ljava.lang.String; Ljava.lang.String;)Ljava.lang.String;
com.unionpay.sdk.av;->b(Ljava.lang.String;)Ljava.lang.String;
com.a.a.c.d;->驶([B)Ljava.lang.String;
com.vivo.sdkplugin.account.a;->始([B [B)[B
com.alipay.b.a.a.a.a.c;->a(Ljava.lang.String; Ljava.lang.String;)Ljava.lang.String;
com.alipay.sdk.encrypt.e;->b(Ljava.lang.String; [B)[B

参考案例:
http://www.wooyun.org/bugs/wooyun-2010-0105766
http://www.wooyun.org/bugs/wooyun-2015-0162907
http://www.wooyun.org/bugs/wooyun-2010-0187287

参考资料:
http://drops.wooyun.org/tips/15870
https://developer.android.com/training/articles/keystore.html


动态扫描发现风险点

风险等级 风险名称

服务端分析

风险等级 风险名称

警告

检测到?处XSS漏洞。
开发中...

警告

检测到?处XSS跨站漏洞。
开发中...

应用证书