All Projects → ZhukMax → smsc

ZhukMax / smsc

Licence: Apache-2.0 license
Lib for modern integration smsc.ru service

Programming Languages

PHP
23972 projects - #3 most used programming language

Projects that are alternatives of or similar to smsc

smscenter
Класс для работы с сервисом smsc.ru (SMS-Центр)
Stars: ✭ 42 (+55.56%)
Mutual labels:  sms-api, smsc
sms blitz
Send SMS messages through multiple different providers
Stars: ✭ 29 (+7.41%)
Mutual labels:  sms-api
africastalking.Net
Africa's Talking API Wrapper for C#
Stars: ✭ 16 (-40.74%)
Mutual labels:  sms-api
pindo-cli
A simple Command Line Interface that allows you to authenticate with the Pindo API.
Stars: ✭ 32 (+18.52%)
Mutual labels:  sms-api
Textbelt
Free API for outgoing SMS
Stars: ✭ 2,305 (+8437.04%)
Mutual labels:  sms-api
sms
Simple SMS Gateway Package for sending short text messages from your Application. Facade for Laravel 5(Updated to work with Laravel 5.5).Currently supported Gateways Clickatell, MVaayoo, Gupshup, SmsAchariya, SmsCountry, SmsLane, Nexmo, Mocker / Any HTTP/s based Gateways are supported by Custom Gateway. Log gateway can be used for testing.
Stars: ✭ 41 (+51.85%)
Mutual labels:  sms-api
docs
blaulichtSMS API (Schnittstellenbeschreibung)
Stars: ✭ 15 (-44.44%)
Mutual labels:  sms-api
jasmin-web-panel
📨 Jasmin Web Panel for Jasmin SMS Gateway
Stars: ✭ 33 (+22.22%)
Mutual labels:  sms-api
laravel-sms-api
Laravel package to provide SMS API integration.
Stars: ✭ 84 (+211.11%)
Mutual labels:  sms-api
messages-web
📱 SMS gateway using your own phone!
Stars: ✭ 34 (+25.93%)
Mutual labels:  sms-api
library-netgsmapi
🇹🇷 With Netgsm Api Library, you can send a message or voice message to an your customers or members.
Stars: ✭ 18 (-33.33%)
Mutual labels:  sms-api
project-tracking-system-backend-app
Enterprise project tracker, tracks commits done by employees after getting assigned to a couple of projects by their managers
Stars: ✭ 62 (+129.63%)
Mutual labels:  sms-api
sms-spring-boot-project
短信服务Spring Boot Starter ,目前支持腾讯、阿里、赛邮和云之讯短信服务,腾讯、阿里、赛邮和云之讯短信均已验证,期待各位小伙伴合作完善这个项目
Stars: ✭ 79 (+192.59%)
Mutual labels:  sms-api
smpp.net
Short Message Peer-to-Peer (SMPP) .NET library
Stars: ✭ 29 (+7.41%)
Mutual labels:  smsc
ucp
UCP protocol in Go
Stars: ✭ 40 (+48.15%)
Mutual labels:  smsc
smsc
Flexible and scalable GSM Short Message Center (SMSC)
Stars: ✭ 23 (-14.81%)
Mutual labels:  smsc

Smsc API

Latest Version on Packagist Software License Total Downloads

Компонент для интеграции сервиса SMSC.RU API (smsc.ru) на сайт. Основано на версии 3.6 официального кода.

Установка

С помощью композера:

$ composer require zhukmax/smsc

Использование

Для того, что бы правильно отлавливать Исключения желательно использовать в конструкции try\catch. Не обязательно использовать выход exit(), можно эхом вывести текст ошибки и продолжить выполнение скрипта.

<?php
try {
    $sms = new \Zhukmax\Smsc\Api(
        'test',
        '123',
        [
            'https' => true,
            'charset' => 'windows-1251',
            'from' => '[email protected]',
            'post' => true,
            'debug' => '/home/user/smsc.log'
        ]
    );
} catch (Exception $exception) {
    exit($exception->getMessage());
}

Так же можно унаследовать класс \Zhukmax\Smsc\Api и добавить собственное поведение до/после выполнения методов компонента или, даже, переназначить некоторые из них.

<?php
class Sms extends \Zhukmax\Smsc\Api
{
    public function balance()
    {
        var_dump($this->sendCmd('balance'));
    }
}

