<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    posts - 0,  comments - 17,  trackbacks - 0
    Ajax應用(jsp例子)

    --------------------------------------------------------------------------------

     

    首先是jsp頁面和腳本,為了方便寫在一個里面

    這是一個很常見的檢測用戶名是否存在的功能

    這里用的是struts

    <%@ page contentType="text/html; charset=GBK" %>
    <html>
    <head>
    <title>
    ajax
    </title>
    </head>
    <body bgcolor="#ffffff">
    <h1>
    <input name="username" type="text" maxlength="20" />
    <input id="chk-name-btn" type="button" value="檢測帳號" onclick="testName('<%=request.getContextPath()%>')" />
    <div id="view_name"></div>
    </h1>
    </body>
    </html>
    <script language="javascript">
      if (window.ActiveXObject && !window.XMLHttpRequest) {
          window.XMLHttpRequest=function() {
          return new ActiveXObject((navigator.userAgent.toLowerCase().indexOf('msie 5') != -1) ? 'Microsoft.XMLHTTP' : 'Msxml2.XMLHTTP');
       };
      }//取得XMLHttpRequest對象

    function testName(path){

    //path是取得系統路徑
                    var view_name=document.getElementById("view_name");
          var req=new XMLHttpRequest();
          if (req) {
              req.onreadystatechange=function() {
               if (req.readyState==4 && req.status==200) {//判斷狀態,4是已發送,200已完成
                     if(req.responseText==0){
                     view_name.style.color='green';
                    view_name.innerHTML='該用戶名可以正常使用';
                     }else if(req.responseText==1){
                    view_name.style.color='red';
                       view_name.innerHTML='該用戶名已經被使用';
                           }else{
                         view_name.style.color='red';
                         view_name.innerHTML='該用戶名含有非法字符!';
                         }
                     }
             }
                            req.open('POST', path+'/ajax.do');//struts

                //req.open('POST', path+'/ajax.servlet');//servlet

                            //req.open('POST', path+'/ajax.action');//webwork


                              req.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
                              req.send("");//發送參數如果有參數req.send("username="+user_name);用request取得
          }
    }
    </script>

    這個jsp頁面并沒有取得用戶名,就是演示一下。還有<div>可以換span,具體作用問美工吧。

    接受ajax請求的action。

    import org.apache.struts.action.*;
    import javax.servlet.http.*;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    import java.io.PrintWriter;

    /**
     * <p>Title:AjaxAction </p>
     */

    public class AjaxAction extends Action {
      public ActionForward execute(ActionMapping mapping,
                                   ActionForm form,
                                   HttpServletRequest request,
                                   HttpServletResponse response)
          throws Exception {
        PrintWriter out = response.getWriter();
        out.print(1);//ajax取得都是字符的輸出。如果數據量大的話,還可以用xml來發送和接受
        return null;
      }
    }

    struts-config.xml

        <action type="test.whw.upload.AjaxAction" validate="false" scope="request"  path="/ajax"/>
    ----------------------------

    如果是servlet

    web.xml

     <servlet>
      <servlet-name>AjaxServlet </servlet-name>
      <servlet-class>servlet.AjaxServlet </servlet-class>
     </servlet>
        <servlet-mapping>
            <servlet-name>AjaxServlet </servlet-name>
            <url-pattern>/AjaxServlet .servlet</url-pattern>
        </servlet-mapping>

    AjaxServlet.java

    import java.io.IOException;
    import java.io.PrintWriter;
    import javax.servlet.ServletException;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;



    public class AjaxServlet extends HttpServlet {
     Logger log = Logger.getLogger(this.getClass());
     public void doGet(HttpServletRequest request, HttpServletResponse response)
       throws ServletException,IOException {
      response.setContentType("text/xml; charset=GBK");
      PrintWriter out = response.getWriter();
        out.print(2);
       }
     }
     //Process the HTTP Post request
     public void doPost(HttpServletRequest request, HttpServletResponse response)
       throws ServletException, IOException {
      doGet(request, response);
     }

     //Process the HTTP Put request
     public void doPut(HttpServletRequest request, HttpServletResponse response)
       throws ServletException, IOException {
     }

     //Process the HTTP Delete request
     public void doDelete(HttpServletRequest request,
       HttpServletResponse response) throws ServletException, IOException {
     }

     //Clean up resources
     public void destroy() {
     }
    }

    -------------------------------------

    如果是webwork

    xwork.xml

       <action name="ajax" class="com.whw.upload.action.webwork.AjaxAction" method="ajax"/>


    AjaxAction.java

    import java.io.PrintWriter;

    public class AjexAlbumAction extends ActionSupport implements Action{

      public void ajax()throws IOException {
                 PrintWriter pw = ServletActionContext.getResponse().getWriter();
                ServletActionContext.getResponse().setContentType("text/html;charset=GBK");
                pw.print(1);
                pw.close();
      }


    }

    本例子在winXPsp2、JB9、Eclipse3,j2sdk1.4.1 、Tomcat5、Tomcat4.1都能運行
    posted on 2007-12-18 11:33 xyz 閱讀(495) 評論(0)  編輯  收藏 所屬分類: 他山之石

    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    留言簿

    隨筆檔案(1)

    文章分類(44)

    文章檔案(46)

    收藏夾(1)

    Adobe

    AOP

    API

    appServer

    BI

    c

    • c-free
    • codeblocks
    • codelite
    • CodeLite IDE 是一個強大的開源,跨平臺的 C/C++整合開發環境. 支持包括 Windows、Linux 和 Mac 系統下運行
    • codelite官網
    • dev-c++
    • Dev-C++是一個C&C++開發工具,它是一款自由軟件,遵守GPL協議。
    • GCC
    • GCC 原名為 GNU C 語言編譯器(GNU C Compiler),因為它原本只能處理 C語言。GCC 很快地擴展,變得可處理 C++。之后也變得可處理 Fortran、Pascal、Objective-C、Java, 以及 Ada 與其他語言。

    Cache

    CMS

    DB

    eclipse

    FreeMarker

    hibernate

    html5

    ibatis

    java

    jquery

    js

    json

    Linux

    Log

    mail server

    mobile

    mysql

    oauth

    openID

    other

    PHP

    portal

    report

    Scheduler

    schema

    Security

    SOA

    spring

    struts

    UI原型設計

    w3c

    Wap

    webservice

    xml

    供應鏈管理

    博客鏈接

    好網站

    工作流

    開源網

    招聘

    插件下載

    操作系統

    構建可伸縮的系統

    構建工具

    測試

    • IETest
    • IE官網
    • OpenSTA
    • Siege
    • Siege是一個壓力測試和評測工具,設計用于WEB開發這評估應用在壓力下的承受能力

    游戲

    源碼托管

    經營

    資源

    金融/財務

    搜索

    •  

    最新評論

    主站蜘蛛池模板: 最近免费中文字幕中文高清| 精品亚洲成AV人在线观看| 国产午夜无码视频免费网站| 毛片a级毛片免费播放100| 免费av欧美国产在钱| 亚洲人成电影网站免费| 毛片在线免费视频| 思思99re66在线精品免费观看| 成人免费a级毛片无码网站入口 | 亚洲精品欧洲精品| 亚洲综合综合在线| 亚洲免费福利视频| 亚洲日韩亚洲另类激情文学| 亚洲欧美成aⅴ人在线观看| 亚洲av日韩av永久无码电影| 添bbb免费观看高清视频| 猫咪免费人成网站在线观看入口| 青青久久精品国产免费看| 男女拍拍拍免费视频网站| 中文字幕久精品免费视频 | 亚洲av永久中文无码精品综合| 亚洲大码熟女在线观看| 美女被吸屁股免费网站| 成人免费区一区二区三区| 131美女爱做免费毛片| 免费看国产成年无码AV片| 国产国产成年年人免费看片| 亚洲午夜精品久久久久久浪潮| 亚洲精品成人片在线观看精品字幕| 亚洲午夜未满十八勿入| 亚洲熟妇自偷自拍另欧美| 美女一级毛片免费观看| 中国一级全黄的免费观看| 久艹视频在线免费观看| 久久久久免费看黄A片APP| 免费一级毛片免费播放| 午夜亚洲AV日韩AV无码大全| 久久精品国产亚洲αv忘忧草| 国产精品亚洲综合天堂夜夜| 光棍天堂免费手机观看在线观看 | 国产精品福利在线观看免费不卡|