① android連接servlet的問題
。。你的IP是區域網伺服器的IP,首先你先確定你的手機或者你的設備連接的WIFI是和你的伺服器是同一個區域網的。如果手機使用的是3G/4G網路是不能訪問的。
② Android登陸後如何判定是否登錄 並且在已經登錄的時候如何獲取用戶信息
給你詳細講一下。 比如系統有個登陸頁面(login.jsp): name:_________ password:____________ (登陸按鈕) 你按下登陸按鈕,就根據name和password去資料庫裡面查,如果判斷有此用戶並且密碼正確,就設置一個session的鍵對應的值,鍵名字自己取,統一即可,比如"userInfo",代碼就是servlet的doPost裡面 HttpSession session = request.getSession(); Hashtable userInfo = new Hashtable(); userInfo.setAttribute("userName", request.getParameter("userName"); userInfo.setAttribute("passWords", Util.toSecret( request.getParameter("passWords)); //密碼最好加密 session.setAttribute("userInfo", userInfo); session是在一定時期(超時時間內)一直存在的,這段時間內你可以隨時判斷用戶是否合法,否則就退回登陸頁面。 在任何除了登陸頁面以外的頁面訪問,只需判斷有沒有這個鍵值,沒就到登陸頁面,否則進正常頁面。(最好寫在servlet中,讓servlet當頁面控制器)代碼如下: if ( session.getAttribute("userInfo")==null ) { response.sendRedirect(request.getServletContext.getPath() + "/login.jsp"); } else { request.getRequestDispatcher("/正常頁面.jsp").forward(request,response); }
③ 請問android 怎麼和servlet 進行交互 通過android界面登錄,由servlet進行驗證然後返回驗證信息
網路編程,每本書里都有吧。。
Socket,Http都行
④ android登陸驗證是在哪裡(客戶端activity還是伺服器servlet)登陸驗證的流程是怎麼樣的
Activity通過EditText獲取用戶輸入的用戶名和密碼,先進行初步判斷,看是否符合標准(比如用戶名、密碼的長度,及包含漢字等),如果不通過彈出提示,通輪頃過的話要先判斷網路連接狀況。有網路連接時可以以http或者socket方式與伺服器通信。如果是http的優先使用post方式,這樣不會把用戶信息暴露在罩桐基url中。servlet接收到用戶名和密碼後,經過資料庫查詢,判斷各種情況,例如用戶名不存在,密碼不正確等情況,並把結果返回給Activity。具體的數據格式協議你自己訂了。Activity根據返回的結果,按照項目需求進行相應的提示或者操作即可。另外4.0以後網路請求不能在物謹Activity的ui線程中進行,需要用Thread發送網路請求,還要考慮網路請求超時的情況。希望能幫到你。