深入剖析某App视频详情逆向:聚焦sig3参数攻克
深入剖析某手App视频详情逆向:聚焦sig3参数攻克
一、引言
在当今互联网信息爆炸的时代,短视频平台如某手,已成为人们获取信息、娱乐消遣的重要渠道。对于技术爱好者和研究人员而言,深入探索其内部机制,特别是视频详情相关参数的逆向分析,不仅能增进对移动应用架构的理解,也为数据挖掘、算法优化等领域提供了宝贵见解。本文将详细阐述对某手App视频详情中关键参数sig3、__NS_sig3以及__NStokensig的逆向过程,涵盖从初步探索到深度解析的全流程。
实现效果
成功率还是蛮高的,对代理ip要求比较高
完整json文件
{'result': 1, 'photos': [{'editInfo': {}, 'supportType': 0, 'enableCoronaViewLater': True, 'danmakuInfo': {'hasDanmaku': True, 'defaultDanmaku': '发个弹幕见证此刻', 'danmakuShortcuts': ['来了来了'], 'danmakuShowDirection': 2, 'photoDanmakuGuide': False, 'paster': False}, 'enableFullScreenPlay': False, 'sharePassingParam': '{"trendingType":"UNKNOWN","mainTitle":"","subTitle":"","likeCount":461,"commentCount":0,"shareCount":0,"collectCount":0,"authorId":1348248304}', 'recreationSetting': -1, 'playerPanelUnsupportedType': [1, 2], 'showGrDetailPage': False, 'ptp': '', 'sourcePhotoPage': 'sp', 'collect_count': 7, 'hasVote': False, 'commentInfo': {'permissions': 63, 'enableAIPresetGuide': False, 'commentCountSpecialEffect': True, 'commentIconType': 0}, 'commentGuessSearch': {'searchWord': '男朋友收到女朋友送的花的反应', 'iconUrl': 'https://ali2.a.kwimgs.com/udata/pkg/se-cdn/search_blue3x.png', 'displayPrefix': '大家都在搜:', 'searchWordMD5': 'c6d9fde9ca0853345af1b54b4502ae52', 'sessionId': 'MzIwXzBfMTc0NzE5MDA0NjM1M19fMzU5NA'}, 'videoColdStartType': 0, 'savePlayProgressStrategy': 2, 'musicDisk': {'expand': False}, 'enableCoronaDetailPage': False, 'feedSwitches': {'disableCommentLikeAnimation': False, 'disable61ActivityAnimation': True, 'enablePlayerPanel': True, 'enablePictureCommentForPhoto': True}, 'type': 1, 'duration': 13862, 'plcFeatureEntryAbFlag': 3, 'noNeedToRequestPLCApi': True, 'plcResponseTime': 1747190046348, 'plcHighPriorityThanBottomEntry': False, 'liked': 0, 'streamManifest': {'version': '1.0.0', 'businessType': 2, 'mediaType': 2, 'videoId': 'a4d0bb0b320fedef', 'hideAuto': False, 'manualDefaultSelect': False, 'stereoType': 0, 'adaptationSet': [{'id': 1, 'duration': 13976, 'representation': [{'id': 1, 'url': 'http://v2-zj-scct.kwaicdn.com/ksc1/JQ3GViu4n0Pm-Esd_z61I3cgzHWJuHK0EE6OzT4PmkDqa2AlgVYE0RUk6M_qCasmOu4QF51l81TzhpAhkOhPHBFhTrmnT0KJxFbgKFcqtRMfqSnj4MROXoa2-Ibc5mF7B-82JGzGMIE0rKxHaMptG4HnZ7aC_5h3yfiLVmdj_nlCHiDA70msxwFvpPUv6lKt.mp4?tag=1-1747190046-sp-0-acoeuufnau-1b14e473a71c40d2&provider=self&clientCacheKey=3xrz92eeifyrnxc_b.mp4&di=7679f82e&bp=10321&Aecs=172.19.0.212&ocid=100000971&tt=b&ss=vp', 'backupUrl': ['http://alimov6.a.yximgs.com/ksc1/JQ3GViu4n0Pm-Esd_z61I3cgzHWJuHK0EE6OzT4PmkDqa2AlgVYE0RUk6M_qCasmOu4QF51l81TzhpAhkOhPHBFhTrmnT0KJxFbgKFcqtRMfqSnj4MROXoa2-Ibc5mF7B-82JGzGMIE0rKxHaMptG4HnZ7aC_5h3yfiLVmdj_nlCHiDA70msxwFvpPUv6lKt.mp4?tag=1-1747190046-sp-1-zc3cs6wqpq-27ebc27765b12cb3&clientCacheKey=3xrz92eeifyrnxc_b.mp4&di=7679f82e&bp=10321&kwai-not-alloc=0&type=cold&tt=b&ss=vp'], 'maxBitrate': 3300, 'avgBitrate': 1800, 'width': 720, 'height': 1280, 'frameRate': 29.0, 'quality': 1.5, 'kvqScore': {'FR': -1.0, 'NR': -1.0, 'FRPost': -1.0, 'NRPost': -1.0}, 'qualityType': '720p', 'qualityLabel': '高清', 'featureP2sp': True, 'p2spCode': '{"fRsn":0,"fixOpt":-1,"schTask":"","schCode":-1,"schRes":"","pushTask":"v=0&p=0&s=0&d=0","pushCode":-1}', 'hidden': False, 'disableAdaptive': False, 'defaultSelect': False, 'comment': 'videoId=a4d0bb0b320fedef/ttExplain=AVC_VeryFast_720P_高码率_Basic/tt=b', 'hdrType': 0, 'fileSize': 3145355, 'bitratePattern': [2568, 1790, 2623, 484, 604], 'agc': False, 'mute': False, 'oriLoudness': 0.0, 'makeupGain': 0.0, 'realLoudness': 0.0, 'realNormalizeGain': 0.0, 'normalizeGain': 0.0}]}], 'playInfo': {'bizType': 0, 'cdnTimeRangeLevel': 0}, 'videoFeature': {'blurProbability': 0.45244139432907104, 'blockyProbability': 0.494193434715271, 'avgEntropy': 16.648486614227295, 'mosScore': 0.490234375}}, 'main_mv_urls': [{'cdn': 'alimov6.a.yximgs.com', 'url': 'http://alimov6.a.yximgs.com/ksc1/JQ3GViu4n0Pm-Esd_z61I3cgzHWJuHK0EE6OzT4PmkDqa2AlgVYE0RUk6M_qCasmOu4QF51l81TzhpAhkOhPHBFhTrmnT0KJxFbgKFcqtRMfqSnj4MROXoa2-Ibc5mF7B-82JGzGMIE0rKxHaMptG4HnZ7aC_5h3yfiLVmdj_nlCHiDA70msxwFvpPUv6lKt.mp4?tag=1-1747190046-sp-0-3vtwyeoygh-a202a8428d64f20c&clientCacheKey=3xrz92eeifyrnxc_b.mp4&tt=b&di=7679f82e&bp=10321', 'feature': [1]}, {'cdn': 'v3.kwaicdn.com', 'url': 'http://v3.kwaicdn.com/ksc1/JQ3GViu4n0Pm-Esd_z61I3cgzHWJuHK0EE6OzT4PmkDqa2AlgVYE0RUk6M_qCasmOu4QF51l81TzhpAhkOhPHBFhTrmnT0KJxFbgKFcqtRMfqSnj4MROXoa2-Ibc5mF7B-82JGzGMIE0rKxHaMptG4HnZ7aC_5h3yfiLVmdj_nlCHiDA70msxwFvpPUv6lKt.mp4?pkey=AAXYodXfFED8EIbQCZzTxVPEP5PkgJRJ-EBheiP-BpOEzh-QWLG8v25gC8hxyWXup-kJ08rGe6yooQ-nfxmgsOv0gxnTwoah97d0iA2D0rnVe4GRDOkK2I9C0KlX2IpOdyk&tag=1-1747190046-sp-1-lhu1lmooyc-586d9bf664b8bd5c&clientCacheKey=3xrz92eeifyrnxc_b.mp4&tt=b&di=7679f82e&bp=10321', 'feature': [1]}], 'cover_thumbnail_urls': [{'cdn': 'p66-plat.wsukwai.com', 'url': 'http://p66-plat.wsukwai.com/upic/2023/04/18/10/BMjAyMzA0MTgxMDEzNThfMTM0ODI0ODMwNF8xMDA5MDE5NzMwNDZfMV8z_hd_Be6983707e466de650e38b2ed39d801f0.kpg?tag=1-1747190046-sp-0-c5nzqmfzds-1c5247c0c27da933&clientCacheKey=3xrz92eeifyrnxc_hd.kpg&di=7679f82e&bp=10321'}, {'cdn': 'ali2.a.kwimgs.com', 'url': 'http://ali2.a.kwimgs.com/upic/2023/04/18/10/BMjAyMzA0MTgxMDEzNThfMTM0ODI0ODMwNF8xMDA5MDE5NzMwNDZfMV8z_hd_Be6983707e466de650e38b2ed39d801f0.kpg?tag=1-1747190046-sp-1-29wb2stz0c-9bb4f5c598d762be&clientCacheKey=3xrz92eeifyrnxc_hd.kpg&di=7679f82e&bp=10321'}], 'ff_cover_thumbnail_urls': [{'cdn': 'p66-plat.wsukwai.com', 'url': 'http://p66-plat.wsukwai.com/upic/2023/04/18/10/BMjAyMzA0MTgxMDEzNThfMTM0ODI0ODMwNF8xMDA5MDE5NzMwNDZfMV8z_ff_B873d8c939a883c65969f398e38d229d1.kpg?tag=1-1747190046-sp-0-r3iicsjhsi-961ccacb7979f988&clientCacheKey=3xrz92eeifyrnxc_ff.kpg&di=7679f82e&bp=10321'}, {'cdn': 'ali2.a.kwimgs.com', 'url': 'http://ali2.a.kwimgs.com/upic/2023/04/18/10/BMjAyMzA0MTgxMDEzNThfMTM0ODI0ODMwNF8xMDA5MDE5NzMwNDZfMV8z_ff_B873d8c939a883c65969f398e38d229d1.kpg?tag=1-1747190046-sp-1-7qta9u6xqe-bad18ec928a2c27b&clientCacheKey=3xrz92eeifyrnxc_ff.kpg&di=7679f82e&bp=10321'}], 'us_c': 0, 'comment_count': 19, 'slideCommentEntryDisabled': False, 'frameStyle': 0, 'photoTextLocationInfo': {'leftRatio': 0.08148, 'topRatio': 0.10937, 'widthRatio': 0.85925, 'heightRatio': 0.78333}, 'verified': True, 'verifiedDetail': {'description': '临沂市广播电视台临沂新闻官方账号', 'iconType': 2, 'viceVerifiedType': 0, 'type': 7, 'newVerified': True, 'musicCompany': False}, 'kwaiId': 'lytvlyxw107', 'following': 0, 'user_name': '临沂新闻', 'headurls': [{'cdn': 'p2.a.yximgs.com', 'url': 'http://p2.a.yximgs.com/uhead/AB/2022/12/08/01/BMjAyMjEyMDgwMTI2MzZfMTM0ODI0ODMwNF8yX2hkMjg5Xzg3_s.jpg'}, {'cdn': 'p1.a.yximgs.com', 'url': 'http://p1.a.yximgs.com/uhead/AB/2022/12/08/01/BMjAyMjEyMDgwMTI2MzZfMTM0ODI0ODMwNF8yX2hkMjg5Xzg3_s.jpg'}], 'user_sex': 'F', 'us_l': True, 'location': {}, 'time': '2023-04-18 10:14:14', 'timestamp': 1681784054791, 'originalPhotoId': '3xrz92eeifyrnxc', 'like_count': 461, 'caption': '女孩把男朋友送的鲜花做成干花 当作伴手礼又送给了男朋友 双向奔赴的恋爱真的好让人羡慕', 'forward_count': 0, 'view_count': 34055, 'share_count': 48, 'photo_id': 5252604642649245005, 'photo_status': 0, 'shareGuide': {'playTimes': 2, 'photoShareGuide': False, 'minPlayDurationInSeconds': 15, 'textDisplayDurationInSeconds': 4}, 'us_d': 0, 'share_info': 'userId=3x39ucjfetdys42&photoId=3xrz92eeifyrnxc', 'forward_stats_params': {'et': '1_i/0_sp0'}, 'enableShareToStory': True, 'recoTags': [], 'soundTrack': {'name': "临沂新闻's soundtrack", 'duration': 13, 'user': {'following': False, 'kwaiId': 'lytvlyxw107', 'user_name': '临沂新闻', 'user_id': 1348248304, 'profilePagePrefetchInfo': {'profilePageType': 1}, 'headurl': 'http://p2.a.yximgs.com/uhead/AB/2022/12/08/01/BMjAyMjEyMDgwMTI2MzZfMTM0ODI0ODMwNF8yX2hkMjg5Xzg3_s.jpg', 'user_sex': 'F', 'headurls': [{'cdn': 'p2.a.yximgs.com', 'url': 'http://p2.a.yximgs.com/uhead/AB/2022/12/08/01/BMjAyMjEyMDgwMTI2MzZfMTM0ODI0ODMwNF8yX2hkMjg5Xzg3_s.jpg'}, {'cdn': 'p1.a.yximgs.com', 'url': 'http://p1.a.yximgs.com/uhead/AB/2022/12/08/01/BMjAyMjEyMDgwMTI2MzZfMTM0ODI0ODMwNF8yX2hkMjg5Xzg3_s.jpg'}], 'visitorBeFollowed': False, 'eid': '3x39ucjfetdys42'}, 'photoId': 5252604642649245005, 'audioUrls': [{'cdn': 'ali2.a.yximgs.com', 'url': 'http://ali2.a.yximgs.com/bs2/ost/MTAwOTAxOTczMDQ2XzEzNDgyNDgzMDQ.m4a'}, {'cdn': 'hw.a.yximgs.com', 'url': 'http://hw.a.yximgs.com/bs2/ost/MTAwOTAxOTczMDQ2XzEzNDgyNDgzMDQ.m4a'}], 'imageUrls': [{'cdn': 'ali2.a.yximgs.com', 'url': 'http://ali2.a.yximgs.com/bs2/ost/MTAwOTAxOTczMDQ2XzEzNDgyNDgzMDQ.jpg'}, {'cdn': 'hw.a.yximgs.com', 'url': 'http://hw.a.yximgs.com/bs2/ost/MTAwOTAxOTczMDQ2XzEzNDgyNDgzMDQ.jpg'}], 'artist': '临沂新闻', 'avatarUrls': [{'cdn': 'ali2.a.yximgs.com', 'url': 'http://ali2.a.yximgs.com/bs2/ost/MTAwOTAxOTczMDQ2XzEzNDgyNDgzMDQ.jpg'}, {'cdn': 'hw.a.yximgs.com', 'url': 'http://hw.a.yximgs.com/bs2/ost/MTAwOTAxOTczMDQ2XzEzNDgyNDgzMDQ.jpg'}], 'id': '5xbidgshmzff66c', 'type': 9, 'loudness': -15.0, 'finalStatus': 0, 'genreId': 0, 'audioType': 1, 'isOffline': False, 'hasCopyright': True, 'disableEnhancedEntry': True}, 'tag_hash_type': 1, 'tags': [], 'sameFrame': {'allow': False}, 'adminTags': [], 'user_id': 1348248304, 'ext_params': {'mtype': 3, 'color': 'A29890', 'w': 720, 'sound': 13860, 'h': 1280, 'interval': 29, 'video': 13862}, 'serverExpTag': 'feed_photo|5252604642649245005|1348248304|1_i/0_sp0', 'profilePagePrefetchInfo': {'profilePageType': 1}, 'exp_tag': '1_i/0_sp0', 'followShoot': {'disableFollowShoot': True}, 'feedLogCtx': {'stidContainer': 'CkMxfDIwMDQ1NzI0ODE4NDY4NjkwOTB8cGhvdG86NTI1MjYwNDY0MjY0OTI0NTAwNXx7InBnIjoic3AifXx7InIiOjB9', 'stExParams': '', 'logParams': '{}'}}], 'host-name': 'public-bjy-c26-kce-node1198.idchb1az2.hb1.kwaidc.com'}
二、某手App架构概述
某手App作为一款功能丰富的短视频应用,拥有复杂且高效的架构体系。其核心功能包括视频播放、上传、用户互动等,背后涉及多个模块协同工作。在网络通信层面,为保障数据安全与完整性,对请求参数进行加密处理是常见手段,而sig3等参数便是其中关键的加密产物。从客户端角度看,其通过一系列网络请求与服务器交互,获取视频详情、用户信息等数据,这些请求中的参数承载着关键信息,同时也被精心加密以防止非法篡改与数据窃取。
三、逆向工具准备
(一)静态分析工具
- Jadx:一款广泛使用的Java反编译工具,能将Android应用的字节码文件(.dex)反编译为Java代码,便于查看和分析应用的逻辑结构。在App逆向中,可通过Jadx搜索与sig3参数相关的代码引用,初步定位参数生成的位置。例如,在Jadx中搜索“sig3”字符串,可筛选出可能涉及参数处理的代码片段,尽管搜索结果众多,需要进一步筛选,但为后续分析提供了重要线索。
- Jeb:同样是强大的反编译工具,与Jadx相比,Jeb在代码解析和可视化方面具有独特优势。它能将字节码转换为更易理解的Java代码结构,对于Jadx中因自身原因未编译好的代码,在Jeb中可能能呈现出更清晰的逻辑。在分析sig3参数生成逻辑时,结合Jeb与Jadx,可相互补充,更全面地理解代码逻辑。
(二)动态调试工具
- Frida:作为一款动态插桩框架,Frida允许开发者在运行时对目标应用进行脚本注入,从而实现对应用内部函数调用、变量值等的监控与修改。在App逆向中,对于一些通过静态分析难以确定具体值的变量,如某些加密过程中的中间变量,可利用Frida编写hook脚本,在应用运行时获取其真实值。例如,在分析sig3参数生成过程中,若遇到某个native方法调用返回的值影响最终sig3结果,可通过Frida hook该native方法,获取其返回值,辅助理解整个加密流程。
- IDA Pro:常用于二进制文件的反汇编与调试,在分App的so库文件(包含native代码)时发挥重要作用。通过IDA Pro可查看so库中函数的汇编代码,进一步还原其功能逻辑。例如,在定位到与sig3参数相关的native方法后,使用IDA Pro打开对应的so库文件,分析其汇编代码,了解参数在native层的处理方式,包括数据转换、加密算法调用等细节。
四、sig3参数逆向分析流程
(一)初步定位
- 字符串搜索:在Jadx中以“sig3”为关键词进行搜索,发现大量相关引用。经过仔细筛选,排除与界面视图(view相关)、推送服务(push服务相关)等明显无关的结果,聚焦到可能真正生成sig3参数的代码区域。在这个过程中,会发现一些代码调用了特定方法来计算某个值,并将其赋值给与sig3相关的变量,这为后续深入分析提供了入口。
- 代码逻辑梳理:跟进筛选出的代码,发现其调用了一个名为CPU.getClock的方法来计算sig3参数。通过进一步查看CPU类的定义与实现,发现getClock方法是一个native方法,由libcore.so文件引入,这意味着需要深入到so库文件中继续分析其具体实现。
(二)深入so库分析
- IDA Pro导入与函数定位:使用IDA Pro打开libcore.so文件,通过Exports选项卡查找是否有与CPU_getClock相关的函数导出。由于Java native方法在so库中的命名遵循Java_类名_方法名的规则,很容易找到对应的CPU_getClock函数。进入该函数内部,看到的是汇编代码,为了便于理解,通过F5键将其转换为伪代码。
- 伪代码逻辑解析:在伪代码中,首先看到两个判断,分别检查cpu_inited和cpu_cnt的值是否存在。这两个判断涉及一些系统方法调用,从整体加密逻辑来看,可先暂时跳过。从if(!cpu_cnt)之后的代码开始分析,经过一系列byte数组相关的转换操作,遇到一个由自定义函数sDecryptedText得到的值v12。通过深入分析sDecryptedText方法内部逻辑,发现v12的值对应一个固定地址(如6074),为了获取其真实值,利用Frida编写hook脚本。通过获取so库的基地址,加上6074的偏移量,使用Frida的memory方法读取该地址的指针,成功获取v12的值。继续分析后续代码,发现有三个关键部分:j_cpu_clock_start、j_cpu_clock_x和j_cpu_clock_end,从命名推测加密逻辑可能在此处。
- 加密逻辑核心分析:进入j_cpu_clock_start方法,发现其初始化了一些变量。接着分析j_cpu_clock_x方法,该方法被认为是加密逻辑的核心部分。在代码中,定义了一些变量后,调用了sub_1EF4方法。通过对sub_1EF4方法的分析,并结合之前的代码逻辑,发现其具有典型的加盐MD5加密特征。经过编写代码验证,确定其确实是对相关数据加盐后进行MD5运算,最终得到影响sig3的关键加密值。这些值经过一系列组合与处理,最终生成sig3参数。
五、__NS_sig3与__NStokensig逆向要点
(一)__NS_sig3逆向思路
- 类似定位方法:与sig3参数逆向类似,首先在Jadx中搜索“__NS_sig3”字符串,筛选出可能的代码引用。通过对这些引用的代码逻辑梳理,发现其生成过程同样涉及多个方法调用与数据处理。与sig3不同的是,__NS_sig3可能与特定的网络请求场景或用户身份验证流程相关。在某些代码片段中,会发现它依赖于用户设备信息、当前网络状态以及部分用户特定数据的组合加密。
- 跨模块分析:__NS_sig3的生成可能跨越多个模块。例如,部分数据可能来自于设备信息模块获取的设备唯一标识符、系统版本等信息,与用户登录模块获取的用户账号相关信息进行整合,再经过一系列加密算法处理生成。在分析过程中,需要跟踪这些不同模块数据的流向与处理方式,理解它们如何协同作用生成__NS_sig3参数。
(二)__NStokensig逆向难点
- 复杂加密体系:__NStokensig的逆向难度相对较高,其加密体系更为复杂。它可能涉及多层加密,不仅包括常见的哈希加密,还可能结合非对称加密算法,如RSA等。在代码中,会发现多个加密函数嵌套调用,且加密密钥的生成方式也较为隐蔽。例如,密钥可能是根据设备指纹、当前时间戳以及用户特定的加密种子经过复杂运算得到。
- 动态变化特性:__NStokensig具有动态变化特性,每次请求生成的值可能不同,且与多种实时因素相关。这意味着在逆向过程中,不能简单地通过静态分析确定其固定生成逻辑,需要结合动态调试,实时跟踪其在不同请求场景下的生成过程。例如,通过Frida hook相关函数,观察在不同网络环境、不同用户操作下,__NStokensig生成过程中变量值的变化,从而总结出其动态生成规律。
六、逆向过程中的挑战与解决方案
(一)代码混淆
为保护其代码逻辑,采用了代码混淆技术。在Jadx反编译的代码中,类名、方法名和变量名多被混淆为无意义的字符,增加了代码理解难度。解决方案是借助一些代码分析工具和技巧,如通过代码的调用关系、参数传递类型等信息,推测混淆代码的实际功能。同时,结合多个反编译工具的结果,相互印证,提高代码理解的准确性。例如,在分析某个混淆方法时,通过观察其传入参数的类型与数量,以及该方法在整个代码逻辑中的调用位置,判断其可能实现的功能,再结合其他工具对同一方法的解析结果,进一步确认推测。
(二)反调试机制
可能存在反调试机制,阻止逆向人员进行动态调试。当使用Frida或IDA Pro等调试工具时,应用可能会检测到调试行为并采取相应措施,如闪退或关闭某些关键功能。针对这一问题,可通过分析反调试检测代码,使用Hook技术绕过检测。例如,若发现应用通过特定系统函数检测调试器存在,可使用Frida hook该函数,使其返回虚假的未调试状态,从而避免应用触发反调试措施,保证动态调试能够顺利进行。
(三)数据加密多样性
如前文所述,App在参数加密方面采用了多种加密算法和复杂的加密流程,增加了逆向难度。应对策略是深入研究各种加密算法原理,结合代码分析确定实际使用的加密方式。在分析过程中,对于复杂的加密逻辑,可将其分解为多个子步骤,逐步分析每个步骤的输入、输出以及所使用的加密算法,通过不断积累经验和总结规律,提高对复杂加密体系的破解能力。例如,对于__NStokensig涉及的多层加密,先分析最外层加密算法的类型与特征,再逐步深入内层,通过跟踪加密过程中数据的变化,理解整个加密体系的运作机制。
七、逆向成果应用与合规考量
(一)成果应用
- 数据挖掘与分析:通过逆向获取的参数生成逻辑,可在合法合规的前提下,更准确地模拟App的网络请求,实现对视频详情数据的高效抓取与分析。这对于研究短视频内容趋势、用户行为模式等具有重要意义。例如,通过模拟请求获取大量视频的点赞数、评论数、播放量等数据,分析不同类型视频的受欢迎程度,为内容创作者提供参考,帮助其优化创作方向。
- 算法优化与改进:深入理解App的参数加密与数据传输机制,有助于对相关算法进行优化。例如,在开发类似短视频应用时,可借鉴快手在参数加密方面的经验,结合自身业务需求,设计更高效、安全的加密算法,保障用户数据安全与应用的稳定运行。同时,对于一些数据处理算法,通过分析快手的实现方式,可发现潜在的优化点,提高数据处理效率。
(二)合规考量
在进行App逆向分析时,必须严格遵守法律法规与道德规范。未经授权对商业应用进行逆向分析并用于非法目的,如恶意攻击、数据窃取、破解付费功能等,属于违法行为。在合法合规的范围内,可进行技术研究与学习,但需确保不侵犯他人知识产权和用户隐私。例如,在数据挖掘与分析过程中,仅使用公开可见的数据,并遵循相关隐私政策与数据保护法规,不滥用用户数据。同时,在分享逆向技术与成果时,也要注意避免传播可能被用于非法活动的信息,维护健康的网络技术生态。
八、结论
对App视频详情中sig3、__NS_sig3以及__NStokensig参数的逆向分析,是一个充满挑战但极具价值的过程。通过运用多种逆向工具,从静态分析到动态调试,逐步揭开其加密逻辑的面纱,不仅能深入了解快手App的内部运行机制,也为相关领域的技术发展提供了有力支持。然而,在享受技术探索带来的乐趣与成果时,务必牢记合规原则,确保技术应用在合法、道德的轨道上。随着移动应用技术的不断发展,逆向分析技术也将持续演进,未来我们将面临更多新的挑战与机遇,需要不断提升技术能力与知识储备,以应对复杂多变的技术环境。
相关文章:
深入剖析某App视频详情逆向:聚焦sig3参数攻克
深入剖析某手App视频详情逆向:聚焦sig3参数攻克 一、引言 在当今互联网信息爆炸的时代,短视频平台如某手,已成为人们获取信息、娱乐消遣的重要渠道。对于技术爱好者和研究人员而言,深入探索其内部机制,特别是视频详情…...
数据结构与算法-双向链表专题
目录 一. 双向链表的结构 二.双向链表的使用 2.1 创建节点 2.2 初始化 2.3 打印 2.4 尾插 2.5 头插 2.6 尾删 2.7 头删 2.8 在指定位置pos之后插入数据 2.9 查找数据 2.10 删除pos位置的节点 2.11 销毁链表 一. 双向链表的结构 在List.h的头文件中对链表的结构进行创建 #prag…...
为什么要选择七彩喜数字康养平台?加盟后有何优势?
一.七彩喜数字康养平台 1.技术领先性 七彩喜依托“端-网-云-脑”四层技术架构,整合毫米波雷达、AI算法引擎、区块链等前沿技术,解决传统养老的隐私泄露、设备孤岛等痛点。 比如非接触式健康监测系统通过毫米波雷达实现跌倒检测准确率&#…...
vscode调试c/c++
1. 调试配置选择 调试 C 程序:选择 "Debug C Program"(调用 gcc 编译)。 调试 C 程序:选择 "Debug C Program"(调用 g 编译)。 2. 调试步骤 打开代码文件:确保当前编辑器…...
进阶数据结构: AVL树
嘿,各位技术潮人!好久不见甚是想念。生活就像一场奇妙冒险,而编程就是那把超酷的万能钥匙。此刻,阳光洒在键盘上,灵感在指尖跳跃,让我们抛开一切束缚,给平淡日子加点料,注入满满的pa…...
C# 调试技巧——日志记录,NuGet内断点
在C#中,Debug.WriteLine()、Trace.WriteLine() 和 Console.WriteLine() 都用于输出信息,但它们的用途和适用场景有显著区别。以下是它们的核心差异总结: Debug.WriteLine()主要适用于控制台程序,输出到控制台Trace.WriteLine() …...
模糊数学方法之模糊贴近度
模糊数学方法之模糊贴近度 一、概述 二、代码实现(内含注释) #程序文件ex14_3.py # 本段带代码主要是用于判断b是属于a中的哪个种类的 # 通过计算贴近度的形式来实现的 import numpy as np a np.array([[0.4,0.3,0.5,0.3],[0.3,0.3,0.4,0.4],[0.2,0.3…...
Spring AI 集成 Mistral AI:构建高效多语言对话助手的实战指南
Spring AI 集成 Mistral AI:构建高效多语言对话助手的实战指南 前言 在人工智能应用开发领域,选择合适的大语言模型(LLM)与开发框架至关重要。Mistral AI 凭借其高效的多语言模型(如 Mistral-7B、Mixtral-8x7B 等&am…...
季报中的FPGA行业:U型反转,春江水暖
上周Lattice,AMD两大厂商相继发布2025 Q1季报,尽管恢复速度各异,但同时传递出FPGA行业整体回暖的复苏信号。 5月5日,Lattice交出了“勉强及格”的答卷,报告季度营收1亿2000万,与华尔街的预期基本相符。 对于这家聚焦在中小规模器件的领先厂商而言,按照其CEO的预期,长…...
Data Mining|缺省值补全实验
实验内容任务描述 利用sklearn完成缺省值补全,完成4种以上缺失值补全,并完整地进行模型训练与测试。 四种缺失值补全方法:众数插补、均值插补、K-邻近填充、迭代插补(极大似然估计) 采用模型:随机森林RandomForestClassifier( …...
RabbitMQ 快速上手:安装配置与 HelloWorld 实践(一)
一、引言 在当今分布式系统大行其道的技术浪潮下,各个服务之间的通信与协同变得愈发复杂。想象一下,一个电商系统在大促期间,订单服务、库存服务、支付服务、物流服务等众多模块需要紧密配合。如果没有一种高效的通信机制,系统很容…...
适配华为昇腾 NPU 的交互式监控工具
适配华为昇腾 NPU 的交互式监控工具 在人工智能开发的过程中,我们常常希望能够实时了解计算设备的使用情况。对于使用华为昇腾 NPU 的团队来说,传统上只能通过命令行工具(如 npu-smi)来查询性能指标。但这些命令输出的信息分散且…...
HarmonyOS NEXT~React Native在鸿蒙系统(HarmonyOS)上的适配现状与技术展望
HarmonyOS NEXT~React Native在鸿蒙系统(HarmonyOS)上的适配现状与技术展望 一、背景与现状 鸿蒙系统(HarmonyOS)作为华为自主研发的分布式操作系统,自2019年发布以来已经迭代多个版本。最新的HarmonyOS NEXT更是明确将仅支持原生应用[5],这…...
匿名函数lambda、STL与正则表达式
一、匿名函数lambda 重点: 怎么传递参数。 传引用还是传 1. 匿名函数的基本语法 [捕获列表](参数列表) mutable(可选) 异常属性 -> 返回类型 {// 函数体 } 语法规则:lambda表达式可以看成是一般函数的函数名被略去,返回值使用了一个 -…...
ssti模板注入学习
ssti模板注入原理 ssti模板注入是一种基于服务器的模板引擎的特性和漏洞产生的一种漏洞,通过将而已代码注入模板中实现的服务器的攻击 模板引擎 为什么要有模板引擎 在web开发中,为了使用户界面与业务数据(内容)分离而产生的&…...
存储扇区分配表:NAND Flash与SD NAND(贴片式SD卡)的架构差异
NAND Flash 和 SD 卡(SD NAND)的存储扇区分配表在原理上有相似之处,但由于二者的结构和应用场景不同,也存在一些差异。 相同点: 基本功能:NAND Flash 和 SD 卡(SD NAND)的存储扇区分…...
FreeRTOS队列原理讲解
继续更新freertos,讲解的是队列,队列是先进先出的一种数据结构,有入队和出队操作,今天主要讲解向队列发送消息源码/从队列取出消息源码。 先讲解入队函数,FreeRTOS中入队操作分为后向入队/前入/覆写,但无论…...
C——俄罗斯方块
前言 编译器选择:VS2022。需要掌握控制台操作、颜色设置、随机数生成、键盘事件、文件操作、二维数组操作等知识。运用语言:C语言。 一、游戏背景 1. 游戏概述 俄罗斯方块是一款经典的益智游戏,主要功能包括: 显示游戏界面 随…...
什么是 Shadow Testing?
Shadow Testing(影子测试)是一种在生产环境中对比验证新旧系统行为一致性的重要测试方法。它被广泛应用于系统迁移、架构重构、模型上线、A/B测试前的数据验证、灰度发布等场景,尤其在保障线上稳定性和数据正确性方面具有关键作用。 一、什么…...
【操作系统期末速成】①操作系统概述
——————2025.5.14————— 操作系统主要考点:操作系统概述、进程管理、内存管理、文件系统、设备管理(前三个重点,第二三个是重中之重) 操作系统概念(OS):(本质上是一个软件…...
关于vue学习的经常性错误
目录 常见问题: 1关于引用本地下载es6模块文件,报404错误 2 使用createApp函数后没有调用mount函数挂载到浏览器 3 在mount函数中,忘记引用插值表达式所在标签的定位符如 标签选择器,类选择器等 4在直接使用Vue3函数时&#…...
使用泛型加载保存数据
文章速览 泛型泛型概述定义优点 实例加载数据保存数据 一个赞,专属于你的足迹! 泛型 泛型概述 泛型(Generics)是 C# 中一种重要的编程特性,它允许程序员编写灵活且类型安全的代码。通过使用泛型,可以创建…...
火山引擎实时音视频 高代码跑通日志
实时音视频 SDK 概览--实时音视频-火山引擎 什么是实时音视频 火山引擎实时音视频(Volcengine Real Time Communication,veRTC)提供全球范围内高可靠、高并发、低延时的实时音视频通信能力,实现多种类型的实时交流和互动。 通…...
ubuntu清除缓存
pip pip cache purgeconda conda clean -a -yapt apt cleanapt-get apt-get cleanmodelscope modelscope clear-cachehuggingface rm -rf ~/.cache/huggingface/*...
Flink SQL 将kafka topic的数据写到另外一个topic里面
-- 创建源表,使用 RAW 格式接收原始 JSON 数据 CREATE TABLE source_kafka ( id STRING, data STRING ) WITH ( connector kafka, topic source_kafka-topic, properties.bootstrap.servers master01:9092, properties.group.id flink-kafka-group, scan.startu…...
【C++重载操作符与转换】纯虚函数
目录 一、纯虚函数的基本概念 1.1 定义与语法 1.2 抽象类 1.3 派生类的实现要求 二、纯虚函数的使用场景 2.1 定义接口 2.2 实现多态 2.3 设计框架 三、纯虚函数的特性 3.1 纯虚函数可以有实现 3.2 抽象类的构造函数和析构函数 3.3 纯虚函数与接口继承 四、纯虚函…...
面向具身智能的视觉-语言-动作模型(VLA)综述
具身智能被广泛认为是通用人工智能(AGI)的关键要素,因为它涉及控制具身智能体在物理世界中执行任务。在大语言模型和视觉语言模型成功的基础上,一种新的多模态模型——视觉语言动作模型(VLA)已经出现&#…...
车用CAN接口芯片:汽车神经系统的沉默构建者
车用CAN接口芯片:汽车神经系统的沉默构建者 在汽车电子系统的复杂架构中,CAN总线如同人体的神经系统,而CAN接口芯片则扮演着神经突触的角色。这些指甲盖大小的芯片,默默承担着整车超过70%的通信任务,却鲜少成为技…...
AI日报 · 2025年5月14日|Android 生态大型更新与多端 Gemini 集成
1、Google “Android Show: I/O Edition” 汇总:设计、安全、Gemini 三线并进 北京时间 5 月 14 日凌晨(原文标注 5 月 13 日 PDT),Google 在 I/O 前夕举办的 Android Show 一口气公布四大方向更新:① Mater…...
QT+opencv实现卡尺工具找圆、拟合圆
QT Opencv 实现卡尺工具找圆 找圆工具是自己从其他项目里面单独整理出来,可直接引用到新项目中。 程序中提供了函数接口,其他文件直接传入参数就能获取圆心和半径信息。次工具全采用QT和opencv,全部源码可随需求更改。 以下是实现效果&am…...
养生:拥抱健康生活的实用之道
在忙碌的现代生活中,养生逐渐成为人们追求健康的重要方式。从饮食、运动到睡眠与心态,各个养生环节相辅相成,共同构建起健康生活的大厦。以下为你详细介绍养生的关键要点,助你开启健康生活之旅。 饮食养生:科学搭配&a…...
Llama:开源的急先锋
Llama:开源的急先锋 Llama1:开放、高效的基础语言模型 Llama1使用了完全开源的数据,性能媲美GPT-3,可以在社区研究开源使用,只是不能商用。 Llama1提出的Scaling Law 业内普遍认为如果要达到同一个性能指标,训练更…...
使用大语言模型从零构建知识图谱(中)
从零到一:大语言模型在知识图谱构建中的实操指南 ©作者|Ninja Geek 来源|神州问学 还没有看过上篇的读者可以阅读《使用大语言模型从零构建知识图谱(上)》了解整个系列的内容 通过创建一个自定义流程来自动上传业务数据 在这一节&#…...
深度强化学习 | 图文详细推导软性演员-评论家SAC算法原理
目录 0 专栏介绍1 最大熵贝尔曼方程2 SAC算法原理推导2.1 参数化动作-价值函数2.2 参数化策略2.3 参数化温度 3 算法流程 0 专栏介绍 本专栏以贝尔曼最优方程等数学原理为根基,结合PyTorch框架逐层拆解DRL的核心算法(如DQN、PPO、SAC)逻辑。针对机器人运动规划场景…...
大数据开发 hadoop集群 3.Hadoop运行环境搭建
一、配置虚拟机 1.1 下载VMware虚拟机 1.下载地址:VMware Workstation下载_VMware Workstation官方免费下载_2024最新版_华军软件园 1.2 创建虚拟机 简易安装信息 1.3. 命名虚拟机 标题一 指定磁盘容量大小(推荐大小) 1.4. 语言和时区设…...
【HTTPS基础概念与原理】HTTPS vs HTTP:为什么现代网站必须用HTTPS?
以下是关于 HTTPS vs HTTP 的详细对比分析,涵盖安全性、性能差异及SEO影响,帮助您全面理解为何现代网站必须采用HTTPS: 一、安全性对比:HTTPS 如何解决 HTTP 的致命缺陷 1. HTTP 的安全隐患 • 明文传输:HTTP 数据以明…...
【springcloud学习(dalston.sr1)】Eureka单个服务端的搭建(含源代码)(三)
该系列项目整体介绍及源代码请参照前面写的一篇文章【springcloud学习(dalston.sr1)】项目整体介绍(含源代码)(一) 这篇文章主要介绍单个eureka服务端的集群环境是如何搭建的。 通过前面的文章【springcloud学习(dalston.sr1)】…...
榕壹云打车系统:基于Spring Boot+MySQL+UniApp的开源网约车解决方案
传统出租车行业的数字化痛点与破局 近年来,随着网约车市场的爆发式增长,传统出租车企业面临数字化转型的迫切需求。传统出租车行业存在以下核心痛点: 1. 运营效率低下:手工调度、纸质单据导致资源浪费。 2. 乘客体验不足:无法实时查看车辆位置、支付不便。 3. 安全监管…...
第5章 运算符、表达式和语句
目录 5.1 循环简介5.2 基本运算符5.3 其他运算符5.4 表达式和语句5.5 类型转换5.6 带有参数的函数5.7 一个实例程序5.11 编程练习 5.1 循环简介 5.2 基本运算符 赋值运算符: 几个术语:数据对象、左值、右值和操作数 数据对象:泛指数据存储区…...
全流量解析:让安全防御从“被动挨打”升级为“主动狩猎”
在网络安全领域,攻击者就像“隐形小偷”,总想悄无声息地入侵你的网络。而全流量解析,就是一套能“看清每一辆网络货车里装了什么”的技术。它通过采集并分析网络中的全部原始流量数据,帮助安全团队发现威胁、溯源攻击,…...
bfs-最小步数问题
最小步长模型 特征: 主要是解决权值为1且状态为字符串类型的最短路问题,实质上是有向图的最短路问题,可以简化为bfs求最短路问题。 代表题目: acwing 845 八数码问题: 八数码题中由于每次交换的状态是由x进行上下左右…...
机器学习 Day17 朴素贝叶斯算法-----概率论知识
1.简介 朴素贝叶斯(Naive Bayes)是一类基于贝叶斯定理(之后讲)并假设特征之间相互独立的概率分类算法 ,是机器学习中应用广泛的分类模型。以下为您详细介绍: 核心原理 贝叶斯定理:描述后验概…...
Selenium-Java版(环境安装)
Selenium自动化环境安装 前言 安装 安装客户端库 安装Chrome浏览器 安装Chrome浏览器驱动 安装Edge浏览器驱动 配置环境变量 示例 前言 参考教材:Python Selenium Web自动化 2024版 - 自动化测试 爬虫_哔哩哔哩_bilibili 安装 安装客户端库 <dep…...
【华为HCIP | 华为数通工程师】821—多选解析—第二十四页
980、以下关于BGP路由等价负载分担的描述,正确的是哪些项? A、公网中到达同一目的地的IBGP和EBGP路由不能形成负载分担。 B、在设备上使能BGP负载分担功能后,只有满足条件的多条BGP路由才会成为等价路由,进行负载分担。 C、默认情况下设备只会对AS Path长度相同的路由进…...
如何用Jsoup库提取商品名称和价格?
使用 Jsoup 库提取商品名称和价格是一个常见的任务,尤其是在爬取电商网站的商品详情时。Jsoup 是一个非常强大的 HTML 解析库,可以方便地从 HTML 文档中提取数据。以下是如何使用 Jsoup 提取商品名称和价格的详细步骤和代码示例。 一、环境准备 确保你…...
一文掌握六个空转数据库
写在前面 在实际的空转分析,尤其是细胞注释环节中,我们需要依赖大量的文献/数据库来对结果进行参考、校验,此时空间转录数据库能够快速帮助我们找到合适的参考数据集/信息。此外,现存的很多空转数据库收集了大量可供挖掘的数据&a…...
基于Qt的OSG三维建模
以下是一个基于Qt和OpenSceneGraph(OSG)实现三维模型交互的示例代码,包含模型高亮、文本标注等功能。代码采用Qt5和OSG 3.6版本开发。 一、核心类设计(C) 1. 主窗口类(继承QMainWindow) #inc…...
Spring Cloud:构建云原生微服务架构的最佳工具和实践
🌥️ 1. 引言 一、背景介绍:为什么需要微服务? 随着互联网技术的发展,企业级应用的功能日益复杂,传统的单体架构(Monolithic Architecture)逐渐暴露出一系列问题: 项目庞大&#…...
云图库和黑马点评的项目学习经验
捷优商超 我这个项目我主要实现了三个点,第一个是博主推送,就是用户进行消息的推送,拱用户进行商品的评价。第二个就是用户的签到。第三个就是优惠券秒杀了。 首先是博主推送,我们获取到前端信息以后直接把消息放到数据库里面&…...
苍穹外卖 - Day02 学习笔记
一、核心功能:新增员工 在实现新增员工功能时,有几个关键的技术点和设计考量需要我们掌握。 1.1 数据传输对象 (DTO) 的应用 核心概念: 数据传输对象(Data Transfer Object, DTO)是在应用程序不同分层之间传递数据的…...