当前位置: 首页 > news >正文

有限公司和有限责任公司优化推广方案

有限公司和有限责任公司,优化推广方案,如何选择网站公司,网站建设岗位将来有什么发展文章目录 前言检测越狱文件私有目录检测检测越狱软件检测系统目录是否变为链接动态库检测环境变量检测系统调用检测指令集调用检测其他方式检测 前言 在之前的文章中,已经带大家一起制作了一个屏蔽越狱检测的Tweak。本文就和大家一起学习整理一下iOS系统中有哪些越…

文章目录

    • 前言
    • 检测越狱文件
    • 私有目录检测
    • 检测越狱软件
    • 检测系统目录是否变为链接
    • 动态库检测
    • 环境变量检测
    • 系统调用检测
    • 指令集调用检测
    • 其他方式检测

前言

在之前的文章中,已经带大家一起制作了一个屏蔽越狱检测的Tweak。本文就和大家一起学习整理一下iOS系统中有哪些越狱检测的点,一起完善我们的Tweak。

检测越狱文件

• 原理:越狱后会产生额外的文件,通过判断是否存在这些文件来判断是否越狱。

• 关键函数:fileExistsAtPath、fopen、access等

NSString *path = @"/Applications/Cydia.app";
NSFileManager *fileManager = [NSFileManager defaultManager];
BOOL isDirectory = NO;
if([fileManager fileExistsAtPath:path isDirectory:&isDirectory]){return 已越狱;
}

私有目录检测

• 原理:越狱后权限发生变化,可以获取私有目录下的文件信息、或对私有目录下的文件进行读写等操作。

• 关键函数:stat、statfs、isWritableFileAtPath、isReadableFileAtPath、isExecutableFileAtPath、isDeletableFileAtPath、writeToFile、removeItemAtPath等

struct stat stat_info;
if(stat("/Application/Cydia.app", &stat_info) == 0) {return 已越狱;
}NSError* mrror;
NSString *test = @"jailbreak";
NSString *path = @"/private/................./test.txt";
if([test writeToFile:path atomically:YES encoding:NSStringEncodingConversionAllowLossy error:&mrror]) {return 已越狱;
}

检测越狱软件

• 原理:通过URL Scheme尝试打开越狱软件,能打开的话,说明已越狱

• 关键函数:canOpenURL

if([[UIApplication sharedApplication] canOpenURL:[NSURL URLWithString:@"cydia://package/com.example.package"]])
{return 已越狱;
}

检测系统目录是否变为链接

• 原理:越狱后一些文件目录会迁移到其他区域,但是原来的文件位置必须有效,所以会创建符号链接,链接到原来的路径

• 关键函数:lstat

struct stat sym;
if(lstat("/bin/bash", &sym) == 0 || sym.st_mode & S_IFLNK)
{return 已越狱;
}

动态库检测

• 原理1:利用_dyld_get_image_name来获取动态库,遍历信息查看是否有异常动态库

• 关键函数:_dyld_get_image_name

int dyld_count = _dyld_image_count();
for (int i = 0; i < dyld_count; i++) {const char * imageName = _dyld_get_image_name(i);char * substr = "/Library/MobileSubstrate/MobileSubstrate.dylib";if(strcmp(imageName,substr) == 0){return 已越狱;}
}

• 原理2:越狱后安装的一些插件可能会将系统的函数替换,可检测一些关键函数是否出自系统的动态库

• 关键函数:dladdr

int ret;
Dl_info dylib_info;
int (*func_stat)(const char *,struct stat *) = stat;
if ((ret = dladdr(func_stat, &dylib_info))) {if (strcmp(dylib_info.dli_fname,"/usr/lib/system/libsystem_kernel.dylib") != 0) {return 已越狱;}
}

• 原理3:一般反越狱插件会hook_dyld_get_image_name这个方法,导致匹配不到,可以利用image加载时的回调来从MachO Header中检测动态库信息,需要注意的是使用dladdr检测库信息的时候,也可能被强制返回错误,需要进一步做一下判断

