WellCMS 是一款具備億級負載、開源、傾向移動端、輕量級、具有超快反應能力的高負載CMS,是大數據量、高并發訪問網站最佳選擇的輕CMS。wellcms具有安全、高效、穩定、速度超快、負載超強的特點。是大數據時代下誕生的CMS,低成本解決網站負載和性能問題,專為大數據量站點設計的高性能、高負載的CMS。小編對他還是比較了解的,今天小編就以新增短信接口為例,給大家講解一下如何進行二次開發,我們今天講解的是v2.3.0版本,使用的短信接口是我們短信寶短信群發平臺的短信接口,我們短信寶短信群發平臺的接口非常穩定,發送速度快,注冊就送測試短信,推薦大家使用
1:打開項目:admin\view\htm\setting_base.htm 在48行增加短信寶配置頁面
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
|
<div class= "form-group row" > <label class= "col-sm-2 form-control-label" >開啟注冊手機驗證:</label> <div class= "col-sm-10" > <?php echo $input[ 'user_create_mobile_on' ];?> </div> </div> <div class= "form-group row" > <label class= "col-sm-2 form-control-label" >短信寶賬號:</label> <div class= "col-sm-10" > <?php echo $input[ 'smsbao_user' ];?> </div> </div> <div class= "form-group row" > <label class= "col-sm-2 form-control-label" >短信寶密碼:</label> <div class= "col-sm-10" > <?php echo $input[ 'smsbao_pwd' ];?> </div> </div> <div class= "form-group row" > <label class= "col-sm-2 form-control-label" >短信寶簽名:</label> <div class= "col-sm-10" > <?php echo $input[ 'smsbao_sign' ];?> </div> </div> <div class= "form-group row" > <label class= "col-sm-2 form-control-label" >短信模板:</label> <div class= "col-sm-10" > <?php echo $input[ 'smsbao_template' ];?> </div> </div> |
2:打開項目:\admin\route\setting.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
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
81
82
|
case 'base' : // hook admin_setting_base_get_post.php if ( 'GET' == $method) { // hook admin_setting_base_get_start.php $input = array(); $input[ 'sitename' ] = form_text( 'sitename' , $conf[ 'sitename' ]); $input[ 'sitebrief' ] = form_textarea( 'sitebrief' , $conf[ 'sitebrief' ], '' , '100%' , 100); $input[ 'runlevel' ] = form_radio( 'runlevel' , array(0 => lang( 'runlevel_0' ), 1 => lang( 'runlevel_1' ), 2 => lang( 'runlevel_2' ), 3 => lang( 'runlevel_3' ), 4 => lang( 'runlevel_4' ), 5 => lang( 'runlevel_5' )), $conf[ 'runlevel' ]); $input[ 'user_create_on' ] = form_radio_yes_no( 'user_create_on' , $conf[ 'user_create_on' ]); $input[ 'user_create_email_on' ] = form_radio_yes_no( 'user_create_email_on' , $conf[ 'user_create_email_on' ]); $input[ 'user_create_mobile_on' ] = form_radio_yes_no( 'user_create_mobile_on' , $conf[ 'user_create_mobile_on' ]); $input[ 'smsbao_user' ] = form_text( 'smsbao_user' , $conf[ 'smsbao_user' ]); $input[ 'smsbao_pwd' ] = form_password( 'smsbao_pwd' , $conf[ 'smsbao_pwd' ]); $input[ 'smsbao_sign' ] = form_text( 'smsbao_sign' , $conf[ 'smsbao_sign' ]); $input[ 'smsbao_template' ] = form_text( 'smsbao_template' , $conf[ 'smsbao_template' ]); $input[ 'user_resetpw_on' ] = form_radio_yes_no( 'user_resetpw_on' , $conf[ 'user_resetpw_on' ]); $input[ 'lang' ] = form_select( 'lang' , array( 'zh-cn' => lang( 'lang_zh_cn' ), 'zh-tw' => lang( 'lang_zh_tw' ), 'en-us' => lang( 'lang_en_us' )), $conf[ 'lang' ]); $safe_token = well_token_set($uid, 'admin_setting_base' ); $input[ 'safe_token' ] = form_hidden( 'safe_token' , $safe_token); $header[ 'title' ] = lang( 'admin_setting_base' ); $header[ 'mobile_title' ] = lang( 'admin_setting_base' ); // hook admin_setting_base_get_end.php include _include(ADMIN_PATH . 'view/htm/setting_base.htm' ); } elseif ( 'POST' == $method) { $safe_token = param( 'safe_token' ); FALSE === well_token_verify($uid, $safe_token, 'admin_setting_base' ) AND message(1, lang( 'illegal_operation' )); FALSE === group_access($gid, 'managesetting' ) AND message(1, lang( 'user_group_insufficient_privilege' )); $sitebrief = param( 'sitebrief' , '' , FALSE); $sitename = param( 'sitename' , '' , FALSE); $sitename = trim($sitename); $runlevel = param( 'runlevel' , 0); $user_create_on = param( 'user_create_on' , 0); $user_create_email_on = param( 'user_create_email_on' , 0); $user_create_mobile_on = param( 'user_create_mobile_on' , 0); $smsbao_user = param( 'smsbao_user' , '' ); $smsbao_pwd = param( 'smsbao_pwd' , '' ); $smsbao_sign = param( 'smsbao_sign' , '' ); $smsbao_template = param( 'smsbao_template' , '' ); $user_resetpw_on = param( 'user_resetpw_on' , 0); $_lang = param( 'lang' ); // hook admin_setting_base_post_start.php $replace = array(); $replace[ 'sitename' ] = xn_html_safe(filter_all_html($sitename)); $replace[ 'sitebrief' ] = xn_html_safe($sitebrief); $replace[ 'runlevel' ] = $runlevel; $replace[ 'user_create_on' ] = $user_create_on; $replace[ 'user_create_email_on' ] = $user_create_email_on; $replace[ 'user_create_mobile_on' ] = $user_create_mobile_on; $replace[ 'smsbao_user' ] = $smsbao_user; $replace[ 'smsbao_pwd' ] = $smsbao_pwd; $replace[ 'smsbao_sign' ] = $smsbao_sign; $replace[ 'smsbao_template' ] = $smsbao_template; $replace[ 'user_resetpw_on' ] = $user_resetpw_on; $replace[ 'lang' ] = $_lang; file_replace_var(APP_PATH . 'conf/conf.php' , $replace); // hook admin_setting_base_post_end.php message(0, lang( 'modify_successfully' )); } break ; |
3:打開項目:view\htm\user_create.htm 31行左右 增加手機號注冊頁面
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
|
<?php if ($conf[ 'user_create_mobile_on' ]) { ?> <div class= "form-group input-group" > <div class= "input-group-prepend" > <span class= "input-group-text" ><i class= "icon-mobile-phone icon-fw" ></i></span> </div> <input type= "mobile" class= "form-control" placeholder= "手機號" name= "mobile" id= "mobile" required> </div> <div class= "media" > <div class= "media-body" > <div class= "form-group input-group" > <div class= "input-group-prepend" > <span class= "input-group-text" ><i class= "icon-barcode icon-fw" ></i></span> </div> <input type= "text" class= "form-control" placeholder= "手機驗證碼" name= "mobile_code" id= "mobile_code" required> </div> </div> <div class= "align-self-center ml-1" > <button type= "submit" class= "btn btn-primary btn-sm ml-3 form-group" id= "sendmobilecode" data-loading-text= "<?php echo lang('sending');?>..." > <?php echo lang( 'send_verify_code' );?> </button> </div> </div> <?php } else { ?> <div class= "form-group input-group" > <div class= "input-group-prepend" > <span class= "input-group-text" ><i class= "icon-envelope icon-fw" ></i></span> </div> <input type= "email" class= "form-control" placeholder= "<?php echo lang('email');?>" name= "email" id= "email" required> </div> <?php } ?> |
4:打開項目:\view\htm\user_resetpw.htm 修改密碼重置頁面
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
|
<?php if ($conf[ 'user_create_mobile_on' ]) { ?> <div class= "form-group input-group" > <div class= "input-group-prepend" > <span class= "input-group-text" ><i class= "icon icon-mobile-phone icon-fw" ></i></span> </div> <input type= "text" class= "form-control" placeholder= "手機號" name= "mobile" id= "mobile" required> <div class= "invalid-feedback" ></div> </div> <!--{hook user_resetpw_verify_code_before.htm}--> <div class= "media" > <div class= "media-body" > <div class= "form-group input-group" > <div class= "input-group-prepend" > <span class= "input-group-text" ><i class= "icon icon-key icon-fw" ></i></span> </div> <input type= "text" class= "form-control" placeholder= "<?php echo lang('verify_code');?>" name= "mobile_code" id= "mobile_code" required> </div> </div> <div class= "ml-1 mt-1" > <button type= "submit" class= "btn btn-primary btn-sm ml-3" id= "mobile_send" data-loading-text= "<?php echo lang('sending');?>..." > <?php echo lang( 'send_verify_code' );?> </button> </div> </div> <!--{hook user_resetpw_verify_code_after.htm}--> <?php } else { ?> <div class= "form-group input-group" > <div class= "input-group-prepend" > <span class= "input-group-text" ><i class= "icon icon-envelope icon-fw" ></i></span> </div> <input type= "text" class= "form-control" placeholder= "<?php echo lang('email');?>" name= "email" id= "email" required> <div class= "invalid-feedback" ></div> </div> <?php } ?> |
5:打開項目:route\user.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
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
|
case 'create' : $uid and http_location($conf[ 'path' ]); // hook user_create_get_post.php empty($conf[ 'user_create_on' ]) and message(-1, lang( 'user_create_not_on' )); if ( 'GET' == $method) { // hook user_create_get_start.php $header[ 'title' ] = lang( 'create_user' ); $referer = user_http_referer(); empty($safe_token) and $safe_token = well_token_set(0); $extra = array( 'safe_token' => $safe_token); $form_action = url( 'user-create' , $extra); // hook user_create_get_end.php if ( '1' == _GET( 'ajax' )) { $apilist[ 'header' ] = $header; $apilist[ 'safe_token' ] = $safe_token; $apilist[ 'referer' ] = $referer; $apilist[ 'action' ] = $form_action; $conf[ 'api_on' ] ? message(0, $apilist) : message(0, lang( 'closed' )); } else { include _include(theme_load( 'user_create' )); } } else if ( 'POST' == $method) { // hook user_create_post_start.php $email = param( 'email' ); $username = param( 'username' ); $password = param( 'password' ); if ($conf[ 'user_create_mobile_on' ]){ $mobile = param( 'mobile' ); $code = param( 'mobile_code' ); } else { $code = param( 'code' ); $email = filter_all_html($email); empty($email) and message( 'email' , lang( 'please_input_email' )); } $username = filter_all_html($username); empty($username) and message( 'username' , lang( 'please_input_username' )); empty($password) and message( 'password' , lang( 'please_input_password' )); if ($conf[ 'user_create_email_on' ]) { $sess_email = _SESSION( 'user_create_email' ); $sess_code = _SESSION( 'user_create_code' ); empty($sess_code) and message( 'code' , lang( 'click_to_get_verify_code' )); empty($sess_email) and message( 'code' , lang( 'click_to_get_verify_code' )); $email != $sess_email and message( 'code' , lang( 'verify_code_incorrect' )); $code != $sess_code and message( 'code' , lang( 'verify_code_incorrect' )); } if ($conf[ 'user_create_mobile_on' ]) { $sess_mobile = _SESSION( 'user_create_mobile' ); $sess_code = _SESSION( 'user_create_code' ); empty($sess_code) and message( 'code' , lang( 'click_to_get_verify_code' )); empty($sess_mobile) and message( 'code' , lang( 'click_to_get_verify_code' )); $mobile != $sess_mobile and message( 'code' , lang( 'verify_code_incorrect' )); $code != $sess_code and message( 'code' , lang( 'verify_code_incorrect' )); if (!preg_match( '/^1[3-9]\d{9}$/' , $mobile)) { message( 'mobile' , '手機號錯誤' ); } $_user = user_read_by_mobile($mobile); $_user and message( 'mobile' , '手機號已經使用' ); } else { is_email($email, $err) || message( 'email' , $err); $_user = user_read_by_email($email); $_user and message( 'email' , lang( 'email_is_in_use' )); } is_username($username, $err) || message( 'username' , $err); $_user = user_read_by_username($username); $_user and message( 'username' , lang( 'username_is_in_use' )); is_password($password, $err) || message( 'password' , $err); // hook user_create_post_before.php $salt = xn_rand(16); $_user = array( 'username' => $username, 'email' => $email, 'mobile' => $mobile, 'password' => md5($password . $salt), 'salt' => $salt, 'gid' => 101, 'create_ip' => $longip, 'create_date' => $time, 'logins' => 1, 'login_date' => $time, 'login_ip' => $longip, ); // hook user_create_post_center.php $uid = user_create($_user); FALSE === $uid and message(-1, lang( 'user_create_failed' )); $user = user_read($uid); // hook user_create_post_after.php // 更新 session unset($_SESSION[ 'user_create_email' ],$_SESSION[ 'user_create_mobile' ], $_SESSION[ 'user_create_code' ]); $_SESSION[ 'uid' ] = $uid; $token = user_token_set($uid); unset($user[ 'password' ], $user[ 'salt' ], $user[ 'password_sms' ], $user[ 'create_ip' ], $user[ 'create_ip_fmt' ], $user[ 'create_date' ], $user[ 'login_ip' ], $user[ 'login_date' ], $user[ 'login_ip_fmt' ], $user[ 'avatar_path' ]); $extra = array( 'user' => $user, 'token_key' => $conf[ 'cookie_pre' ] . 'token' , 'token' => $token); // hook user_create_post_end.php message(0, lang( 'user_create_successfully' ), $extra); } break ; |
6:打開當前項目:修改重置密碼方法
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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
|
case 'resetpw' : // 重設密碼第 1 步 | reset password first step // hook user_resetpw_get_post.php empty($conf[ 'user_resetpw_on' ]) and message(-1, lang( 'closed' )); if ( 'GET' == $method) { // hook user_resetpw_get_start.php $header[ 'title' ] = lang( 'resetpw' ); $form_action = url( 'user-resetpw' ); // hook user_resetpw_get_end.php if ( '1' == _GET( 'ajax' )) { $apilist[ 'header' ] = $header; $apilist[ 'form_action' ] = $form_action; $conf[ 'api_on' ] ? message(0, $apilist) : message(0, lang( 'closed' )); } else { include _include(theme_load( 'user_resetpw' )); } } else if ( 'POST' == $method) { // hook user_resetpw_post_start.php if ($conf[ 'user_create_mobile_on' ]){ $mobile = param( 'mobile' ); empty($mobile) and message( 'mobile' , '請填寫手機號' ); if (!preg_match( '/^1[3-9]\d{9}$/' , $mobile)) { message( 'mobile' , '手機號錯誤' ); } $_user = user_read_by_mobile($mobile); empty($_user) and message( 'mobile' , '手機號未被注冊' ); $code = param( 'mobile_code' ); } else { $email = param( 'email' ); empty($email) and message( 'email' , lang( 'please_input_email' )); is_email($email, $err) || message( 'email' , $err); $_user = user_read_by_email($email); empty($_user) and message( 'email' , lang( 'email_is_not_in_use' )); $code = param( 'code' ); } empty($code) and message( 'code' , lang( 'please_input_verify_code' )); $sess_code = _SESSION( 'user_resetpw_code' ); empty($sess_code) and message( 'code' , lang( 'click_to_get_verify_code' )); $code != $sess_code and message( 'code' , lang( 'verify_code_incorrect' )); if ($conf[ 'user_create_mobile_on' ]){ $sess_mobile = _SESSION( 'user_resetpw_mobile' ); (empty($sess_mobile) || $mobile != $sess_mobile) and message( 'mobile' , '數據有問題' ); $_SESSION[ 'resetpw_verify_mobile' ] = $sess_mobile; } else { $sess_email = _SESSION( 'user_resetpw_email' ); (empty($sess_email) || $email != $sess_email) and message( 'email' , lang( 'data_malformation' )); $_SESSION[ 'resetpw_verify_email' ] = $sess_email; } // hook user_resetpw_post_end.php message(0, lang( 'check_ok_to_next_step' )); } break ; case 'resetpw_complete' : // 重設密碼第 3 步 | reset password step 3 // hook user_resetpw_get_post.php // 校驗數據 if ($conf[ 'user_create_mobile_on' ]){ $mobile = _SESSION( 'user_resetpw_mobile' ); $resetpw_verify_mobile = _SESSION( 'resetpw_verify_mobile' ); (empty($mobile) || empty($resetpw_verify_mobile) || $resetpw_verify_mobile != $mobile) and message(-1, lang( 'data_empty_to_last_step' )); $_user = user_read_by_mobile($mobile); } else { $email = _SESSION( 'user_resetpw_email' ); $resetpw_verify_email = _SESSION( 'resetpw_verify_email' ); (empty($email) || empty($resetpw_verify_email) || $resetpw_verify_email != $email) and message(-1, lang( 'data_empty_to_last_step' )); $_user = user_read_by_email($email); } empty($_user) and message(-1, lang( 'email_not_exists' )); $_uid = $_user[ 'uid' ]; if ( 'GET' == $method) { // hook user_resetpw_get_start.php $header[ 'title' ] = lang( 'resetpw' ); $form_action = url( 'user-resetpw_complete' ); // hook user_resetpw_get_end.php if ( '1' == _GET( 'ajax' )) { $apilist[ 'header' ] = $header; $apilist[ 'form_action' ] = $form_action; $conf[ 'api_on' ] ? message(0, $apilist) : message(0, lang( 'closed' )); } else { include _include(theme_load( 'user_resetpw_complete' )); } } else if ( 'POST' == $method) { // hook user_resetpw_post_start.php $password = param( 'password' ); empty($password) and message( 'password' , lang( 'please_input_password' )); $salt = $_user[ 'salt' ]; $password = md5($password . $salt); is_password($password, $err) || message( 'password' , $err); user_update($_uid, array( 'password' => $password)); unset($_SESSION[ 'user_resetpw_email' ],$_SESSION[ 'user_resetpw_mobile' ],$_SESSION[ 'user_resetpw_code' ]); // hook user_resetpw_post_end.php message(0, lang( 'modify_successfully' )); } break ; |
7:打開當前項目:新增短信發送方法
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
|
case 'send_mobile_code' : // 發送驗證碼 'POST' != $method and message(-1, lang( 'method_error' )); // hook user_send_code_start.php $action2 = param(2); if ( 'user_create' == $action2) { // 創建用戶 $mobile = param( 'mobile' ); empty($mobile) and message( 'mobile' , '手機號為空' ); if (!preg_match( '/^1[3-9]\d{9}$/' , $mobile)) { message( 'mobile' , '手機號錯誤' ); } empty($conf[ 'user_create_mobile_on' ]) and message(-1, '未開啟手機驗證' ); $_user = user_read_by_mobile($mobile); empty($_user) || message( 'mobile' , '手機號已注冊' ); $code = rand(100000, 999999); $_SESSION[ 'user_create_mobile' ] = $mobile; $_SESSION[ 'user_create_code' ] = $code; } elseif ( 'user_resetpw' == $action2) { // 重置密碼,往老地址發送 $mobile = param( 'mobile' ); empty($mobile) and message( 'mobile' , '手機號為空' ); if (!preg_match( '/^1[3-9]\d{9}$/' , $mobile)) { message( 'mobile' , '手機號錯誤' ); } $_user = user_read_by_mobile($mobile); empty($_user) and message( 'mobile' , '手機號未被注冊' ); empty($conf[ 'user_resetpw_on' ]) and message(-1, lang( 'resetpw_not_on' )); $code = rand(100000, 999999); $_SESSION[ 'user_resetpw_mobile' ] = $mobile; $_SESSION[ 'user_resetpw_code' ] = $code; } else { message(-1, 'action2 error' ); } $statusStr = array( "0" => "短信發送成功" , "-1" => "參數不全" , "-2" => "服務器空間不支持,請確認支持curl或者fsocket,聯系您的空間商解決或者更換空間!" , "30" => "密碼錯誤" , "40" => "賬號不存在" , "41" => "余額不足" , "42" => "帳戶已過期" , "43" => "IP地址限制" , "50" => "內容含有敏感詞" ); $user = $conf[ 'smsbao_user' ]; //短信平臺帳號 $pass = md5($conf[ 'smsbao_pwd' ]); //短信平臺密碼 $content= '【' .$conf[ 'smsbao_sign' ]. '】' .str_replace( '{$code}' ,$code,$conf[ 'smsbao_template' ]); //要發送的短信內容 $phone = $mobile; //要發送短信的手機號碼 $sendurl = $smsapi. "sms?u=" .$user. "&p=" .$pass. "&m=" .$phone. "&c=" .urlencode($content); $result =file_get_contents($sendurl) ; if ( '0' === $result) { message(0, lang( 'send_successfully' )); } else { xn_log($statusStr[$result], 'send_mail_error' ); message(-1, $statusStr[$result]); } break ; |
8:打開項目:model\user.func.php 增加獲取手機號方法
1
2
3
4
5
6
7
8
9
10
11
12
|
function user_read_by_mobile($mobile) { global $g_static_users; // hook model_user_read_by_email_start.php $user = user__read(array( 'mobile' => $mobile)); if ($user) { user_format($user); $g_static_users[$user[ 'uid' ]] = $user; } // hook model_user_read_by_email_end.php return $user; } |
經過上面的替換,短信寶的短信平臺已經替換成功了,可以正常使用了。進行測試發送:
報備一下短信寶的VIP模板,這樣就可以走短信寶的優質通道了,即便遇到敏感文字我們都不會人工審核,短信內容3~5秒就可送達。
另外:我們已經開發好完整的WellCMS_V2.3.0系統短信寶插件,點擊此鏈接?下載及查看安裝流
最新更新
電商類
CMS類
微信類