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];

;

;

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編碼傳過去

原創文章,作者:XEGF,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/131651.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
XEGF的頭像XEGF
上一篇 2024-10-03 23:46
下一篇 2024-10-03 23:46

相關推薦

  • Python讀取CSV數據畫散點圖

    本文將從以下方面詳細闡述Python讀取CSV文件並畫出散點圖的方法: 一、CSV文件介紹 CSV(Comma-Separated Values)即逗號分隔值,是一種存儲表格數據的…

    編程 2025-04-29
  • Python中讀入csv文件數據的方法用法介紹

    csv是一種常見的數據格式,通常用於存儲小型數據集。Python作為一種廣泛流行的編程語言,內置了許多操作csv文件的庫。本文將從多個方面詳細介紹Python讀入csv文件的方法。…

    編程 2025-04-29
  • 如何用Python統計列表中各數據的方差和標準差

    本文將從多個方面闡述如何使用Python統計列表中各數據的方差和標準差, 並給出詳細的代碼示例。 一、什麼是方差和標準差 方差是衡量數據變異程度的統計指標,它是每個數據值和該數據值…

    編程 2025-04-29
  • Python多線程讀取數據

    本文將詳細介紹多線程讀取數據在Python中的實現方法以及相關知識點。 一、線程和多線程 線程是操作系統調度的最小單位。單線程程序只有一個線程,按照程序從上到下的順序逐行執行。而多…

    編程 2025-04-29
  • Python爬取公交數據

    本文將從以下幾個方面詳細闡述python爬取公交數據的方法: 一、準備工作 1、安裝相關庫 import requests from bs4 import BeautifulSou…

    編程 2025-04-29
  • Python兩張表數據匹配

    本篇文章將詳細闡述如何使用Python將兩張表格中的數據匹配。以下是具體的解決方法。 一、數據匹配的概念 在生活和工作中,我們常常需要對多組數據進行比對和匹配。在數據量較小的情況下…

    編程 2025-04-29
  • 服務器安裝Python的完整指南

    本文將為您提供服務器安裝Python的完整指南。無論您是一位新手還是經驗豐富的開發者,您都可以通過本文輕鬆地完成Python的安裝過程。以下是本文的具體內容: 一、下載Python…

    編程 2025-04-29
  • Python數據標準差標準化

    本文將為大家詳細講述Python中的數據標準差標準化,以及涉及到的相關知識。 一、什麼是數據標準差標準化 數據標準差標準化是數據處理中的一種方法,通過對數據進行標準差標準化可以將不…

    編程 2025-04-29
  • STUN 服務器

    STUN 服務器是一個網絡服務器,可以協助網絡設備(例如 VoIP 設備)解決 NAT 穿透、防火牆等問題,使得設備可以正常地進行數據傳輸。本文將從多個方面對 STUN 服務器做詳…

    編程 2025-04-29
  • 如何使用Python讀取CSV數據

    在數據分析、數據挖掘和機器學習等領域,CSV文件是一種非常常見的文件格式。Python作為一種廣泛使用的編程語言,也提供了方便易用的CSV讀取庫。本文將介紹如何使用Python讀取…

    編程 2025-04-29

發表回復

登錄後才能評論