您的位置:

ios想php服务端传数据,苹果手机搭建php服务器

本文目录一览:

iOS想PHP服务端传数据,怎么加密好?

客户端

每一个请求的URL中加上时间的参数。对url中的参数是排序好的。

然后对这个URL进行MD5。将这个MD5作为最后一个参数(sign)拼接到url最后。

服务端

收到请求后,对去掉最后一个参数的url进行md5。得到的md5和参数中的md5进行匹配。如果匹配成功进行正常返回,如果不成功就500

加密

用AES的。

ios推送消息 用php推送怎么实现

iOS消息推送的工作机制可以简单的用下图来概括:

Provider是指某个iPhone软件的Push服务器,APNS是Apple Push Notification Service的缩写,是苹果的服务器。

上图可以分为三个阶段:

第一阶段:应用程序把要发送的消息、目的iPhone的标识打包,发给APNS。

第二阶段:APNS在自身的已注册Push服务的iPhone列表中,查找有相应标识的iPhone,并把消息发送到iPhone。

第三阶段:iPhone把发来的消息传递给相应的应用程序,并且按照设定弹出Push通知。

1、应用程序注册消息推送。

2、iOS从APNS Server获取device token,应用程序接收device token。

3、应用程序将device token发送给PUSH服务端程序。

4、服务端程序向APNS服务发送消息。

5、APNS服务将消息发送给iPhone应用程序。

无论是iPhone客户端和APNS,还是Provider和APNS,都需要通过证书进行连接。

下面我介绍一下几种用到的证书。

一、CSR文件

1、生成Certificate Signing Request(CSR)

2、填写你的邮箱和常用名称,并选择保存到硬盘。

点击继续:

这样就在本地生成了一个Push.certSigningRequest文件。

二、p12文件

1、导出密钥。

2、输入你的密码。

这样就生成了一个Push.p12文件。

三、SSL certificate文件

1、用你付过费的帐号登录到iOS Provisioning Portal,并新建一个App ID,这个过程可以参考:iOS应用的真机调试,这样就会生成下面这条记录:

2、点击右侧的Configure:

3、点击Development Push SSL Certificate一行后的Configure:

4、点击Continue:

5、选择前面生成好的Push.certSigningRequest文件,点击Generate,出现如下所示的页面:

6、点击Continue:

7、点击Download,并将文件命名为aps_developer_identity.cer。

8、点击Done,你会发现状态变成了Enabled:

到现在为止,我们已经生成了三个文件:

1、Push.certSigningRequest

2、Push.p12

3、aps_developer_identity.cer

双击aps_developer_dientity.cer 注册到你的钥匙串中,这样你的钥匙串中就会有

二、准备profile证书,因为推送消息只能再真机上测试,所以要建一个profile证书

点击"new profile"为上面新建的APP ID建个profile ,成功之后下载*_Dev_Profile.mobileprovision

双击将其加入到xcode 的Provisioning Profiles 中,这里有一点要注意,再将这个加入xcode之前如果之前已经加入过一定要把之前加入的删掉,如果有多个的话会出错。

三、工程代码

到这里证书已经准备完毕,接下来,我们在xcode中新建一个测试工程,注意设置工程的Bundle Identifier必须与上面建的APP ID 里的相同

在didFinishLaunchingWithOptions 中加入一下代码

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions

{

[self.window makeKeyAndVisible];

[[UIApplication sharedApplication] registerForRemoteNotificationTypes: UIRemoteNotificationTypeBadge |UIRemoteNotificationTypeSound | UIRemoteNotificationTypeAlert];

return YES;

}

- (void)application:(UIApplication *)application didRegisterForRemoteNotificationsWithDeviceToken:(NSData *)pToken {

NSLog(@"regisger success:%@", pToken);

//注册成功,将deviceToken保存到应用服务器数据库中

}

- (void)application:(UIApplication *)application didReceiveRemoteNotification:(NSDictionary *)userInfo{

// 处理推送消息

UIAlertView *alert=[[UIAlertView alloc]initWithTitle:@"通知" message:@"我的信息" delegate:selfcancelButtonTitle:@"取消" otherButtonTitles:nil, nil];

[alert show];

[alert release];

NSLog(@"%@", userInfo);

}

