iOS攻防:Cycript攻·防

简介:

简介

Cycript允许开发人员探讨和修改iOS和Mac OS X上运行的应用程序。

Cycript是一个理解Objective-C语法的javascript解释器,它能够挂钩正在运行的进程,能够在> 运行时修改应用的很多东西。

  • 能够挂钩正在运行的进程,并且找出正被使用的类信息,例如view controllers,内部和第三方库,甚至程序的delegate的名称。
  • 对于一个特定的类,例如View Controller, App delegate或者任何其他的类,我们能够得到所有被使用的方法名称。
  • 能够得到所有实例变量的名称和在程序运行的任意时刻实例变量的值。
  • 能够在运行时修改实例变量的值。
  • 能够执行Method Swizzling,例如替换一个特定方法的实现。
  • 可以在运行时调用任意方法,即使这个方法目前并不在应用的实际代码当中。

Cycript安装

  • 在这里下载 http://www.cycript.org/
  • 在这里阅读所有Cycript诡计 http://top.jobbole.com/crawler/

先看看怎么用Cycript干点坏事吧

1. 给应用弹一个莫名其妙的alert

ssh登陆你的手机(如果不会,上一篇有~)

找一个app

这里我找的是以前做的一个app


  
  
  1. ps aux | grep blackwidow 

print


  
  
  1. mobile 466 6.6 7.0 508416 36204 ?? Ss 11:22AM 0:09.65 /xxxx/blackwidow 

这样知道进程号是466

hock住


  
  
  1. cycript -p 466 

如果你看到出现了cy#,说明你可以开始编写Cycript代码了

alert


  
  
  1. // 找到widnow 
  2. var window = [UIApplication sharedApplication].keyWindow; 
  3. // 初始化一个alert 
  4. var alert = [[UIAlertView alloc] initWithTitle:@"hack you" message:@"hack you" window cancelButtonTitle:@"cancel" otherButtonTitles:@"yes", nil]; 
  5. // 弹出来吧 
  6. [alert show];   

2. 探索一个app


  
  
  1. function printMethods(className) { 
  2. var count = new new Type("I"); 
  3. var methods = class_copyMethodList(objc_getClass(className), count); 
  4. var methodsArray = []; 
  5. for(var i = 0; i 
  6. var method = methods[i]; 
  7. methodsArray.push({selector:method_getName(method), implementation:method_getImplementation(method)}); 
  8. free(methods); 
  9. return methodsArray; 
  10.  

调用一下:


  
  
  1. printMethods(AppDelegate) 

输出结果:

是不是觉得发生了很可怕的事情?该有的都被打印出来了。

你还可以通过试探的方式找出每一个Controller的名字,例如:

insert


  
  
  1. var homeVC= [[[[[UIApplication sharedApplication] keyWindow] subviews] objectAtIndex:0] nextResponder]; 

print


  
  
  1. #"<HomePageTabBarViewController: 0x156cf200>" 

insert


  
  
  1. var page0VC = [homeVC.childViewControllers objectAtIndex:3] 

print


  
  
  1. #"<BaseNavigationController: 0x156decc0>" 

insert


  
  
  1. var meVC = page0VC.topViewController 

print


  
  
  1. var meVC = page0VC.topViewController 

这样,我们就找到了『我的』页面所属Controller。

查看所有的方法:


  
  
  1. printMethods(MeViewController)  

改个标题试试:


  
  
  1. [meVC setCurrentTitle:@"hack you"]; 

效果如下:

试想一下,如果MeViewController中或者LoginViewController中有一个方法叫getUserInfo,那么通过Cycript就可以轻而易举的拿到用户信息。

不过Cycript在这里最主要的作用还是偷窥APP和调试APP。

当然,好玩的方法还有很多。

知道了Cycript的可怕,在有重要信息藏在代码中的时候,我们也得学会如何放置Cycript修改运行时。





本文作者:佚名
来源:51CTO
目录
相关文章
|
JavaScript 前端开发 Java
iOS逆向-day3:Cycript
iOS逆向-day3:Cycript
344 0
iOS逆向-day3:Cycript
|
缓存 JavaScript iOS开发
iOS 逆向编程(十四)Cycript 语法入门
iOS 逆向编程(十四)Cycript 语法入门
196 0
|
缓存 iOS开发
iOS 逆向编程(十七)Cycript 使用对APP实测
iOS 逆向编程(十七)Cycript 使用对APP实测
223 0
|
缓存 JavaScript iOS开发
iOS 逆向编程(十五)Cycript 语法进阶(封装 .cy 脚本文件)
iOS 逆向编程(十五)Cycript 语法进阶(封装 .cy 脚本文件)
189 0
|
监控 JavaScript 前端开发
iOS 逆向编程(十二)Cycript 安装与使用
iOS 逆向编程(十二)Cycript 安装与使用
305 0
|
20天前
|
开发框架 前端开发 Android开发
安卓与iOS开发中的跨平台策略
在移动应用开发的战场上,安卓和iOS两大阵营各据一方。随着技术的演进,跨平台开发框架成为开发者的新宠,旨在实现一次编码、多平台部署的梦想。本文将探讨跨平台开发的优势与挑战,并分享实用的开发技巧,帮助开发者在安卓和iOS的世界中游刃有余。
|
7天前
|
开发框架 Android开发 iOS开发
安卓与iOS开发中的跨平台策略:一次编码,多平台部署
在移动应用开发的广阔天地中,安卓和iOS两大阵营各占一方。随着技术的发展,跨平台开发框架应运而生,它们承诺着“一次编码,到处运行”的便捷。本文将深入探讨跨平台开发的现状、挑战以及未来趋势,同时通过代码示例揭示跨平台工具的实际运用。
|
11天前
|
Java 调度 Android开发
安卓与iOS开发中的线程管理差异解析
在移动应用开发的广阔天地中,安卓和iOS两大平台各自拥有独特的魅力。如同东西方文化的差异,它们在处理多线程任务时也展现出不同的哲学。本文将带你穿梭于这两个平台之间,比较它们在线程管理上的核心理念、实现方式及性能考量,助你成为跨平台的编程高手。
|
13天前
|
存储 前端开发 Swift
探索iOS开发:从新手到专家的旅程
本文将带您领略iOS开发的奇妙之旅,从基础概念的理解到高级技巧的掌握,逐步深入iOS的世界。文章不仅分享技术知识,还鼓励读者在编程之路上保持好奇心和创新精神,实现个人成长与技术突破。
|
16天前
|
安全 IDE Swift
探索iOS开发之旅:从初学者到专家
在这篇文章中,我们将一起踏上iOS开发的旅程,从基础概念的理解到深入掌握核心技术。无论你是编程新手还是希望提升技能的开发者,这里都有你需要的指南和启示。我们将通过实际案例和代码示例,展示如何构建一个功能齐全的iOS应用。准备好了吗?让我们一起开始吧!