jsp+ajax發送GET、POST請求教程

來源:互聯網
上載者:User

Ajax發送GET請求

這裡用一個執行個體示範Ajax發送get請求,執行個體具體要求為一個註冊頁面,當使用者填寫完使用者名稱稱時,該輸入框失去焦點後會通過Ajax向後台發送驗證資訊,如果使用者名稱不是admin則通過驗證,否則不通過驗證。

下面先看JSP頁面具體資訊:

 代碼如下 複製代碼
<form action="servlet/LoginServlet" method="post">
    <table>
        <tr>
            <td>使用者帳號:</td>
            <td><input type="text" name="username" onblur="checkUser(this)"/></td>
        </tr>
        <tr>
            <td>使用者密碼:</td>
            <td><input type="password" name="password"/></td>
        </tr>
        <tr>
            <td><input type="submit" value="註冊"/></td>
            <td><input type="reset" value="重設"></td>
        </tr>
    </table>
</form>


這裡幕後處理資訊用的是Servlet進行處理

首先看web.xml配置資訊

 代碼如下 複製代碼
<servlet>
<servlet-name>LoginServlet</servlet-name>
<servlet-class>login.LoginServlet</servlet-class>
</servlet>

<servlet-mapping>
<servlet-name>LoginServlet</servlet-name>
<url-pattern>/servlet/LoginServlet</url-pattern>
</servlet-mapping>


然後看具體的servlet類的doGet方法

 代碼如下 複製代碼
public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {

        response.setContentType("text/html;charaet=UTF-8");
        PrintWriter out = response.getWriter();
        String name=request.getParameter("username");
        System.out.println(name);
        if(name.equals("admin"))
            out.print(false);
        else
            out.print(true);
        out.flush();
        out.close();
    }


在Servlet類中做一個簡單的驗證。

在JSP的表單中,對輸入使用者名稱稱的輸入框設定了失去焦點的事件,也就是onblur事件。下面看javascript代碼。

 代碼如下 複製代碼
<script type="text/javascript">
    //建立XMLHttpRequest
    function createXmlHttpRequest(){
        if(window.XMLHttpRequest){
            return new XMLHttpRequest();
        }else{
            return new ActiveXObject("Microsoft.XMLHTTP");
        }
    }
    //當使用者帳號輸入框失去焦點時調用該方法
    function checkUser(obj){
        //擷取輸入框輸入的值
        var user = obj.value;
        //如果輸入框中的值為空白,那麼彈窗提示,並且讓該輸入框獲得焦點
        if(!user){
            alert("使用者名稱不可為空!");
            obj.focus();
            return;
        }
        //不為空白時,使用Ajax請求向後台發送資訊,驗證該使用者名稱是否可用
        //get請求字串
        var url="servlet/LoginServlet?username="+user;
        //調用方法建立XMLHttpRequest對象
        XmlHttpRequest = createXmlHttpRequest();
        //設定回呼函數
        XmlHttpRequest.onreadystatechange=finish;
        //初始化xmlhttprequest
        XmlHttpRequest.open("GET",url,true);
        //發送請求
        XmlHttpRequest.send(null);
    }
    //回呼函數
    function finish(){
        if(XmlHttpRequest.readyState == 4&& XmlHttpRequest.status == 200){
            var result = XmlHttpRequest.responseText;
            if(result =="true"){
                alert("使用者名稱可用!");
            }else{
                alert("使用者名稱不可用!");
            }
        }
    }
</script>


Ajax發送GET請求

這裡用一個執行個體示範Ajax發送get請求,執行個體具體要求為一個註冊頁面,當使用者填寫完使用者名稱稱時,該輸入框失去焦點後會通過Ajax向後台發送驗證資訊,如果使用者名稱不是admin則通過驗證,否則不通過驗證。

下面先看JSP頁面具體資訊:

 代碼如下 複製代碼
<form action="servlet/LoginServlet" method="post">
    <table>
        <tr>
            <td>使用者帳號:</td>
            <td><input type="text" name="username" onblur="checkUser(this)"/></td>
        </tr>
        <tr>
            <td>使用者密碼:</td>
            <td><input type="password" name="password"/></td>
        </tr>
        <tr>
            <td><input type="submit" value="註冊"/></td>
            <td><input type="reset" value="重設"></td>
        </tr>
    </table>
</form>


這裡幕後處理資訊用的是Servlet進行處理

首先看web.xml配置資訊

 代碼如下 複製代碼
<servlet>
    <servlet-name>LoginServlet</servlet-name>
    <servlet-class>login.LoginServlet</servlet-class>
  </servlet>

  <servlet-mapping>
    <servlet-name>LoginServlet</servlet-name>
    <url-pattern>/servlet/LoginServlet</url-pattern>
  </servlet-mapping>


然後看具體的servlet類的doGet方法

 代碼如下 複製代碼
public void doGet(HttpServletRequest request, HttpServletResponse response)
            throws ServletException, IOException {

        response.setContentType("text/html;charaet=UTF-8");
        PrintWriter out = response.getWriter();
        String name=request.getParameter("username");
        System.out.println(name);
        if(name.equals("admin"))
            out.print(false);
        else
            out.print(true);
        out.flush();
        out.close();
    }

在Servlet類中做一個簡單的驗證。

在JSP的表單中,對輸入使用者名稱稱的輸入框設定了失去焦點的事件,也就是onblur事件。下面看javascript代碼。

 代碼如下 複製代碼
<script type="text/javascript">
        //建立XMLHttpRequest
        function createXmlHttpRequest(){
            if(window.XMLHttpRequest){
                return new XMLHttpRequest();
            }else{
                return new ActiveXObject("Microsoft.XMLHTTP");
            }
        }
        //當使用者帳號輸入框失去焦點時調用該方法
        function checkUser(obj){
            //擷取輸入框輸入的值
            var user = obj.value;
            //如果輸入框中的值為空白,那麼彈窗提示,並且讓該輸入框獲得焦點
            if(!user){
                alert("使用者名稱不可為空!");
                obj.focus();
                return;
            }
            //不為空白時,使用Ajax請求向後台發送資訊,驗證該使用者名稱是否可用
            //get請求字串
            var url="servlet/LoginServlet?username="+user;
            //調用方法建立XMLHttpRequest對象
            XmlHttpRequest = createXmlHttpRequest();
            //設定回呼函數
            XmlHttpRequest.onreadystatechange=finish;
            //初始化xmlhttprequest
            XmlHttpRequest.open("GET",url,true);
            //發送請求
            XmlHttpRequest.send(null);
        }
        //回呼函數
        function finish(){
            if(XmlHttpRequest.readyState == 4&& XmlHttpRequest.status == 200){
                var result = XmlHttpRequest.responseText;
                if(result =="true"){
                    alert("使用者名稱可用!");
                }else{
                    alert("使用者名稱不可用!");
                }
            }
        }
    </script>

 

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.