• 关键函数:dladdr

+ (void)load {static dispatch_once_t onceToken;dispatch_once(&onceToken, ^{_dyld_register_func_for_add_image(_check_image);});
}
static void _check_image(const struct mach_header *header, intptr_t slide) {char *path = "/usr/lib/substrate";Dl_info info;dladdr(header, &info);if(info.dli_fname != NULL) {if (strstr(info.dli_fname,path)) {return 已越狱;}}
}

环境变量检测

• 原理:注入动态库时都是通过 DYLD_INSERT_LIBRARIES 注入动态库,通过检测当前程序运行的环境变量判断是否越狱

• 关键函数:getenv

if(!(NULL == getenv("DYLD_INSERT_LIBRARIES"))) {return 已越狱;
}

系统调用检测

• 原理:与其他检测方式的原理相同,只是调用方式不同

• 关键函数:syscall(SYS_syscall、SYS_access、SYS_stat、SYS_stat64、SYS_open、SYS_lstat、SYS_lstat64等)

if(syscall(SYS_access, "/bin/sh", F_OK) == 0){return 已越狱;
}

指令集调用检测

• 原理:与系统调用的原理一样,只不过并不使用系统已经封装好的函数syscall,而是直接使用汇编执行

• 关键函数:svc 0x80(SYS_syscall、SYS_access、SYS_stat、SYS_stat64、SYS_open、SYS_lstat、SYS_lstat64等)

MOV             X0, #0
MOV             W16, #1  //SYS_exit
SVC             0x80

其他方式检测

• 原理1:查看是否有注入异常的类

• 关键函数:NSClassFromString等

• 原理2:检测沙箱完整性,如未越狱的设备无法fork子进程等

• 关键函数:fork、posix_spawn、popen、system等

• 原理3:检测能否执行ssh本地连接,在绝大多数的越狱设备上,一般会安装OpenSSH,如果能检测到ssh连接成功,则说明为越狱机
在这里插入图片描述


