UIAlertController* alertVC = [UIAlertController alertControllerWithTitle:nil message:nil preferredStyle:UIAlertControllerStyleActionSheet];
Title:nil message:nil 标题和信息都设为 nil 不能设置为 @“” 这样还是会出现空白的标题
Paste_Image.png
删除字符串指定位置的字符,返回剩余的字符
deleteCharactersInRange:NSMakeRange(1,2); 删除字符串 第二位置往后2个长度的字符串。
-(NSString *)getAddress
{
char iphone_ip[255];
strcpy(iphone_ip,"127.0.0.1"); // if everything fails
NSHost* myhost =[NSHost currentHost];
if (myhost)
{
NSString *ad = [myhost address];
if (ad)
strcpy(iphone_ip,[ad cStringUsingEncoding:NSASCIIStringEncoding]);
}
return [NSString stringWithFormat:@"%s",iphone_ip];
}
本机号码要是用户设置了可以获得:
[[NSUserDefaults standardUserDefaults] valueForKey:@"SBFormattedPhoneNumber"];
iPhone应用的发布是通过iTunes,用户下载之后会对程序产生一个对应你iTunes帐号的签名。而破解,正是需要去掉这个签名,让它可以安装在 每一个帐号上。但是安装过程还是需要欺骗iTunes,告诉它这个程序是已经签名了的。 这个破解的签名在哪里呢?对了,就是每个应用或游戏下的Info.plist文件,如果你下载过破解的 iPhone应用来研究。就会发现所有的破解程序都有这个一个键值:
SignerIdentity Apple iPhone OS Application Signing
那么保护破解最简单的入手点就是针对这个地方了。 打开xcode,在你需要检测破解的地方添加以下代码:
NSBundle *bundle = [NSBundle mainBundle];
NSDictionary *info = [bundle infoDictionary];
if ([info objectForKey: @"SignerIdentity"] != nil)
{
//你的代码
}
#以上代码读取info.plist,如果发现了SignerIdentity的键,就执行你的代码。
- (IBAction)closeApplication:(id)sender
{
UIApplication *application = [UIApplication sharedApplication];
if([application respondsToSelector:@selector(terminateWithSuccess)])
{
[application performSelector:@selector(terminateWithSuccess)];
}
}
在开发中会遇到应用需要记录设备标示,即使应用卸载后再安装也可重新识别的情况,在这写一种实现方式——读取设备的UUID(Universally Unique Identifier)并通过KeyChain(钥匙串)记录。
使用 cellForRowAtIndexPath ??,对不起这个方法只能获取到可视的Cell,就是说,这个方法只能获取到出现了的Cell,对于没有出现的Cell,你是获取不到的
解决方法:使用CellModel,不管是获取到Cell上的数据、状态,还是对Cell的操作,都可以实现。