Invia un messaggio SMS con Twilio su iOS
-
27-10-2019 - |
Domanda
Come posso inviare un messaggio SMS programatically da un'applicazione per iPhone? Sto usando Twilio in questo momento, e può correttamente impostare una richiesta HTTP, l'autenticazione con il server e ottenere una risposta.
Ci deve essere qualche errore di configurazione del HTTP intestazioni come posso ottenere una risposta dai server Twilio ma mai passa i dati a destra attraverso.
Il mio codice attuale è in un metodo che si chiama con una semplice pressione del pulsante.
- (IBAction)sendButtonPressed:(id)sender {
NSLog(@"Button pressed.");
NSString *kYourTwillioSID = @"AC8c3...f6da3";
NSString *urlString = [NSString stringWithFormat:@"https://AC8c3...6da3:bf...0b7@api.twilio.com/2010-04-01/Accounts/%@/SMS/Messages", kYourTwillioSID];
NSURL *url = [NSURL URLWithString:urlString];
NSMutableURLRequest *request = [[NSMutableURLRequest alloc] init];
[request setURL:url];
[request setValue:@"+18584334333" forHTTPHeaderField:@"From"];
[request setValue:@"+13063707780" forHTTPHeaderField:@"To"];
[request setValue:@"Hello\n" forHTTPHeaderField:@"Body"];
NSError *error;
NSURLResponse *response;
NSData *urlData=[NSURLConnection sendSynchronousRequest:request returningResponse:&response error:&error];
if (!error) {
NSString *response_details = [[NSString alloc]initWithData:urlData encoding:NSUTF8StringEncoding];
NSLog(@"%@",response_details);
}
NSLog(@"Request finished %@", error);
Soluzione
Se siete solo in cerca di inviare un messaggio SMS in iOS è possibile utilizzare la parte interna MFMessageComposeViewController
del MessageUI.framework
. Come sapete, però, questo richiede interazione con l'utente.
Come avevamo richiesto, è possibile utilizzare Twilio per inviare SMS direttamente utilizzando quasi tutte le piattaforme. Per iOS è possibile utilizzare il seguente codice Swift per colpire l'API Twilio e inviare messaggi di testo che desideri:
func tappedSendButton() {
print("Tapped button")
// Use your own details here
let twilioSID = "AC8c3...6da3"
let twilioSecret = "bf2...b0b7"
let fromNumber = "4152226666"
let toNumber = "4153338888"
let message = "Hey"
// Build the request
let request = NSMutableURLRequest(URL: NSURL(string:"https://\(twilioSID):\(twilioSecret)@api.twilio.com/2010-04-01/Accounts/\(twilioSID)/SMS/Messages")!)
request.HTTPMethod = "POST"
request.HTTPBody = "From=\(fromNumber)&To=\(toNumber)&Body=\(message)".dataUsingEncoding(NSUTF8StringEncoding)
// Build the completion block and send the request
NSURLSession.sharedSession().dataTaskWithRequest(request, completionHandler: { (data, response, error) in
print("Finished")
if let data = data, responseDetails = NSString(data: data, encoding: NSUTF8StringEncoding) {
// Success
print("Response: \(responseDetails)")
} else {
// Failure
print("Error: \(error)")
}
}).resume()
Per ogni ulteriore interazione API è possibile controllare la documentazione ufficiale: https: //www.twilio .com / docs / api / riposare
Altri suggerimenti
Ok, penso che avevo ragione circa le intestazioni.
Ho trovato questa risposta che sembra confermarlo: iOS: come per eseguire una richiesta HTTP POST?
Si deve inviare i dati POST nel corpo della richiesta, non è nelle intestazioni. Twilio sta ottenendo la chiamata HTTP ma i dati POST è vuoto.
Fammi sapere se funziona.
Usa AFNetworking per inviare richiesta.
NSString *kTwilioSID = @"AC73bb270.......4d418cb8";
NSString *kTwilioSecret = @"335199.....9";
NSString *kFromNumber = @"+1......1";
NSString *kToNumber = @"+91.......8";
NSString *kMessage = @"Hi";
NSString *urlString = [NSString
stringWithFormat:@"https://%@:%@@api.twilio.com/2010-04-01/Accounts/%@/SMS/Messages/",
kTwilioSID, kTwilioSecret,kTwilioSID];
NSDictionary*
dic=@{@"From":kFromNumber,@"To":kToNumber,@"Body":kMessage};
__block NSArray* jsonArray;
AFHTTPRequestOperationManager *manager = [AFHTTPRequestOperationManager manager];
manager.responseSerializer=[AFHTTPResponseSerializer serializer];
manager.responseSerializer.acceptableContentTypes=[NSSet setWithObject:@"application/xml"];
[manager POST:urlString parameters:para success:^(AFHTTPRequestOperation *operation, id responseObject)
{
NSError* err;
NSLog(@"success %@",[[NSString alloc] initWithData:responseObject encoding:NSUTF8StringEncoding]);
jsonArray=[NSJSONSerialization JSONObjectWithData:responseObject options:NSJSONReadingAllowFragments
error:&err];
[_del getJsonResponsePOST:jsonArray];
} failure:^(AFHTTPRequestOperation *operation, NSError *error)
{
[_del getError:[NSString stringWithFormat:@"%@",error]];
}];
Potrebbe essere questo:
Il numero + YOURNUMBER è verificato. account di prova non possono inviare messaggi a numeri non verificati; verificare + YOURNUMBER all'indirizzo twilio.com/user/account/phone-numbers/verified, o acquistare un numero di Twilio per inviare messaggi a numeri non verificati.
Twilio con Swift 2.2 + , Alamofire , SwiftyJSON -> risposta:
import Alamofire
import SwiftyJSON
........
........
//twillio config
private static let TWILIO_ACCOUNT_SID = "A...7"
private static let TWILIO_AUTH_TOKEN = "6...5"
//end url string is .json,to get response as JSON
static let URL_TWILIO_SMS = "https://\(TWILIO_ACCOUNT_SID):\(TWILIO_AUTH_TOKEN)@api.twilio.com/2010-04-01/Accounts/\(TWILIO_ACCOUNT_SID)/SMS/Messages.json"
Alamofire.request(.POST, URL_TWILIO_SMS, parameters: ["To":"+880....6","From":"+1...9","Body":"Hellow Rafsun"])
.responseJSON { response in
if let jso = response.result.value {
let json = JSON(jso)
//Twilio response
if let twStatus = json["status"].string,twSentMessage = json["body"].string where twStatus == "queued"{
//Twilio message sent
}else{
//Twilio message not sent
}
}else if let error = response.result.error?.localizedDescription{
//parse error
}
}
Un esempio (aggiornato) per Xcode 8 e Swift 3 .
https://www.twilio.com/blog/2016/11/how-to-send-an-sms-from-ios-in-swift.html
Non è consigliabile memorizzare il vostro lato delle credenziali del client e così gli spettacoli pubblicare come evitare una potenziale vulnerabilità utilizzando un linguaggio lato server di tua scelta e Alamofire per le richieste HTTP:
@IBAction func sendData(sender: AnyObject) {
let headers = [
"Content-Type": "application/x-www-form-urlencoded"
]
let parameters: Parameters = [
"To": phoneNumberField.text ?? "",
"Body": messageField.text ?? ""
]
Alamofire.request("YOUR_NGROK_URL/sms", method: .post, parameters: parameters, headers: headers).response { response in
print(response)
}
}