摘要:但是,作為一名合格的,我們也應(yīng)該具備一些前端知識。但是,我們還需要驗證手機號是否是唯一的,如果不唯一則應(yīng)告知給客戶端。
前言
前兩篇文章我們已經(jīng)把基本的注冊功能給完成了。但是,作為一名合格的PHPer,我們也應(yīng)該具備一些前端知識。HTML+css已經(jīng)是最基本的技能了,那么接下來,就來點題外內(nèi)容,讓我們?nèi)パ芯恳幌?b>JavaScript吧。
首先先說明用js要做什么事情,對,就是完善注冊頁面的驗證功能。我們的注冊信息有(用戶名)(手機號)(密碼),在一般網(wǎng)站或APP的注冊機制中,都會有讓用戶再輸入一遍密碼,以確保錄入正確的密碼防止因為亂輸錯輸導(dǎo)致的不便,因此還應(yīng)當(dāng)有(重復(fù)密碼)。
開始之前先說說我的js資源吧,我用到了jQuery.js和Validator.js來開發(fā)這個功能。前者不必多說,后者是什么呢?Validator.js來自于大神的手筆,具體請看 Validator.js。
于是照著文檔和自己的理解,寫出了這么一段代碼(別忘記引入相關(guān)的js文件)
// 表單驗證 var validator = new Validator("register",[ { name: "name", display:"請?zhí)顚懹脩裘鹻{name}}|用戶名太短|用戶名太長", rules: "required|min_length(6)|max_length(20)" }, { name: "phone", display:"你輸入的{{phone}}不是合法手機號碼", rules: "is_phone" }, { name: "password", display:"請輸入密碼|密碼長度應(yīng)超過6位|密碼長度應(yīng)少于20位", rules: "required|min_length(6)|max_length(20)" }, { name: "password_confirmation", display:"請再輸入一遍密碼", rules: "required" } ],function(obj,evt){ var checkPassword = $("#icon_password").val(); var checkConfirmPassword = $("#icon_password_confirmation").val(); if (checkPassword != checkConfirmPassword) { var message = { id: null,display: null,element: null,name: null, message: "兩次輸入的密碼不一致",messages: null,rule: null }; obj.errors.push(message); } if(obj.errors.length>0){ for (var i = 0; i < obj.errors.length; i++) { writeError(obj.errors[i].message); } // 自動清除內(nèi)容 setTimeout(function(){ $("#error_msg").empty(); }, 5000); // console.log(validator); }else{ submitForm(); } }); function writeError(errorMessage){ var errorHtml = ""+errorMessage+"close"; $("#error_msg").append(errorHtml); }
它都做了哪些事,首先所有內(nèi)容不能為空,然后驗證了是否為空和長度夠不夠還有兩次輸入密碼是否一致,最后把錯誤信息用jQuery的append()函數(shù)插入到頁面上,并且規(guī)定了5秒后自動清除。之后的submitForm()才開始提交表單。
// 提交表單 function submitForm() { var $registerForm = $("#register"); $.ajax({ type: "post", url: "http://localhost/register", data: $registerForm.serialize(), async: false, dataType:"json", success: function(data){ alert(JSON.stringify(data)); } }); }
OK,完成表單的驗證和上傳了,接下來我又想,是不是應(yīng)該寫一個點擊查看密碼的功能呢?
于是乎,就有了下面的東西。
visibility密碼 visibility// 顯示隱藏密碼 $("#see-pw1").click(function(){ if ($("#icon_password").val() != "") { if ($("#icon_password").hasClass("see")) { $("#icon_password").removeClass("see"); $("#icon_password").attr("type", "password"); $("#see-pw1").text("visibility"); }else{ $("#icon_password").addClass("see"); $("#icon_password").attr("type", "text"); $("#see-pw1").text("visibility_off"); } } }); $("#see-pw2").click(function(){ if ($("#icon_password_confirmation").val() != "") { if ($("#icon_password_confirmation").hasClass("see")) { $("#icon_password_confirmation").removeClass("see"); $("#icon_password_confirmation").attr("type", "password"); $("#see-pw2").text("visibility"); }else{ $("#icon_password_confirmation").addClass("see"); $("#icon_password_confirmation").attr("type", "text"); $("#see-pw2").text("visibility_off"); } } });重復(fù)密碼
附上效果圖
雖然說我們已經(jīng)在前端完善了驗證規(guī)則,但是,如果一旦被別人得到了我們的API,那么就能胡亂的輸入數(shù)據(jù)了,真是一場災(zāi)難。
所以對于APP來說,如何防止注冊的時候無法驗證注冊方的真實環(huán)境呢?就是說注冊者到底是不是用APP客戶端來注冊信息的。這里我又要提一點自己的個人見解了。在APP安裝完成之后我們應(yīng)該及時告知服務(wù)器有一款A(yù)PP被安裝了,并且在客戶端生成一段特殊標識傳回服務(wù)器,服務(wù)器將有特殊驗證規(guī)則的標識儲存起來,等注冊時由APP返回給服務(wù)器,OK,是對的注冊環(huán)境,再開始注冊。
但是我只是想想O(∩_∩)O~,實際做起來我還是有千萬個不想。但是,我們還需要驗證手機號是否是唯一的,如果不唯一則應(yīng)告知給客戶端。
首先我們應(yīng)該修改AuthenticateController.php文件的內(nèi)容
//引入類 use Validator; //在register方法內(nèi)添加驗證規(guī)則的代碼 $validator = Validator::make($request->all(), [ "phone" => "unique:users" ]); if ($validator->fails()) { return response()->json("該用戶已存在"); }
去測試
到這時功能就很完備了。
接下來我們將用得到的token值來獲取服務(wù)器上數(shù)據(jù)庫的內(nèi)容。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/35771.html
摘要:當(dāng)注冊成功以后,我們應(yīng)該立即返回確認用戶登錄的值,并且作為的變量給儲存起來,直到退出時刪除,或者超出時間后刪除。在文檔里也有提及,對,就是那個叫的東東。用戶信息也被正常寫入,之后就可以歡快的擴展注冊機制啦。 前言 根據(jù)上一篇文章,我們已經(jīng)吧dingo/api給安裝并且調(diào)試好了,那么下一步,就是來完善咱們的API了。最首要的步驟一定是要先把注冊的功能給完善了,好了,那就給第一條正式API...
摘要:當(dāng)注冊成功以后,我們應(yīng)該立即返回確認用戶登錄的值,并且作為的變量給儲存起來,直到退出時刪除,或者超出時間后刪除。在文檔里也有提及,對,就是那個叫的東東。用戶信息也被正常寫入,之后就可以歡快的擴展注冊機制啦。 前言 根據(jù)上一篇文章,我們已經(jīng)吧dingo/api給安裝并且調(diào)試好了,那么下一步,就是來完善咱們的API了。最首要的步驟一定是要先把注冊的功能給完善了,好了,那就給第一條正式API...
摘要:但是,作為一名合格的,我們也應(yīng)該具備一些前端知識。但是,我們還需要驗證手機號是否是唯一的,如果不唯一則應(yīng)告知給客戶端。 前言 前兩篇文章我們已經(jīng)把基本的注冊功能給完成了。但是,作為一名合格的PHPer,我們也應(yīng)該具備一些前端知識。HTML+css已經(jīng)是最基本的技能了,那么接下來,就來點題外內(nèi)容,讓我們?nèi)パ芯恳幌翵avaScript吧。首先先說明用js要做什么事情,對,就是完善注冊頁面的...
摘要:但是,作為一名合格的,我們也應(yīng)該具備一些前端知識。但是,我們還需要驗證手機號是否是唯一的,如果不唯一則應(yīng)告知給客戶端。 前言 前兩篇文章我們已經(jīng)把基本的注冊功能給完成了。但是,作為一名合格的PHPer,我們也應(yīng)該具備一些前端知識。HTML+css已經(jīng)是最基本的技能了,那么接下來,就來點題外內(nèi)容,讓我們?nèi)パ芯恳幌翵avaScript吧。首先先說明用js要做什么事情,對,就是完善注冊頁面的...
閱讀 1691·2023-04-25 20:16
閱讀 3857·2021-10-09 09:54
閱讀 2706·2021-09-04 16:40
閱讀 2523·2019-08-30 15:55
閱讀 840·2019-08-29 12:37
閱讀 2743·2019-08-26 13:55
閱讀 2913·2019-08-26 11:42
閱讀 3155·2019-08-23 18:26