jsp+ajax發送GET請求的方法_JSP編程

來源:互聯網
上載者:User

本文執行個體講述了ajax發送GET請求,然後通過jsp頁面來接收處理的實現方法。分享給大家供大家參考。具體實現方法如下:

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>

希望本文所述對大家的jsp+Ajax程式設計有所協助。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.