##Android基礎網絡次日css
通常在公司開發客戶端和服務端的編碼要保持一致。 android端的默認編碼是utf-8; 作url請求時須要對參數進行URLEncode編碼. URL url = new URL("http://192.168.13.83:8080/itheima74/servlet/LoginServlet?username="+URLEncoder.encode(username)+"&pwd="+URLEncoder.encode(password)); connection.setDoOutput(true); connection.getOutputStream().write(parmes.getBytes());
URLEncode
HttpClient: get方式: //使用HttpClient請求服務器將用戶密碼發送服務器驗證 try{ String path = "http://192.168.13.83:8080/itheima74/servlet/LoginServlet?username="+URLEncoder.encode(username,"utf-8")+"&pwd="+URLEncoder.encode(password,"utf-8"); //1.建立一個httpClient對象 HttpClient httpclient = new DefaultHttpClient(); //2.設置請求的方式 HttpGet httpget = new HttpGet(path); //3.執行一個http請求 HttpResponse response = httpclient.execute(httpget); //4.獲取請求的狀態碼, StatusLine statusLine = response.getStatusLine(); int code = statusLine.getStatusCode(); //5.判斷狀態碼後獲取內容 if(code == 200){ HttpEntity entity = response.getEntity();//獲取實體內容,中封裝的有http請求返回的流信息 InputStream inputStream = entity.getContent(); //將流信息轉換成字符串 String result = StreamUtils.streamToString(inputStream); Message msg = Message.obtain(); msg.what = 1; msg.obj = result; handler.sendMessage(msg); } }catch (Exception e) { e.printStackTrace(); } post方式: //使用UrlConncetion請求服務器將用戶密碼發送服務器驗證 try{ String path = "http://192.168.13.83:8080/itheima74/servlet/LoginServlet"; //1.建立一個httpclient對象 HttpClient httpclient = new DefaultHttpClient(); //2.建立一個請求方式 HttpPost httppost = new HttpPost(path); //建立集合封裝數據 ArrayList<BasicNameValuePair> arrayList = new ArrayList<BasicNameValuePair>(); BasicNameValuePair nameValuePair = new BasicNameValuePair("username",username); arrayList.add(nameValuePair); BasicNameValuePair nameValuePair1 = new BasicNameValuePair("pwd",password); arrayList.add(nameValuePair1); //建立一個Entity UrlEncodedFormEntity entity = new UrlEncodedFormEntity(arrayList, "utf-8"); //設置請求時的內容 httppost.setEntity(entity); //3.執行一個請求,返回一個response對象 HttpResponse response = httpclient.execute(httppost); //4.獲取狀態碼 int code = response.getStatusLine().getStatusCode(); //5.判斷並獲取內容 if(code == 200){ HttpEntity entity1 = response.getEntity();//獲取實體內容,中封裝的有http請求返回的流信息 InputStream inputStream = entity1.getContent(); //將流信息轉換成字符串 String result = StreamUtils.streamToString(inputStream); Message msg = Message.obtain(); msg.what = 2; msg.obj = result; handler.sendMessage(msg); } }catch (Exception e) { e.printStackTrace(); }
get方式: public static void requestNetForGetLogin(final Context context,final Handler handler ,final String username, final String password) { //使用HttpClient請求服務器將用戶密碼發送服務器驗證 try{ String path = "http://192.168.13.83:8080/itheima74/servlet/LoginServlet?username="+URLEncoder.encode(username,"utf-8")+"&pwd="+URLEncoder.encode(password,"utf-8"); //建立一個AsyncHttpClient對象 AsyncHttpClient asyncHttpClient = new AsyncHttpClient(); asyncHttpClient.get(path, new AsyncHttpResponseHandler() { [@Override](https://my.oschina.net/u/1162528) public void onSuccess(int statusCode, Header[] headers, byte[] responseBody) { //statusCode:狀態碼 headers:頭信息 responseBody:返回的內容,返回的實體 //判斷狀態碼 if(statusCode == 200){ //獲取結果 try { String result = new String(responseBody,"utf-8"); Toast.makeText(context, result, 0).show(); } catch (UnsupportedEncodingException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } [@Override](https://my.oschina.net/u/1162528) public void onFailure(int statusCode, Header[] headers, byte[] responseBody, Throwable error) { System.out.println("...............onFailure"); } }); }catch (Exception e) { e.printStackTrace(); } } post方式: String path = "http://192.168.13.83:8080/itheima74/servlet/LoginServlet"; AsyncHttpClient asyncHttpClient = new AsyncHttpClient(); RequestParams params = new RequestParams(); params.put("username", username); params.put("pwd", password); //url: parmas:請求時攜帶的參數信息 responseHandler:是一個匿名內部類接受成功過失敗 asyncHttpClient.post(path, params, new AsyncHttpResponseHandler() { [@Override](https://my.oschina.net/u/1162528) public void onSuccess(int statusCode, Header[] headers, byte[] responseBody) { //statusCode:狀態碼 headers:頭信息 responseBody:返回的內容,返回的實體 //判斷狀態碼 if(statusCode == 200){ //獲取結果 try { String result = new String(responseBody,"utf-8"); Toast.makeText(context, result, 0).show(); } catch (UnsupportedEncodingException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } [@Override](https://my.oschina.net/u/1162528) public void onFailure(int statusCode, Header[] headers, byte[] responseBody, Throwable error) { } });
使用第三方utils作文件上傳。 public void fileupload(View v){ try{ EditText et_filepath = (EditText) findViewById(R.id.et_filepath); //獲取輸入的文件地址 String filepath = et_filepath.getText().toString().trim(); //使用開源Utils作上傳操做 AsyncHttpClient asyncHttpClient = new AsyncHttpClient(); RequestParams params = new RequestParams(); params.put("filename", new File(filepath)); //url : 請求服務器的url asyncHttpClient.post("http://192.168.13.83:8080/itheima74/servlet/UploaderServlet", params, new AsyncHttpResponseHandler() { [@Override](https://my.oschina.net/u/1162528) public void onSuccess(int statusCode, Header[] headers, byte[] responseBody) { if(statusCode == 200){ Toast.makeText(MainActivity.this, "上傳成功", 0).show(); } } @Override public void onFailure(int statusCode, Header[] headers, byte[] responseBody, Throwable error) { } }); }catch (Exception e) { e.printStackTrace(); } }
1.線程越多下載越快?? 不是。 與 本地網絡帶寬, 服務器資源的帶寬 有關 2.迅雷:3-5個。 多線程下載的步驟: 1.要知道服務端資源的大小。 經過URLConnection請求服務器url獲取。 UrlConnection.getContentLength();//資源的大小 2.在本地建立一個與服務端資源一樣大小的一個文件(佔位) //file : 文件; mode:文件的模式,rwd:直接寫到底層設備,硬盤 RandomAccessFile randomfile =new RandomAccessFile(File file,String mode) randomfile.setLength(long size);//建立一個文件和服務器資源同樣大小 3.要分配每一個線程下載文件的開始位置和結束位置。 4.開啓線程去執行下載 經過UrlConnection下載部分資源。 注意: 1.須要Range頭,key:Range value:bytes:0-499 urlconnection.setRequestPropety("Range","bytes:0-499") 2.須要設置每一個線程在本地文件的保存的開始位置 RandomAccessFile randomfile =new RandomAccessFile(File file,String mode) randomfile.seek(int startPostion);//本次線程下載保存的開始位置。 5.要知道每一個線程下載完畢。
安智: sdcard沒有判斷。uc
public void download(View v){ EditText et_url = (EditText) findViewById(R.id.et_url); String url = et_url.getText().toString().trim(); //1.建立httpUtils對象 HttpUtils httpUtils = new HttpUtils(); //2.調用download方法 url:下載的地址 target:下載的目錄 callback:回調 httpUtils.download(url, "/sdcard/feiqiu/feiq.exe", new RequestCallBack<File>() { @Override public void onLoading(long total, long current, boolean isUploading) { System.out.println("total:"+total+";current:"+current); super.onLoading(total, current, isUploading); } @Override public void onSuccess(ResponseInfo<File> responseInfo) { System.out.println(responseInfo.result); } @Override public void onFailure(HttpException error, String msg) { // TODO Auto-generated method stub } }); }
總結:java
第一天: android入門: 1.環境搭建 jdk+ eclipse+android sdk 2,項目結構介紹 熟悉各個目錄的用途. 3.五大布局 LinearLayout + RelativeLayout 控件: EditText TextVeiw Button ImageView ListView ScrollView CheckBox ProgressBar 4.adb的練習 adb devices adb install ; adb uninstall ; adb push ;adb pull;logcat ;adb shell adb kill-server ;adb start-server ;adb shell+input text ;adb shell+monkey 5.android系統架構 4層; 6. 電話撥號器 Intent intent = new Intent(); intent.setAction(); intent.setData(); startActivity(); 次日:數據的存儲 1.登陸案例 File file = context.getFilesDir(); context.openFileOutput(String filename,String mode);//mode:Context.Mode_Private context.openFileInput(String filename); 2.sdcard的使用 1.權限 2.硬性編碼 File file = Enviroment.getExternalStorageDirectory();//獲取sdcard的目錄文件 3.判斷sdcard狀態 boolean state = Environment.getExternalStorageState().equals(Environment.MEDIA_MOUNTED) 4.判斷sdcard大小 File file = Enviroment.getExternalStorageDirectory();//獲取sdcard的目錄文件 long usablespace= file.getUsableSpace(); String usablespace_str= Formatter.foramatterFilesize(long size); 4.SharedPreference的使用 1.保存數據 a. 獲取一個sharedpreference對象 Sharedpreference sharedpreference = context.getShare..(String name ,String mode); b.獲得一個Editor對象 Editor editor = sharedpreference.edit(); c.往Editor中添加數據 editor.putString(String key ,Stirng value); d.提交Editor editor.commit(); 2.讀取數據 a. 獲取一個sharedpreference對象 Sharedpreference sharedpreference = context.getShare..(String name ,String mode); b.使用sharedpreference獲取數據 sharedpreference.getString(String key ,String defValue); 5.xml的生成與解析 a.生成 XmlSerializer 模板代碼 b.解析 XmlPullParser 模板代碼
第三天: 數據庫 listviewandroid
1.數據庫的使用 對於一個數據庫2個類, 1是幫助類 SqliteOpenHelper 2是Dao類封裝增刪改查 1.建立數據庫 建立一個類集成SqliteOpenHelper 建立一個構造方法設置數據庫的名稱,版本,實現兩個方法,oncteate:特別適合作表結構的初始化,數據庫第一次建立的時候調用。 onupgrade:特別適合作表結構的修改,數據庫版本發生改變時調用 2.增刪改查 a.建立一個幫助類的對象,並調用getReadableDatabase或getWriteableDatabase幫助獲取一個SqliteDatabase數據庫操做對象。 b.使用SqliteDatabase數據庫操做對象作增刪改查 2種方式 1.調用execSql(String sql ,Object[] obj)能夠作增刪改,調用rawQuery(String sql ,Object[] obj)作查詢,返回一個Cursor對象,遍歷Cursor獲取查詢結果。 2.調用insert delete update query作增刪改查 第一種方式適合作查詢,第二種方式有了返回值,更適合作的增刪改 2.listview的使用 1.寫佈局 2.找到listview,並設置條目的點擊事件 listview.setOnItemClickListener(OnItemClickListener on); 3.獲取listview條目上要展現的數據到list集合中,傳給adapter作控制顯示 4.寫一個類集成BaseAdapter,實現四個方法,寫一個構造方法接受list集合中的數據 getCount();返回listview要顯示的條目數 getItem(int postion);返回listveiw上postion位置上的Bean對象 getId();返回postion *****getView();告訴listview條目要顯示的內容 1.模板代碼優化listview 2.建立一個item佈局轉化成view對象做爲getview的返回值 3.獲取item佈局中子控件 4.獲取list集合中postion位置的Bean對象 5.將Bean中的數據設置給子控件作展現 5.建立一個adapter,並設置給listview listveiw.setAdapter(ListAdapter adapter) 6.實現條目點擊事件的操做
第四天:網絡編程sql
1.使用UrlConnection鏈接網絡獲取數據 1.建立一個Url對象 2.使用URL對象獲取一個HttpUrlConnection 3.設置connection對象的參數 4.獲取狀態碼 5.獲取流信息。 2.主線程不能作耗時的操做(網絡請求),只能在子線程中請求;子線程不能更新UI;解決辦法:Handler 3.使用handler 1.主線程建立Handler,重寫handlermessage方法 2.子線程中建立Message對象,攜帶子線程獲取的數據 3.使用主線程的handlerf發送message到主線程 4.主線程的handlerMessage方法接受數據,處理Ui 4.流轉圖片 Bitmap bitmap = BitmaptFatory.decodeStream(InputStream in); 5.網絡版新聞: 數據庫 listview URLConnection Json解析 Handler json解析: JsonObject JsonArray 6.get post請求網絡 post提交數據須要設置內容到寫入流: connection.setDoOut(true); connection.getOutputStream().write(byte[]); 7.解決亂碼問題 1.客戶端和服務端編碼保持一致 2.提交的數據須要用URLEncode編碼
第五天 網絡請求2 HttpClient 文件上傳 多線程下載shell
1.HttpClent: 1.建立一個DefaultHttpclient 2.建立一個請求方式 HttpGet HttpPost Arraylist<BaicNameValueparire> list = new Arraylist<BaicNameValueparire>(); BaicNameValueparire valuse = BaicNameValueparire() valuse.put(String key ,String valuse); list.add(valuse); UrlEncodeFormEntity entity = new UrlEncodeFormEntity(List<NameValuepare>); HttpPost.setEntity(entity); 3.httpclient執行請求 httpeclient.execut(HttpGet httpget) 4.獲取響應碼 httpclient.getStateLines().getstateCode(); 5.獲取內容 InputStream in = httpclient.getEntry.getContent(); 2.文件上傳 使用開源項目 AsycnHttpClient 3.多線程斷點續傳下載 1.獲取資源大小 2.本地建立一個與服務端一致的文件 RandmodAcecssFile 3.根據線程數量計算每一個線程下載的開始位置,結束位置 4.開啓線程進行真實的下載。 header : Range value : bytes:0-499 UrlConnection.setRequestProperty(String header , String value); 5.將讀取 的流分段寫入文件 RandmodAcecssFile file = new RandmodAcecssFile(File file,String mode); file.seek(int startIndex);//設置文件從哪裏開始寫入 6.ProgressBar : 主要屬性 : style 樣式 max 最大進度 progress 當前進度