2016年2月

swift使用cookie

//
//  ViewController.swift
//  加密
//
//  Created by admin on 16/2/27.
//  Copyright © 2016年 jin. All rights reserved.
//

import UIKit

class ViewController: UIViewController {
    override func viewDidLoad() {
        super.viewDidLoad()
    }
    // 发送下请求,服务器那边有写cookie的代码
    @IBAction func sendRequest(sender: AnyObject) {
        let url = NSURL(string: "http://test.com/login2.php")
        let request = NSMutableURLRequest(URL: url!, cachePolicy: NSURLRequestCachePolicy.ReloadIgnoringCacheData, timeoutInterval: 10)
        let postData = "username=zhangsan&password=zhang"
        request.HTTPMethod = "post"
//        request.HTTPBody = postData.dataUsingEncoding(NSUTF8StringEncoding)
        // 请求会自动带上cookie
        NSURLConnection.sendAsynchronousRequest(request, queue: NSOperationQueue()) { (response:NSURLResponse?, data:NSData?, error:NSError?) -> Void in
            print(try? NSJSONSerialization.JSONObjectWithData(data!, options: NSJSONReadingOptions.AllowFragments))
        }
    }
    @IBAction func readCookie(sender: AnyObject) {
        // 第一次读取是没有任何输出的,发送请求之后久能取到下面的值了,因为服务器设置了cookie
        for cookie in NSHTTPCookieStorage.sharedHTTPCookieStorage().cookies!
        {
            if(cookie.name == "userName")
            {
                print("用户名为\(cookie.value)")
            }
            if(cookie.name == "userPassword")
            {
                print("密码为\(cookie.value)")
            }
        }
    }
}

swift数据加密

//
//  ViewController.swift
//  加密
//
//  Created by admin on 16/2/27.
//  Copyright © 2016年 jin. All rights reserved.
//

import UIKit

class ViewController: UIViewController,UIPickerViewDelegate,UIPickerViewDataSource {
    @IBOutlet weak var picker: UIPickerView!
    @IBOutlet weak var textField: UITextField!
    @IBOutlet weak var message: UILabel!
    @IBOutlet weak var keyText: UITextField!
    @IBOutlet weak var valueText: UITextField!

