成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

小白的邊學(xué)邊寫,一個基于laravel的APP接口【API】(三)

TerryCai / 3205人閱讀

摘要:但是,作為一名合格的,我們也應(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)當有(重復(fù)密碼)。

開始操作

開始之前先說說我的js資源吧,我用到了jQuery.jsValidator.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)容不能為空,然后驗證了是否為空和長度夠不夠還有兩次輸入密碼是否一致,最后把錯誤信息用jQueryappend()函數(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"); } } });

附上效果圖


后端分析

雖然說我們已經(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("該用戶已存在");
}

去測試

到這時功能就很完備了。

后續(xù)

接下來我們將用得到的token值來獲取服務(wù)器上數(shù)據(jù)庫的內(nèi)容。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/78977.html

相關(guān)文章

  • 小白學(xué)邊寫,一個基于laravelAPP接口API】(二)

    摘要:當注冊成功以后,我們應(yīng)該立即返回確認用戶登錄的值,并且作為的變量給儲存起來,直到退出時刪除,或者超出時間后刪除。在文檔里也有提及,對,就是那個叫的東東。用戶信息也被正常寫入,之后就可以歡快的擴展注冊機制啦。 前言 根據(jù)上一篇文章,我們已經(jīng)吧dingo/api給安裝并且調(diào)試好了,那么下一步,就是來完善咱們的API了。最首要的步驟一定是要先把注冊的功能給完善了,好了,那就給第一條正式API...

    skinner 評論0 收藏0
  • 小白學(xué)邊寫一個基于laravelAPP接口API】(二)

    摘要:當注冊成功以后,我們應(yīng)該立即返回確認用戶登錄的值,并且作為的變量給儲存起來,直到退出時刪除,或者超出時間后刪除。在文檔里也有提及,對,就是那個叫的東東。用戶信息也被正常寫入,之后就可以歡快的擴展注冊機制啦。 前言 根據(jù)上一篇文章,我們已經(jīng)吧dingo/api給安裝并且調(diào)試好了,那么下一步,就是來完善咱們的API了。最首要的步驟一定是要先把注冊的功能給完善了,好了,那就給第一條正式API...

    jlanglang 評論0 收藏0
  • 小白學(xué)邊寫,一個基于laravelAPP接口API】(

    摘要:但是,作為一名合格的,我們也應(yīng)該具備一些前端知識。但是,我們還需要驗證手機號是否是唯一的,如果不唯一則應(yīng)告知給客戶端。 前言 前兩篇文章我們已經(jīng)把基本的注冊功能給完成了。但是,作為一名合格的PHPer,我們也應(yīng)該具備一些前端知識。HTML+css已經(jīng)是最基本的技能了,那么接下來,就來點題外內(nèi)容,讓我們?nèi)パ芯恳幌翵avaScript吧。首先先說明用js要做什么事情,對,就是完善注冊頁面的...

    econi 評論0 收藏0
  • 小白學(xué)邊寫,一個基于laravelAPP接口API】(

    摘要:但是,作為一名合格的,我們也應(yīng)該具備一些前端知識。但是,我們還需要驗證手機號是否是唯一的,如果不唯一則應(yīng)告知給客戶端。 前言 前兩篇文章我們已經(jīng)把基本的注冊功能給完成了。但是,作為一名合格的PHPer,我們也應(yīng)該具備一些前端知識。HTML+css已經(jīng)是最基本的技能了,那么接下來,就來點題外內(nèi)容,讓我們?nèi)パ芯恳幌翵avaScript吧。首先先說明用js要做什么事情,對,就是完善注冊頁面的...

    piglei 評論0 收藏0

發(fā)表評論

0條評論

TerryCai

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<