Object-c学习之路六(oc字符串文件读写)

//
//  main.m
//  NSString
//
//  Created by WildCat on 13-7-25.
//  Copyright (c) 2013年 wildcat. All rights reserved.
//

#import <Foundation/Foundation.h>

void testCreat(){
    NSString *str=@"你好。";
    NSLog(@"str :%@",str);
    
    NSString *str2=[NSString stringWithUTF8String:"哈哈哈"];
    NSLog(@"str2 :%@",str2);
    NSString *str3=[[NSString alloc] initWithString:@"测试3"] ;
    NSLog(@"str3 :%@",str3);

}
#pragma mark 从文件中获取
void creatWithContent(){

   //设置gb2312编码格式: CFStringConvertEncodingToNSStringEncoding(kCFStringEncodingGB_18030_2000);
    
    NSError *error;
    
    NSString *str=[NSString stringWithContentsOfFile:@"/Users/bird/Desktop/资料/qqq.txt" encoding:CFStringConvertEncodingToNSStringEncoding(kCFStringEncodingGB_18030_2000) error:&error];
    if (error==nil){//如果不为空,说明读去正常
        NSLog(@"文档中获取:%@",str);
    }else{
       NSLog(@"出现错误:%@",error);
    }
    
    //用url读取文件内容:
    NSError *error2;
    NSURL *url=[NSURL URLWithString:@"file:///Users/bird/Downloads/qqq.txt"];
    NSString *str2=[NSString stringWithContentsOfURL:url encoding:NSUTF8StringEncoding error:&error2];
    
        NSLog(@"文档中获取2:%@",str2);
    //获得远程的文件
    NSURL *url3=[NSURL URLWithString:@"http://www.baidu.com"];
    NSString *str3=[NSString stringWithContentsOfURL:url3 encoding:NSUTF8StringEncoding error:nil];
    
    NSLog(@"文档中获取3:%@",str3);
    
}

#pragma mark 写入文件
void writeToFile(){
    //要写入的字符串
    NSString *str3=@"你好吗?";

    NSError *error;
    //写入文件   YES 代表原子性操作  ,也就是会创建一个中间的临时文件
    [str3 writeToFile:@"/Users/bird/Downloads/qqq.txt" atomically:YES encoding:NSUTF8StringEncoding error:&error];
    
    if (error){
        //[error localizedDescription]  会打印出主要的错误信息
        NSLog(@"写入失败:%@",[error localizedDescription]);
    
    }else{
        NSLog(@"写入成功");
    }


}

#pragma mark 主函数
int main(int argc, const char * argv[])
{

    @autoreleasepool {
        
       // testCreat();
       // creatWithContent();
        writeToFile();
    }
    return 0;
}


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
iOS中使用公钥字符串进行RSA加密的步骤如下: 1. 将公钥字符串转换为NSData类型。 ``` NSString *publicKeyString = @"-----BEGIN PUBLIC KEY-----\n...公钥字符串...\n-----END PUBLIC KEY-----"; NSData *publicKeyData = [publicKeyString dataUsingEncoding:NSUTF8StringEncoding]; ``` 2. 创建SecKey对象。 ``` NSMutableDictionary *publicKeyAttributes = [[NSMutableDictionary alloc] init]; [publicKeyAttributes setObject:(__bridge id)kSecAttrKeyTypeRSA forKey:(__bridge id)kSecAttrKeyType]; [publicKeyAttributes setObject:@(2048) forKey:(__bridge id)kSecAttrKeySizeInBits]; [publicKeyAttributes setObject:publicKeyData forKey:(__bridge id)kSecValueData]; [publicKeyAttributes setObject:(__bridge id)kSecAttrKeyClassPublic forKey:(__bridge id)kSecAttrKeyClass]; SecKeyRef publicKey; OSStatus status = SecItemAdd((__bridge CFDictionaryRef)publicKeyAttributes, (CFTypeRef *)&publicKey); ``` 3. 使用SecKey对象进行加密。 ``` NSData *plainData = [@"要加密的数据" dataUsingEncoding:NSUTF8StringEncoding]; size_t cipherBufferSize = SecKeyGetBlockSize(publicKey); uint8_t *cipherBuffer = malloc(cipherBufferSize); memset(cipherBuffer, 0, cipherBufferSize); OSStatus status = SecKeyEncrypt(publicKey, kSecPaddingPKCS1, [plainData bytes], [plainData length], cipherBuffer, &cipherBufferSize); NSData *encryptedData = [NSData dataWithBytesNoCopy:cipherBuffer length:cipherBufferSize]; ``` 4. 释放SecKey对象。 ``` CFRelease(publicKey); ``` 注意:在iOS中使用公钥加密时,需要使用PKCS#1填充模式(kSecPaddingPKCS1)。另外,如果公钥字符串中的换行符不是`\n`,需要将其替换为`\n`。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值