今天我們要來開始試著寫 LINE notify 這段。我們建立一個 private function 叫做 line_send_notify
,這個函式傳入了一參數叫做 $text
:
這個函式一開始我們先建立 $request_params
,裡面有我們的 header
和 body
。其中 header
包含了我們在 【第 27 天】取出 LINE Notify token ,所拿到的 token ,作為 Authorization 的 value。以及在 body
放入 一個 key 為 message
,value 為剛剛函式傳入的 $text
。
$request_params = array(
"headers" => "Authorization: Bearer {$this->options['token']}",
"body" => array(
"message" => "{$text}"
)
);
還記得我們在 【第 15 天】WordPress 的 HTTP API ,了解了 WordPress 提供了許多好用的 HTTP API 讓我們可以對第三方發送 HTTP 請求,這時候就可以派出用場了
LINE 官方文件提到要推送 notify 的位址是 https://notify-api.line.me/api/notify
,並且是 POST
方法,然後要傳入剛剛建立好的 header
和 body
:
$response = wp_remote_post('https://notify-api.line.me/api/notify', $request_params);
這樣我們的訊息應該就可以正常送出去了,完整的程式碼如下:
private function line_send_notify($text) {
$request_params = array(
"headers" => "Authorization: Bearer {$this->options['token']}",
"body" => array(
"message" => "{$text}"
)
);
$response = wp_remote_post('https://notify-api.line.me/api/notify', $request_params);
}
順帶一提,如果想要確認一下我們 API 是否有打成功,我們還可以加入:
$response_code = wp_remote_retrieve_response_code($response);
然後用 if...else... 去判斷狀態碼:
if( $response_code == '200' ){
// Do something...
} else {
// Do something...
}