Kotsms2 ( 2016 新版 簡訊王 KotSMS API Ruby 版套件 )

Gem Version Build Status

kotsms

此為針對 簡訊王 KotSMS API 開發的專屬套件

您可以透過該套件來實作簡訊王的一般、預約簡訊發送 與 簡訊餘額查詢 的程式

適用於

Ruby 2 以上的版本,也可在 Ruby On Rails 專案引入

安裝方式

請在您的 Ruby 或 Rails 專案裡的 Gemfile 加入以下指令

gem 'kotsms2', '~> 1.0.0'

然後執行 bundle install 更新套件組

$ bundle

或也可以直接將 kotsms2 裝在系統上

$ gem install kotsms2

使用方式

本 API 套件,提供幾組以下方法來方便您開發簡訊相關服務

但要使用前,需要先註冊簡訊王的會員,否則您的程式無法存取簡訊王的 API 管道

require 'kotsms2'

# Kotsms2 是走 https 的方式進行系統操作
sms_client = Kotsms2::Client.new(username: '會員帳號', password: '會員密碼', agent: "Mozilla/5.0 (可自訂 user-agent)")

使用範例

系統檢查

檢查帳號是否有效、是否可以發送簡訊,有效為 true、無效則為 false

sms_client.

發送簡訊

一般使用

手機號碼格式 0911222333 ( 台灣手機 )、886911222333 ( 國碼 + 手機號碼 )

# 備註:簡訊王的內容需要為 Big 5 編碼,本套件將會自動進行轉換,若有遇到無法轉換的,會將會替換成「?」號
sms_client.send_message to: '手機號碼', content: "簡訊內容.."

預約發送

若要使用預約發送,可以指定 at 參數給 send_message 方法

同時程式會自動轉換時區 至 簡訊王 適用的時區 ( +08:00 )

# 純 Ruby 請用加秒數的方式
sms_client.send_message to: '手機號碼', content: "預約簡訊測試: #{Time.now}", at: Time.now + 120

# 在 Ruby On Rails 專案則可以用 Rails 專用的方法
sms_client.send_message to: '手機號碼', content: "預約簡訊測試: #{Time.now}", at: Time.now + 2.days

切換 大量發送 專用線路

根據簡訊王文件說明,若要進行上千、萬數以上的大量發送,建議使用專用線路

因此,本程式有提供一個 heavy_loading 參數,讓您切換至大量發送專用線路

sms_client.send_message to: '手機號碼', content: "簡訊內容..", heavy_loading: true

當您指定了該參數後,將會使用另外的線路進行發送

但請根據實際發送需求進行使用,小量發送可以不用加入 heavy_loading 參數

因為簡訊王的大量發送專用線路,屬於另一種處理方式,小量發送並不會比較即時

發送簡訊 的 回傳結果

發送成功

當你執行完成後,send_message 方法會回傳一組 hash 型態的結果

只要 access_success 的值為 true 就一定代表發送成功

系統會另外回傳一組 message_id 用來讓你追蹤簡訊

{:access_success=>true, :message_id=>"123456789", :error=>nil}

發生錯誤時

若 access_success 為 false 則表示過程有出現錯誤

以下範例為帳號密碼的錯誤,error 參數則是簡訊王的 error code

error code 的部分,請以 簡訊王 API 文件的定義為主,本套件不處理相關結果

{:access_success=>false, :message_id=>nil, :error=>"KOTSMS:-2"}

查詢簡訊餘額

若你需要查詢您會員帳號的簡訊餘額,可以用以下指令處理

sms_client.get_balance

查詢簡訊餘額 的 回傳結果

得到簡訊餘額

當你執行完成後,get_balance 方法會回傳一組 hash 型態的結果

只要 access_success 的值為 true 就一定代表系統有成功取得資料

message_quota 則是簡訊餘額,代表你還剩幾封可以用,若為 0 就代表都沒有

# 備註:簡訊商若發送過程中出現意外狀況,會晚點將簡訊額度補回您的會員帳號
{:access_success=>true, :message_quota=>10, :error=>nil}

發生錯誤

若 access_success 為 false 則表示過程有出現錯誤,同時 message_quota 會為 0

{:access_success=>false, :message_quota=>0, :error=>"KOTSMS:-2"}

LICENSE

本專案原始碼採 MIT LICENSE 授權 ( 詳見 LICENSE 檔案 )

連結分享

註冊簡訊王的會員簡訊王官網API 技術支援