- (void)application:(UIApplication *)application didFailToRegisterForRemoteNotificationsWithError:(NSError *)error {

NSLog(@"Regist fail%@",error);

}

到这里一切顺利的话我们就可以在真机运行了,注册成功我们会得到iphone 的deviceToken,

My token is:

四、在应用服务器采用php的方式将消息推送给APNS,

1、php连接APNS也是需要证书的,还记得我们上面获得的几个证书吗?打开终端,对上面的证书做如下处理,

cd 进入证书所在目录

把.cer文件转换成.pem文件:

$ openssl x509 -in aps_developer_identity.cer -inform der

-out PushChatCert.pem

把私钥Push.p12文件转换成.pem文件:

$ openssl pkcs12 -nocerts -out PushChatKey.pem -in Push.p12

Enter Import Password:

MAC verified OK

Enter PEM pass phrase:

Verifying – Enter PEM pass phrase:

你首先需要为.p12文件输入passphrase密码短语,这样OpenSSL可以读它。然后你需要键入一个新的密码短语来加密PEM文件。还是使用”pushchat”来作为PEM的密码短语。你需要选择一些更安全的密码短语。

注意:如果你没有键入一个PEM passphrase,OpenSSL将不会返回一个错误信息,但是产生的.pem文件里面将不会含有私钥。

最后。把私钥和证书整合到一个.pem文件里:

$ cat PushChatCert.pem PushChatKey.pem ck.pem

为了测试证书是否工作,执行下面的命令:

$ telnet gateway.sandbox.push.apple.com 2195

Trying 17.172.232.226…

Connected to gateway.sandbox.push-apple.com.akadns.net.

Escape character is ‘^]’.

它将尝试发送一个规则的,不加密的连接到APNS服务。如果你看到上面的反馈,那说明你的MAC能够到达APNS。按下Ctrl+C 关闭连接。如果得到一个错误信息,那么你需要确保你的防火墙允许2195端口。

然后再次连接,这次用我们的SSL证书和私钥来设置一个安全的连接:

$ openssl s_client -connect gateway.sandbox.push.apple.com:2195

-cert PushChatCert.pem -key PushChatKey.pem

Enter pass phrase for PushChatKey.pem:

你会看到一个完整的输出,让你明白OpenSSL在后台做什么。如果连接是成功的,你可以键入一些字符。当你按下回车后,服务就会断开连接。如果在建立连接时有问题,OpenSSL将会给你一个错误消息,

ck.pem文件就是我们需要得到php连接APNS 的文件,将ck.pem和push.php放入同一目录上传到服务器,push.php的代码如下:

?php

// 这里是我们上面得到的deviceToken,直接复制过来(记得去掉空格)

$deviceToken = '740f4707bebcf74f 9b7c25d4 8e3358945f6aa01da5ddb387462c7eaf 61bb78ad';

// Put your private key's passphrase here:

$passphrase = 'abc123456';

// Put your alert message here:

$message = 'My first push test!';

////////////////////////////////////////////////////////////////////////////////

$ctx = stream_context_create();

stream_context_set_option($ctx, 'ssl', 'local_cert', 'ck.pem');

stream_context_set_option($ctx, 'ssl', 'passphrase', $passphrase);

// Open a connection to the APNS server

//这个为正是的发布地址

//$fp = stream_socket_client(“ssl://gateway.push.apple.com:2195“, $err, $errstr, 60, //STREAM_CLIENT_CONNECT, $ctx);

//这个是沙盒测试地址,发布到appstore后记得修改哦

$fp = stream_socket_client(

'ssl://gateway.sandbox.push.apple.com:2195', $err,

$errstr, 60, STREAM_CLIENT_CONNECT|STREAM_CLIENT_PERSISTENT, $ctx);

if (!$fp)

exit("Failed to connect: $err $errstr" . PHP_EOL);

echo 'Connected to APNS' . PHP_EOL;

// Create the payload body

$body['aps'] = array(

'alert' = $message,

'sound' = 'default'

);

// Encode the payload as JSON

$payload = json_encode($body);

// Build the binary notification

$msg = chr(0) . pack('n', 32) . pack('H*', $deviceToken) . pack('n', strlen($payload)) . $payload;

