从PHP脚本发送短信

时间:2016-11-30 07:17:23

标签: php sms

我使用PHP脚本通过我的短信api发送消息。 短信正在发送成功,但我的消息中出现了问题。 仅剩下“ThankYou”消息的Php脚本不会出现在移动设备上。

 $message1="ThankYou '$email' you are succesfully booked your service.Your booking details Booking Date = '$date'Booking Location='$location'";

我的PHP脚本:

  <?php

 require 'PHPMailer/PHPMailerAutoload.php';
 require "init.php";
  $email=$_POST['email']; 
  $bikeno=$_POST['bikeno'];
  $location=$_POST['location'];
  $date=$_POST['date'];
  $mobileno=$_POST['mobileno'];
   $sql="select * from book_order where location ='".$location."' and date ='".$date."';";
  $result=mysqli_query($con,$sql);
  $response =array();
  if(mysqli_num_rows($result)>=20)
    {
   $code="reg_failed";
   $message="Sorry For that Selected Date or Service Centre Is also Booked try with another Date or Service centre";
array_push($response,array("code"=>$code,"message"=>$message));
echo json_encode($response);    
     }
   else {
$sql="insert into book_order(email,bikeno,location,date,mobileno) values ('".$email."','".$bikeno."','".$location."','".$date."','".$mobileno."');";
$result=mysqli_query($con,$sql);
$code="reg_success";
$message="Thanks for choose use for serve you better.";
array_push($response,array("code"=>$code, "message"=>$message));
echo json_encode($response);
  if($sql)
{   
$message1="ThankYou '$email' you are succesfully booked your service.Your         booking details Booking Date = '$date'Booking Location='$location'";


   $URL = "http://ptms.bulksmshyderabad.in/API/sms.php?username=xxxx&password=xxxx&from=YAMAHA&to=$mobileno&msg=$message1&type=1&dnd_check=0";
    $ch = curl_init();


curl_setopt($ch, CURLOPT_URL, $URL);
curl_setopt($ch, CURLOPT_POSTFIELDS, $post_fields);
 curl_setopt($ch, CURLOPT_RETURNTRANSFER, true);

    $result=curl_exec($ch);


   }    

  }


  mysqli_close($con);
    ?>

3 个答案:

答案 0 :(得分:1)

网址中包含无效字符(即')。 SMS服务器无法正确解析您的SMS消息。使用下面的代码使查询字符串对GET请求安全/有效。

$message1 = "..."; // Your original message
$safeMessage = urlencode($message1);

当然,在为$safeMessage分配值时,您需要使用$URL

附加说明:

  • 请考虑从问题中删除您的敏感凭证,即网址中的真实用户名和密码。
  • 您的curl请求正在形成POST请求,但GET请求似乎已足够,因为API可以从网址获取所有信息。

答案 1 :(得分:0)

我假设您已经使用上述设置从msg91获得了sms服务,或者可以使用Twilio,Nexmo等任何sms服务提供商。现在,我正在创建一个通用函数,您可以在PHP代码中的任意位置调用该函数以发送任何类型短信

timestamp: any;

this.HeroService.getPublicHero()
.subscribe(hero => {
    this.timestamp = hero.yourtimestampcoulmnname,
});

有关更多详细信息: https://www.lelocode.com/posts/sending-sms-like-otp,-welcome-message,mobile-verification-using-php---lelocode

答案 2 :(得分:0)

http POST API用于发送短信。这里使用了simplexml_load_file()函数来执行该过程。


    $to="88".$this->mobile_no; //Country code concatenation
    $gsm =$to; // Formed as ISD number 
    $msg ="Thank you"; //SMS content that will be sent
    $user = 'úsername'; // API username
    $password = 'password'; //API password
    $sender =sender; // i.e.: 880155911456 or Sender id might be alfanumeric for masking
    $url = "http://api.olineit.com/api/v3/sendsms/plain?user=$user&password=$password&sender=$sender&SMSText=$msg&GSM=$gsm&"; //http REST API url
    $smsResult = simplexml_load_file($url); // Function called and parameter passed.