Свойства конструктора

  • логин клиента
  • пароль или MD5-хеш пароля в нижнем регистре
  • Массив с опциями:
    • protocol - использовать HTTPS протокол, любое значение кроме 'https' приравнивается использованию не защищенного протокола HTTP
    • charset - кодировка сообщения: utf-8 (по умолчанию), koi8-r или windows-1251
    • from - e-mail адрес отправителя
    • post - использовать метод POST, булев
    • debug - флаг отладки, булев

Методы

Публичные методы:

sendSms() - Функция отправки SMS

  • обязательные параметры:

    • $phones - список телефонов через запятую или точку с запятой
    • $message - отправляемое сообщение
  • необязательные параметры:

    • $translit - переводить или нет в транслит (1,2 или 0)
    • $time - необходимое время доставки в виде строки (DDMMYYhhmm, h1-h2, 0ts, +m)
    • $id - идентификатор сообщения. Представляет собой 32-битное число в диапазоне от 1 до 2147483647.
    • $format - формат сообщения (0 - обычное sms, 1 - flash-sms, 2 - wap-push, 3 - hlr, 4 - bin, 5 - bin-hex, 6 - ping-sms, 7 - mms, 8 - mail, 9 - call)
    • $sender - имя отправителя (Sender ID). Для отключения Sender ID по умолчанию необходимо в качестве имени передать пустую строку или точку.
    • $query - строка дополнительных параметров, добавляемая в URL-запрос ("valid=01:00&maxsms=3&tz=2")
    • $files - массив путей к файлам для отправки mms или e-mail сообщений

возвращает массив (, <количество sms>, <стоимость>, <баланс>) в случае успешной отправки либо массив (, -<код ошибки>) в случае ошибки

sendSmsMail() - SMTP версия функции отправки SMS

getSmsCost() - Функция получения стоимости SMS

  • обязательные параметры:

    • $phones - список телефонов через запятую или точку с запятой
    • $message - отправляемое сообщение
  • необязательные параметры:

    • $translit - переводить или нет в транслит (1,2 или 0)
    • $format - формат сообщения (0 - обычное sms, 1 - flash-sms, 2 - wap-push, 3 - hlr, 4 - bin, 5 - bin-hex, 6 - ping-sms, 7 - mms, 8 - mail, 9 - call)
    • $sender - имя отправителя (Sender ID)
    • $query - строка дополнительных параметров, добавляемая в URL-запрос ("list=79999999999:Ваш пароль: 123\n78888888888:Ваш пароль: 456")

возвращает массив (<стоимость>, <количество sms>) либо массив (0, -<код ошибки>) в случае ошибки

getStatus() - Функция проверки статуса отправленного SMS или HLR-запроса

  • $id - ID cообщения или список ID через запятую

  • $phone - номер телефона или список номеров через запятую

  • $all - вернуть все данные отправленного SMS, включая текст сообщения (0,1 или 2)

возвращает массив (для множественного запроса двумерный массив):

для одиночного SMS-сообщения: (<статус>, <время изменения>, <код ошибки доставки>)

для HLR-запроса: (<статус>, <время изменения>, <код ошибки sms>, <код IMSI SIM-карты>, <номер сервис-центра>, <код страны регистрации>, <код оператора>, <название страны регистрации>, <название оператора>, <название роуминговой страны>, <название роумингового оператора>)

при $all = 1 дополнительно возвращаются элементы в конце массива: (<время отправки>, <номер телефона>, <стоимость>, , <название статуса>, <текст сообщения>)

при $all = 2 дополнительно возвращаются элементы <страна>, <оператор> и <регион>

при множественном запросе: если $all = 0, то для каждого сообщения или HLR-запроса дополнительно возвращается <ID сообщения> и <номер телефона>

если $all = 1 или $all = 2, то в ответ добавляется <ID сообщения>

либо массив (0, -<код ошибки>) в случае ошибки

getBalance() - Функция получения баланса

возвращает баланс в виде строки или false в случае ошибки

Внутренние методы:

sendCmd() - Функция вызова запроса. Формирует URL и делает 5 попыток чтения через разные подключения к сервису

readUrl() - Функция чтения URL.

Для работы должно быть доступно: curl или fsockopen (только http) или включена опция allow_url_fopen для file_get_contents

Stargazers repo roster for @ZhukMax/smsc

Лицензия

The Apache License Version 2.0. Текст лицензии находится в файле License File.

Note that the project description data, including the texts, logos, images, and/or trademarks, for each open source project belongs to its rightful owner. If you wish to add or remove any projects, please contact us at [email protected].