// Send it to the server

$result = fwrite($fp, $msg, strlen($msg));

if (!$result)

echo 'Message not delivered' . PHP_EOL;

else

echo 'Message successfully delivered' . PHP_EOL;

// Close the connection to the server

fclose($fp);

?

接下来我们访问

iphone就会接收到一条推送消息了,如果有问题的话就检查上面的操作步骤,特别是加红的部分

另外去除标记的方法为,在viewDidApper中加入

int badge = [UIApplication sharedApplication].applicationIconBadgeNumber;

if(badge 0)

{

badge--;

[UIApplication sharedApplication].applicationIconBadgeNumber = badge;

}

如何将格式化的 base64 字符串发送到 PHP 服务器使用 POST 方法,ios

就是输出的字符串宽度为4,不足的会用空格补足。比方说你要输出“12”,但是在输出之前用了这句话就会输出“ 12”。看看下面的文章吧! cin与cout 一:标准输入函数cin 不知道说它是个函数对还是不对,它是代表标准的输入设备--键盘。他是属于流的,他的用法和流的用法是一样的。也就是:cin变量; 小小的说明一下,输入多个变量可以写在一行,如:cinxyz; 这样写不是不允许,而是不好看,如果是不同的变量类型,那就更是没头没脑了。除了你,人家是不知道该输入什么的,所以,一般在输入语句的前面,我们一般都 要做一个提示,请输入×××,让人家心里有个底,知道这个变量是做什么的。 另外,这个函数是不用带地址符号""的,也不用写明变量类型,千万不要跟scanf混淆。当然他就也不检查变量输入是否合法。如: int i; cout"please input a number:" cini; cout"i="iendl; 如果你输入的是一个字符如'a'那么他也不检查,但你输出的结果不是正确的,这要是手工进行检查。当然他也跟scanf一样,如果在循环内部输入不合法的变量值,那么也将陷入死循环。如下: /*一个输入不合法变量陷入死循环的例子*/ #include iostream.h main() { int i; while(i!=-1) { cout"i=" cini; /*请输入不是一个字符如'a'试试*/ coutendl; } } 如上一个程序,如果你输入的不合法,那就将陷入死循环。解决的办法有个一,把cini;语句移到判断循环的语句中,那么,你输入的如果是不合法的变量,他将跳出循环。 cin是用空格来分隔输入的。请看看如下的例子: /*一个空格分隔使输入的变量达不到希望的值*/ #include iostream.h main() { char str[20]; cout"please input a string:"; cinstr; /*你试着输入"hello word"*/ coutendl"str="str; } 看得到是什么结果呢?得到的仅仅是str=hello,为什么呢?因为cin是以空格为分隔的,当你输入一个空格时,那他就认为后面的输入不属于这里了, 认为应该给后面的变量了。另外,当你输入的字符串大于分配的空间时,还会出现溢出现象。当然,还有整行输入的函数,包括空格也一起输入了,以后也会学到。 二、标准输出函数cout 说cout是函数,也跟cin一样,不知道对不对。他代表的是标准输出设备--显示器。其实前面已经用过很多次这个函数了。我们就通过一个例子来进行格式化的输出就是了,大家就体会体会这个例子就行了,比printf灵活了很多。 首先,我们可以按16进制,8进制和10进制来显示我们的数据,如下: /*一个按进制输出的例子*/ #includeiostream.h void main() { int x=30, y=300, z=1024; coutx' 'y' 'zendl; //按十进制输出 cout.setf(ios::showbase ios::uppercase); //设置基指示符输出和数值中的字母大写输出 coutx' 'y' 'zendl; cout.unsetf(ios::showbase ios::uppercase); //取消基指示符输出和数值中的字母大写输出 cout.setf(ios::oct); //设置为八进制输出,此设置不取消一直有效 coutx' 'y' 'zendl; //按八进制输出 cout.setf(ios::showbase ios::uppercase); //设置基指示符输出和数值中的字母大写输出 coutx' 'y' 'zendl; cout.unsetf(ios::showbase ios::uppercase); //取消基指示符输出和数值中的字母大写输出 cout.unsetf(ios::oct); //取消八进制输出设置,恢复按十进制输出 cout.setf(ios::hex); //设置为十六进制输出 coutx' 'y' 'zendl; cout.setf(ios::showbase ios::uppercase); //设置基指示符输出和数值中的字母大写输出 coutx' 'y' 'zendl; cout.unsetf(ios::showbase ios::uppercase); //取消基指示符输出和数值中的字母大写输出 cout.unsetf(ios::hex); //取消十六进制输出设置,恢复按十进制输出 coutx' 'y' 'zendl; } 我们用cout.setf()设置输出的格式,用cout.unsetf()取消格式。可以看出10进制在输出的时候不管有没有设置基指示符ios:: showbase,都没用,8进制再输出的时候在前面加0,而16进制是在前面加0X。而对于数值中字母大写输出,只对16进制有用,以后我们就应该看情 况使用了。当然,我们前面已经说了,还有一种方法也可以实现格式化输出,那就是使用操纵算子,如下, /*一个按进制输出的例子*/ #includeiomanip.h void main() { int x=30, y=300, z=1024; coutx' 'y' 'zendl; //按十进制输出 coutoctx' 'y' 'zendl; //按八进制输出 coutsetiosflags(ios::showbase); //设置基指示符 coutx' 'y' 'zendl; //仍按八进制输出 coutresetiosflags(ios::showbase); //取消基指示符 couthexx' 'y' 'zendl; //按十六进制输出 coutsetiosflags(ios::showbase ios::uppercase); //设置基指示符和数值中的字母大写输出, coutx' 'y' 'zendl; //仍按十六进制输出 coutresetiosflags(ios::showbase ios::uppercase); //取消基指示符和数值中的字母大写输出 coutx' 'y' 'zendl; //仍按十六进制输出 coutdecx' 'y' 'zendl; //按十进制输出 } 我们用以上的程序也可以输出同样的结果,可见他的灵活。我们现在输出下列一段文字: 第一章 1.1 什么是C语言...........................1 1.11 C语言的历史..........................58 第二章 方法很多种啦,我们可以这样写: /*一个使用填充,宽度,对齐方式的例子*/ #include iostream.h void main() { cout"第一章"endl; cout" "; cout.setf(ios::left); //设置对齐方式为left cout.width(7); //设置宽度为7,不足用空格填充 cout"1.1"; cout"什么是C语言"; cout.unsetf(ios::left); //取消对齐方式,用缺省right方式 cout.fill('.'); //设置填充方式 cout.width(30); //设置宽度,只对下条输出有用 cout1endl; cout" "; cout.width(7); //设置宽度 cout.setf(ios::left); //设置对齐方式为left cout.fill(' '); //设置填充,缺省为空格 cout"1.11"; cout"C语言的历史"; cout.unsetf(ios::left); //取消对齐方式 cout.fill('.'); cout.width(30); cout58endl; cout.fill(' '); cout"第二章"endl; } 我们多次设置了宽度,为的是使我们的间距能一致,也使用了对齐方式,为的是使我们的数据能对齐显示,看起来美观。我们还使用了填充方式。我们下面用操纵算子来实现也是可以的。 /*一个使用填充,宽度,对齐方式的例子*/ #include iomanip.h void main() { cout"第一章"endl; cout" "; coutsetiosflags(ios::left)setw(7); //设置宽度为7,left对齐方式 cout"1.1"; cout"什么是C语言"; coutresetiosflags(ios::left); //取消对齐方式 coutsetfill('.')setw(30)1endl; //宽度为30,填充为'.'输出 coutsetfill(' '); //恢复填充为空格 cout" "; coutsetw(7)setiosflags(ios::left); //设置宽度为7,left对齐方式 cout"1.11"; cout"C语言的历史"; coutresetiosflags(ios::left); //取消对齐方式 coutsetfill('.')setw(30)58endl; //宽度为30,填充为'.'输出 coutsetfill(' ')"第二章"endl; } 我们输出了同样的效果,不过依我的性格,我更喜欢用操纵算子来进行格式化输出。最后我们看看浮点数的格式输出,如下例: /*关于浮点数的格式*/ #include iostream.h void main() { float f=2.0/3.0,f1=0.000000001,f2=-9.9; coutf' 'f1' 'f2endl; //正常输出 cout.setf(ios::showpos); //强制在正数前加+号 coutf' 'f1' 'f2endl; cout.unsetf(ios::showpos); //取消正数前加+号 cout.setf(ios::showpoint); //强制显示小数点后的无效0 coutf' 'f1' 'f2endl; cout.unsetf(ios::showpoint); //取消显示小数点后的无效0 cout.setf(ios::scientific); //科学记数法 coutf' 'f1' 'f2endl; cout.unsetf(ios::scientific); //取消科学记数法 cout.setf(ios::fixed); //按点输出显示 coutf' 'f1' 'f2endl; cout.unsetf(ios::fixed); //取消按点输出显示 cout.precision(18); //精度为18,正常为6 coutf' 'f1' 'f2endl; cout.precision(6); //精度恢复为6 } 同样,我们也一样能用操纵算子实现同样的功能: /*关于浮点数的格式*/ #include iomanip.h void main() { float f=2.0/3.0,f1=0.000000001,f2=-9.9; coutf' 'f1' 'f2endl; //正常输出 coutsetiosflags(ios::showpos); //强制在正数前加+号 coutf' 'f1' 'f2endl; coutresetiosflags(ios::showpos); //取消正数前加+号 coutsetiosflags(ios::showpoint); //强制显示小数点后的无效0 coutf' 'f1' 'f2endl; coutresetiosflags(ios::showpoint); //取消显示小数点后的无效0 coutsetiosflags(ios::scientific); //科学记数法 coutf' 'f1' 'f2endl; coutresetiosflags(ios::scientific); //取消科学记数法 coutsetiosflags(ios::fixed); //按点输出显示 coutf' 'f1' 'f2endl; coutresetiosflags(ios::fixed); //取消按点输出显示 coutsetprecision(18); //精度为18,正常为6 coutf' 'f1' 'f2endl; coutsetprecision(6); //精度恢复为6 } 在c/c++系统中除了标准的输入输出外,还提供了更多的输入函数。这写函数主要有getch(),getche(), getchar (),cin.get(),putch(),putchar(),cout.put(),gets(),cin.getline(),puts()。另外 还有些为了让缓冲区不影响程序的正确操作的缓冲去的操作,如:cin.putback(),fflush(stdin),cout.flush().我们 做一下简单的说明。 1、getch()和getche(),非缓冲式输入,从键盘读入一个字符。getch()读入字符不显示。有conio.h支持。 2、cin.get(),getchar(),缓冲式输入,从键盘读入一个字符,并显示。getchar()由stdio.h支持,cin.get()由iostream.h支持。 3、putch()和putchar(),非缓冲式输出,输出一个字符到显示器。putch()由conio.h支持,putchar()由stdio.h支持。 4、cout.put(),缓冲式输出,输出一个字符到显示器。由iostream.h支持。 5、gets()和cin.geline(),缓冲式输入,读入一字符串(包括空格,不包括最后的回车),gets()由stdio.h支持,cin.getline()由iostream.h支持。 6、puts(),非缓冲输出,输出一个字符串,由stdio.h支持。 7、cin.putback(),把一个字符送回输入缓冲区。 8、fflush(stdin),清除输入缓冲区操作。无法清除cin.get()等带来的操作。 9、cout.flush(),清楚输出缓冲区。 在这里我们稍微说一下输入/输出缓冲区,这是为了减少程序访问io带来中断而设的一段空间。当程序满足某个刷新条件时,那就将清理缓冲区。具体条件为: 1、输入缓冲区 a,程序要求输入时,按下了回车键。 b,遇到程序结束。 c,遇到下一条输入语句。 d,遇到清除缓冲区操作 e,缓冲区溢出 2、输出缓冲区 a,输出缓冲区溢出 b,遇到下一条输入语句 c,使用刷新缓冲区迫使清除 d,程序结束。 缓冲区操作有时会带来程序的不正确的输入,如前面说的scanf(),在连续输入的时候,会把一个回车赋给下一个字符变量。我们操作的时候一定要注意。

IOS上传图片,将NSData提交给PHP接口

上传的是图片,你用文字编辑器打开当然不行!

你想传给PHP接口,有两种途径:

将上传图片的路径传过去

将图片的base 64编码传过去