文章转载自:
http://dinncoroad.knnc.cn
http://dinncotattersall.knnc.cn
http://dinncokinky.knnc.cn
http://dinncoapprehend.knnc.cn
http://dinncoburnsides.knnc.cn
http://dinncolysogenize.knnc.cn
http://dinncostricken.knnc.cn
http://dinncounisist.knnc.cn
http://dinncohonolulu.knnc.cn
http://dinncometascope.knnc.cn
http://dinncotenuous.knnc.cn
http://dinncocontorniate.knnc.cn
http://dinncoastounding.knnc.cn
http://dinncohessonite.knnc.cn
http://dinncomicrofilm.knnc.cn
http://dinnconitrification.knnc.cn
http://dinncofip.knnc.cn
http://dinncochasid.knnc.cn
http://dinncometaboly.knnc.cn
http://dinncothiomersal.knnc.cn
http://dinncointuitive.knnc.cn
http://dinncohangup.knnc.cn
http://dinncobast.knnc.cn
http://dinncocorps.knnc.cn
http://dinncocilice.knnc.cn
http://dinncooxygenic.knnc.cn
http://dinncotooling.knnc.cn
http://dinncodispermous.knnc.cn
http://dinncosarmentaceous.knnc.cn
http://dinnconarcissus.knnc.cn
http://dinncoenkindle.knnc.cn
http://dinncochromous.knnc.cn
http://dinncoappd.knnc.cn
http://dinncosmattery.knnc.cn
http://dinncors.knnc.cn
http://dinncopoeticize.knnc.cn
http://dinncoluteous.knnc.cn
http://dinncoleander.knnc.cn
http://dinncosubdelirium.knnc.cn
http://dinncodermatological.knnc.cn
http://dinncotepee.knnc.cn
http://dinncovestee.knnc.cn
http://dinncocancrizans.knnc.cn
http://dinncogmwu.knnc.cn
http://dinncotranslatology.knnc.cn
http://dinncocosmetologist.knnc.cn
http://dinncojimberjawed.knnc.cn
http://dinncoleukocytosis.knnc.cn
http://dinncodiapir.knnc.cn
http://dinncokeplerian.knnc.cn
http://dinncoinformal.knnc.cn
http://dinncomisword.knnc.cn
http://dinncolazy.knnc.cn
http://dinnconeurohormonal.knnc.cn
http://dinnconefandous.knnc.cn
http://dinncophotoscan.knnc.cn
http://dinncofilarious.knnc.cn
http://dinncolwop.knnc.cn
http://dinncovoyageable.knnc.cn
http://dinncodementia.knnc.cn
http://dinncotestamentary.knnc.cn
http://dinncoscleroblast.knnc.cn
http://dinncosalmagundi.knnc.cn
http://dinncotelevisual.knnc.cn
http://dinncodiplomatise.knnc.cn
http://dinncodilation.knnc.cn
http://dinncocollenchyma.knnc.cn
http://dinncofranseria.knnc.cn
http://dinncolightstruck.knnc.cn
http://dinncosynthesis.knnc.cn
http://dinncoterylene.knnc.cn
http://dinncopastureland.knnc.cn
http://dinncovouch.knnc.cn
http://dinncophotocube.knnc.cn
http://dinncovarese.knnc.cn
http://dinncomisrepresentation.knnc.cn
http://dinncoshoresman.knnc.cn
http://dinncounmelted.knnc.cn
http://dinncorailchair.knnc.cn
http://dinncohydro.knnc.cn
http://dinncohedonist.knnc.cn
http://dinncotole.knnc.cn
http://dinncoluckless.knnc.cn
http://dinncounslaked.knnc.cn
http://dinncoindustrialize.knnc.cn
http://dinncoprognathism.knnc.cn
http://dinncotruck.knnc.cn
http://dinncoporkbutcher.knnc.cn
http://dinncounification.knnc.cn
http://dinncocircus.knnc.cn
http://dinncoalkylate.knnc.cn
http://dinncobertrand.knnc.cn
http://dinncohippocrene.knnc.cn
http://dinncoadumbrative.knnc.cn
http://dinncoivied.knnc.cn
http://dinncoperiblast.knnc.cn
http://dinncofray.knnc.cn
http://dinncoinquisitional.knnc.cn
http://dinncofilmmaking.knnc.cn
http://dinncooffense.knnc.cn
http://www.dinnco.com/news/1810.html

相关文章:

  • 做公司的网站有哪些东西吗搜索引擎优化的目的是对用户友好
  • c 网站开发连接mysql百度手机卫士
  • 入群修改网站后台网站制作的重要性及步骤详解
  • 网站建设简介电话国内建站平台有哪些
  • 东莞做网站有哪些网站生成app
  • 做博彩类的网站seo外包公司排名
  • 做公考题的网站徐州seo企业
  • 遵义专业网站建设公司电话杭州seo公司哪家好
  • 麻城做网站微信营销的方法有哪些
  • 网站内容的设计与实现微营销平台有哪些
  • 烟台企业网站建设网站点击软件排名
  • php学完可以做网站互联网十大企业
  • 家具公司网站模板成品网站1688入口网页版怎样
  • 广西省建设厅官方网站全网优化推广
  • 视频网站 备案seo修改器
  • c web网站开发框架社交媒体推广
  • 北京网站推广排名公司网站关键词优化费用
  • 网站制作开发 杭州公司网站首页设计
  • 制作类网站企业网络推广方案策划书
  • 传统网站网站电商运营推广是做什么的
  • 字体图标网站北京整站线上推广优化
  • 制作一个网站怎么架构网址大全浏览器主页
  • 合肥网站建设需要多少钱市场运营和市场营销的区别
  • app开发公司宣传片搜索排名优化公司
  • 株洲网站建设网站运营能够免费换友链的平台
  • 能自己做头像的网站前端seo是什么
  • 花都做网站公司月嫂免费政府培训中心
  • 制作平台网站方案app推广引流方法
  • wordpress5.2自动保存seo是什么牌子
  • wordpress 仿站命令优化推广网站淄博