    let encodeArr = ["sha1","md5","hmacMD5StringWithKey"]
    let key = "jin"
    override func viewDidLoad() {
        super.viewDidLoad()
    }
    // 设备标识,存钥匙串数据的时候需要标识,这里取的时候用到了第三方库SSKeychain
    let service = "keyChainTest"
    @IBAction func saveKeyChain(sender: AnyObject) {
        // 设置钥匙串
        SSKeychain.setPassword(self.valueText.text, forService: self.service, account: self.keyText.text)
    }
    @IBAction func readKeyChain(sender: AnyObject) {
        // 打印所有钥匙串
        print(SSKeychain.allAccounts())
        // 取出钥匙串
        let content = SSKeychain.passwordForService(self.service, account: self.keyText.text)
        self.message.text = content
    }
    // 对数据进行编码,这里需要用到第三方类库
    @IBAction func encode(sender: AnyObject) {
        let str:NSString = self.textField.text!
        var encodeString = ""
        switch self.picker.selectedRowInComponent(0)
        {
        case 0:
            encodeString = str.sha1String()
            break
        case 1:
            encodeString = str.md5String()
        case 2:
            encodeString = str.hmacMD5StringWithKey(self.key)
            break
        default:
            break
        }
        self.message.text = encodeString
    }
    // 设置pickerView分组数量
    func numberOfComponentsInPickerView(pickerView: UIPickerView) -> Int {
        return 1
    }
    // 设置pickerView分组行数
    func pickerView(pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int {
        return self.encodeArr.count
    }
    // 返回分组标题
    func pickerView(pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? {
        return self.encodeArr[row]
    }
}

php使用curl发送post请求发生错误,记录下

php代码如下

$url = "xxxxxx";

$curl = curl_init();
curl_setopt($curl,CURLOPT_URL,$url);
curl_setopt($curl,CURLOPT_RETURNTRANSFER,1);
curl_setopt($curl, CURLOPT_TIMEOUT,30);   //只需要设置一个秒的数量就可以

$data = http_build_query(array('url_content'=>$urlData['url_id']));//转换成键值对的形
$cookie_file = "./google.txt"; //cookie存放地址
//设置时区
date_default_timezone_set('PRC');
curl_setopt($curl,CURLOPT_COOKIESESSION,1);
curl_setopt($curl,CURLOPT_COOKIEFILE,$cookie_file);
curl_setopt($curl,CURLOPT_COOKIEJAR,$cookie_file);
curl_setopt($curl,CURLOPT_COOKIE,session_name() . '=' . session_id());
curl_setopt($curl,CURLOPT_FOLLOWLOCATION,1);
curl_setopt($curl,CURLOPT_POST,1);
curl_setopt($curl, CURLOPT_POSTFIELDS, $data);//要发送的数据
curl_setopt($curl,CURLOPT_HTTPHEADER,array("application/x-www-form-urlencoded;charset=utf-8","Content-length:".strlen($data)));//http
$OutPut = curl_exec($curl);//

这个请求的网址是当前主机下的另外一个文件,程序使用的是ThinkPHP,请求执行会失败,错误号 28 ,对应的错误是 CURLE_OPERATION_TIMEDOUT,查看错误日志发现是 ThinkPHP session()函数的下面一行报错

// 启动session
if(C('SESSION_AUTO_START'))  session_start();

在if上面添加了

file_put_contents("./curl.text","1",FILE_APPEND);

发现重复调用了很多次,把curl代码中设置cookie的四句代码去掉久ok了,先不调试了,之后有时间再来弄明白

base加密解密

//
//  ViewController.swift
//  base64
//
//  Created by zhang on 16/2/26.
//  Copyright © 2016年 jin. All rights reserved.
//

import UIKit

class ViewController: UIViewController {

    @IBOutlet weak var name: UITextField!
    @IBOutlet weak var password: UITextField!
    @IBOutlet weak var messageLable: UILabel!
    override func viewDidLoad() {
        super.viewDidLoad()
        let userDefault = NSUserDefaults.standardUserDefaults()
        let userName = userDefault.valueForKey("username")
        print(userName)
        if userName != nil
        {
            self.name.text = self.decode(userName as! String)
            let password = userDefault.valueForKey("password")
            self.password.text = self.decode(password as! String)
        }
    }

    @IBAction func login(sender: AnyObject) {
        let username = self.name.text
        let password = self.password.text
        let url = NSURL(string: "http://localhost/login.php")
        let request = NSMutableURLRequest(URL: url!, cachePolicy: NSURLRequestCachePolicy.ReloadIgnoringCacheData, timeoutInterval: 10)
        request.HTTPMethod = "post"
        let dataString = "username=\(self.encode(username!))&password=\(self.encode(password!))"
        print(dataString)
        request.HTTPBody = dataString.dataUsingEncoding(NSUTF8StringEncoding)
        NSURLConnection.sendAsynchronousRequest(request, queue: NSOperationQueue()) { (response:NSURLResponse?, data:NSData?, error:NSError?) -> Void in
            let json:AnyObject? = try? NSJSONSerialization.JSONObjectWithData(data!, options: NSJSONReadingOptions.AllowFragments)
            let userId:Int! = json?.valueForKey("userId") as! Int
            var str = ""
            if userId != nil && userId > 0
            {
                str = "登陆成功"
                let userDefault = NSUserDefaults.standardUserDefaults()
                userDefault.setObject(self.encode(username!), forKey: "username")
                userDefault.setObject(self.encode(password!), forKey: "password")
                userDefault.synchronize()
            }
            else
            {
                str = "登陆失败"
            }
            NSOperationQueue.mainQueue().addOperationWithBlock({ [weak self,str] () -> Void in
                self!.messageLable.text = str
            })
        }
    }
    func encode(str:String)->String
    {
        // 字符串转换成d
        let data = str.dataUsingEncoding(NSUTF8StringEncoding)
        let encodeStr = data?.base64EncodedStringWithOptions(NSDataBase64EncodingOptions.Encoding64CharacterLineLength)
        return encodeStr!
    }
    func decode(str:String)->String
    {
        let decode = NSData(base64EncodedString: str, options: NSDataBase64DecodingOptions.IgnoreUnknownCharacters)
        return String(data: decode!, encoding: NSUTF8StringEncoding)!
    }
}

swift直接传输json字串

客户端

//
//  ViewController.swift
//  http请求
//
//  Created by admin on 16/2/26.
//  Copyright © 2016年 jin. All rights reserved.
//

import UIKit

class ViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()
        self.sendJSON()
    }
    func sendJSON()
    {
        let urlStr = "http://test.com/postjson.php"
        let url = NSURL(string: urlStr.stringByAddingPercentEscapesUsingEncoding(NSUTF8StringEncoding)!)
        let request = NSMutableURLRequest(URL: url!, cachePolicy: NSURLRequestCachePolicy.ReloadIgnoringCacheData, timeoutInterval: 10)
        let jsonData = ["name":"jin","age":18]
        // 检查数据类型是否能转换成json
        if NSJSONSerialization.isValidJSONObject(jsonData) == false
        {
            print("格式错误")
            exit(1)
        }
        let sendData = try? NSJSONSerialization.dataWithJSONObject(jsonData, options: NSJSONWritingOptions.PrettyPrinted)
        // 设置类型以及数据
        request.HTTPMethod = "post"
        request.HTTPBody = sendData
        NSURLConnection.sendAsynchronousRequest(request, queue: NSOperationQueue()) { (response:NSURLResponse?, data:NSData?, error:NSError?) -> Void in
            let jsonData:AnyObject? = try? NSJSONSerialization.JSONObjectWithData(data!, options: NSJSONReadingOptions.MutableContainers)
            print(jsonData)
        }
    }
}

服务器

header('Content-Type:text/plain;charset=utf-8');

$json = file_get_contents('php://input');
// 反序列化JSON
$obj = json_decode($json, TRUE ); 

// 打印对象明细信息
echo json_encode($obj);