ShopXO是國內領先的商城系統提供商,為企業提供php商城系統、微信商城、小程序。小編發現ShopXO更新到6.3.0版本,就以替換短信接口為例告訴大家如何進行二次開發,使用的短信接口是我們短信寶短信群發平臺的接口,我們短信寶短信群發平臺非常穩定,發送速度快,注冊就送測試短信,推薦大家使用
1:打開項目:app\lang\zh.php修改為以下對應字段提示
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
'common_sms_apikey' => [ 'name' => '短信寶賬號' , 'desc' => '短信寶賬號' , 'tips' => '請填寫短信寶賬號' , ], 'common_sms_apisecret' => [ 'name' => '短信寶密碼' , 'desc' => '短信寶密碼' , 'tips' => '請填寫短信寶密碼' , ], 'home_sms_user_reg_template' => [ 'name' => '用戶注冊-短信模板' , 'desc' => '驗證碼code' , 'tips' => '請填寫用戶注冊短信模板內容' , ], 'home_sms_user_forget_pwd_template' => [ 'name' => '密碼找回-短信模板' , 'desc' => '驗證碼code' , 'tips' => '請填寫密碼找回短信模板內容' , ], 'common_sms_currency_template' => [ 'name' => '通用-短信模板' , 'desc' => '驗證碼code' , 'tips' => '請填寫通用短信模板內容' , ], 'home_sms_user_mobile_binding_template' => [ 'name' => '手機號碼綁定-短信模板' , 'desc' => '驗證碼code' , 'tips' => '請填寫手機號碼綁定短信模板內容' , ], 'admin_sms_login_template' => [ 'name' => '后臺登錄-短信模板' , 'desc' => '驗證碼code' , 'tips' => '請填寫后臺登錄短信模板內容' , ], 'home_sms_login_template' => [ 'name' => '用戶登錄-短信模板' , 'desc' => '驗證碼code' , 'tips' => '請填寫用戶登錄短信模板內容' , ] |
2:打開項目:\app\admin\view\default\sms\tips.html 修改跳轉方式
1
2
3
4
5
6
7
8
|
<div class= "am-operate-stretch-tips" > <div class= "title" > <i class= "iconfont icon-tips" ></i> <strong title= "{{:MyLang('operate_list_tips_msg')}}" >{{:MyLang( 'operate_list_tips_button_text' )}}</strong> <i class= "iconfont icon-contract contract" title= "{{:MyLang('operate_list_tips_retract_text')}}" ></i> </div> <p class= "am-text-xs" >短信寶短信地址 <a href= " </div> |
3:打開項目:\extend\base\Sms.php 修改短信發送函數 大概151行
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
|
public function SmsRequest($mobile, $template_value, $sign_name = '' , $template_var = []) { // 簽名 $sign_name = empty($sign_name) ? $ this ->sign_ame : $sign_name; // 短信發送鉤子 $hook_name = 'plugins_extend_sms_send_request_handle' ; $ret = array_filter(MyEventTrigger($hook_name, [ 'hook_name' => $hook_name, 'is_backend' => true , 'sign_name' => $sign_name, 'mobile' => $mobile, 'template_value' => $template_value, 'template_var' => $template_var, ])); // 存在返回值,并且存在code和mag參數,則認為是鉤子處理短信的發送 if (!empty($ret)) { // 處理鉤子數據 $ret = EventReturnHandle($ret); if ($ret[ 'code' ] != 0) { $ this ->error = $ret[ 'msg' ]; return false ; } return true ; } // 請求參數 $request_params = [ 'SignName' => $sign_name, 'Format' => 'JSON' , 'Version' => '2017-05-25' , 'AccessKeyId' => $ this ->access_key_id, 'Timestamp' => gmdate( 'Y-m-d\TH:i:s\Z' ), 'Action' => 'SendSms' , 'TemplateCode' => $template_value, 'PhoneNumbers' => $mobile, ]; // 攜帶參數 if (!empty($template_var)) { if (!is_array($template_var)) { $template_var = [ 'code' =>$template_var]; } $request_params[ 'TemplateParam' ] = json_encode($template_var, JSON_UNESCAPED_UNICODE); } $content = $template_value; foreach ($template_var as $k=>$v){ $content = str_replace($k,$v,$content); } $SignName = empty($sign_name) ? $ this ->sign_ame : $sign_name; $url = $request_url. '?u=' .$ this ->access_key_id. '&p=' .md5($ this ->access_key_secret). '&m=' .$mobile. '&c=【' .$SignName. '】' .$content; // 添加短信日志 $log = SmsLogService::SmsLogAdd( 'smsbao' , $mobile, $sign_name, $template_value, $template_var, $request_url, $request_params); if ($log[ 'code' ] != 0) { $ this ->error = $log[ 'msg' ]; return false ; } $ch = curl_init (); curl_setopt ( $ch, CURLOPT_URL, $url ); curl_setopt ( $ch, CURLOPT_SSL_VERIFYPEER, FALSE ); curl_setopt ( $ch, CURLOPT_SSL_VERIFYHOST, FALSE ); curl_setopt ( $ch, CURLOPT_RETURNTRANSFER, 1 ); curl_setopt ( $ch, CURLOPT_TIMEOUT, 10 ); $result = curl_exec ( $ch ); curl_close ( $ch ); if ($result == '0' ) { // 日志回調 SmsLogService::SmsLogResponse($log[ 'data' ][ 'id' ], 1, $result, time()-$log[ 'data' ][ 'add_time' ]); return true ; } // 錯誤原因 $ this ->error = $ this ->GetErrorMessage($result); // 日志回調 SmsLogService::SmsLogResponse($log[ 'data' ][ 'id' ], 2, $result, time()-$log[ 'data' ][ 'add_time' ], $ this ->error); return false ; } |
經過上面的替換,短信寶的短信平臺已經替換成功了,可以正常使用了。進行測試發送:
報備一下短信寶的VIP模板,這樣就可以走短信寶的優質通道了,即便遇到敏感文字我們都不會人工審核,短信內容3~5秒就可送達。
另外:我們已經開發好完整的ShopXO v6.3.0系統短信寶插件,點擊此鏈接 下載及查看安裝流程。
最新更新
電商類
CMS類
微信類