国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

Android socket如何實現文件列表動態訪問

瀏覽:3日期:2022-09-18 09:08:39
目錄idea服務端更新安卓端更新

Android socket如何實現文件列表動態訪問

idea服務端更新

Android socket如何實現文件列表動態訪問

為了防止代碼量上升可能帶來的結構雜亂,我們對服務端架構進行優化,server包負責socket服務基礎實現,data包負責處理各種安卓端的命令。

將readSocketMsg,writeBackMsg方法單獨拿出,創建一個SocketMsg方法類,專門負責數據流的讀取與寫入。

SocketMsg.java

package lrz.server;import java.io.*;import java.net.Socket;import java.util.ArrayList;public class SocketMsg { public static ArrayList<String> readSocketMsg(Socket socket) throws IOException {ArrayList<String> msgList=new ArrayList<String>();InputStream inputStream = socket.getInputStream();InputStreamReader reader = new InputStreamReader(inputStream, 'utf-8');BufferedReader bufferedReader=new BufferedReader(reader);String lineNumStr = bufferedReader.readLine();int lineNum=Integer.parseInt(lineNumStr);for(int i=0;i<lineNum;i++){ String str = bufferedReader.readLine(); msgList.add(str);}//讀取結束后,輸入流不能關閉,此時關閉,會將socket關閉,從而導致后續對socket寫操作無法實現return msgList; } public static void writeBackMsg(Socket socket, ArrayList<String> msgBackList) throws IOException {BufferedOutputStream os = new BufferedOutputStream(socket.getOutputStream());OutputStreamWriter writer=new OutputStreamWriter(os,'UTF-8');writer.write(''+msgBackList.size()+'n'); //未真正寫入的輸出流,僅僅在內存中writer.flush(); //寫入輸出流,真正將數據傳輸出去for(int i=0;i<msgBackList.size();i++){ writer.write(msgBackList.get(i)+'n'); writer.flush();} }}

創建NetFileData.java作為文件夾訪問的方法類,將exeDir()方法放入其中。

NetFileData.java

package lrz.data;import java.io.File;import java.text.SimpleDateFormat;import java.util.ArrayList;import java.util.Date;public class NetFileData { public static ArrayList<String> exeDir(String cmdBody) throws Exception {// TODO Auto-generated method stubArrayList<String> backList=new ArrayList<String>();File file = new File(cmdBody);File[] listFiles = file.listFiles();for(File mfile:listFiles){ String fileName = mfile.getName(); long lastModified = mfile.lastModified();//獲取文件修改時間 SimpleDateFormat dateFormat = new SimpleDateFormat('yyyy-MM-dd HH:mm:ss');//給時間格式,例如:2018-03-16 09:50:23 String fileDate = dateFormat.format(new Date(lastModified));//取得文件最后修改時間,并按格式轉為字符串 String fileSize='0'; String isDir='1'; if(!mfile.isDirectory()){//判斷是否為目錄isDir='0';fileSize=''+mfile.length(); } backList.add(fileName+'>'+fileDate+'>'+fileSize+'>'+isDir+'>');}return backList; }}

ServerSocket01.java主函數則將以上方法移除,改為調用

package lrz.server;import lrz.data.NetFileData;import java.io.*;import java.net.InetAddress;import java.net.NetworkInterface;import java.net.ServerSocket;import java.net.Socket;import java.util.ArrayList;import java.util.Enumeration;public class ServerSocket01 { int port = 8019;// 自定義一個端口,端口號盡可能挑選一些不被其他服務占用的端口,祥見http://blog.csdn.net/hsj521li/article/details/7678880 static int connect_count = 0;// 連接次數統計 ArrayList<String> msgBackList; public ServerSocket01() {// TODO Auto-generated constructor stub } public ServerSocket01(int port) {super();this.port = port; } private void printLocalIp(ServerSocket serverSocket) {// 枚舉打印服務端的IPtry { System.out.println('服務端命令端口prot=' + serverSocket.getLocalPort()); Enumeration<NetworkInterface> interfaces = null; interfaces = NetworkInterface.getNetworkInterfaces(); while (interfaces.hasMoreElements()) {NetworkInterface ni = interfaces.nextElement();Enumeration<InetAddress> addresss = ni.getInetAddresses();while (addresss.hasMoreElements()) { InetAddress nextElement = addresss.nextElement(); String hostAddress = nextElement.getHostAddress(); System.out.println('本機IP地址為:' + hostAddress);} }} catch (Exception e) { e.printStackTrace();} } public void work() throws IOException {// 注意:由于Socket的工作是阻塞式,Android端Socket的工作必須在新的線程中實現,若在UI主線程中工作會報錯ServerSocket serverSocket = new ServerSocket(port);printLocalIp(serverSocket);while (true) {// 無限循環,使之能結束當前socket服務后,準備下一次socket服務 System.out.println('Waiting client to connect.....'); Socket socket = serverSocket.accept();// 阻塞式,直到有客戶端連接進來,才會繼續往下執行,否則一直停留在此代碼 System.out.println('Client connected from: ' + socket.getRemoteSocketAddress().toString()); ArrayList<String> cmdList= SocketMsg.readSocketMsg(socket); cmdList.forEach(s -> System.out.println(s)); String cmdbody=cmdList.get(0); try {msgBackList= NetFileData.exeDir(cmdbody); } catch (Exception e) {e.printStackTrace(); } msgBackList.forEach(s -> System.out.println(s)); SocketMsg.writeBackMsg(socket,msgBackList); socket.close(); System.out.println('當前Socket服務結束');} } /** * @param args */ public static void main(String[] args) {// TODO Auto-generated method stubtry { new ServerSocket01().work();} catch (IOException e) { // TODO Auto-generated catch block e.printStackTrace();} }}安卓端更新

使用listview顯示文件夾內容,并且實現動態訪問。

MainActivity.java更新了簡單的listview顯示,設立互動事件,在點擊某個列表部分時向服務端發動指定命令,返回結果后更新列表,實現互動效果。

package com.example.android_app;import androidx.appcompat.app.AppCompatActivity;import android.os.Bundle;import androidx.annotation.NonNull;import android.os.Build;import android.os.Handler;import android.os.Message;import android.view.View;import android.widget.AdapterView;import android.widget.ArrayAdapter;import android.widget.Button;import android.widget.EditText;import android.widget.ListView;import android.widget.TextView;import android.widget.Toast;import java.util.ArrayList;public class MainActivity extends AppCompatActivity { public static final String KEY_SERVER_ACK_MSG = 'KEY_SERVER_ACK_MSG'; private Handler handler = null; EditText url,way,dir; ListView lv; Button submit; SocketClient socketClient=null; String here; ArrayList<String> data; int port; @Override protected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);url=findViewById(R.id.url);way=findViewById(R.id.way);dir=findViewById(R.id.dir);lv=findViewById(R.id.listview);submit=findViewById(R.id.submit);handler=new Handler(new Handler.Callback() { @Override public boolean handleMessage(@NonNull Message msg) {Bundle data_bundle = msg.getData();data=data_bundle.getStringArrayList(KEY_SERVER_ACK_MSG);data=dataMaker();printAdapter(data);return false; }});submit.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) {port=Integer.parseInt(way.getText().toString());here=dir.getText().toString();getdata(); }});lv.setOnItemClickListener(new AdapterView.OnItemClickListener() { @Override public void onItemClick(AdapterView<?> parent, View view, int position, long id) {here=here+'/'+data.get(position);getdata(); }}); } private void getdata() {socketClient=new SocketClient(url.getText().toString(),port,handler);socketClient.work(here); } private ArrayList<String> dataMaker() {ArrayList<String> dataResult=new ArrayList<>();int i=data.size();for (int j = 0; j <i ; j++) { String str=data.get(j); str=str.substring(0,str.indexOf('>')); dataResult.add(str);}return dataResult; } private void printAdapter(ArrayList<String> data) {ArrayAdapter<String> arrayAdapter=new ArrayAdapter<>(this,android.R.layout.simple_list_item_1,data);lv.setAdapter(arrayAdapter); }}

SocketClient.java無變動

activity_main.xml布局添加listview,代替原先的textview

<?xml version='1.0' encoding='utf-8'?><LinearLayout xmlns:android='http://schemas.android.com/apk/res/android' xmlns:app='http://schemas.android.com/apk/res-auto' android:orientation='vertical' android:layout_width='match_parent' android:layout_height='match_parent'> <LinearLayoutandroid:layout_width='match_parent'android:layout_height='wrap_content'android:orientation='horizontal'><EditText android:layout_width='0dp' android:layout_height='wrap_content' android:layout_weight='3' android: android:text='服務端ip'/><EditText android:layout_width='0dp' android:layout_height='wrap_content' android:layout_weight='3' android: android:text='8019'/> </LinearLayout> <EditTextandroid:layout_width='match_parent'android:layout_height='wrap_content'android: android:text='d://'/> <Buttonandroid:layout_width='match_parent'android:layout_height='wrap_content'android:text='submit'android: /> <ListViewandroid:layout_width='match_parent'android:layout_height='wrap_content'android: /></LinearLayout>

補充一點:

安卓端訪問的ip在服務端中查看,ip為服務端網絡ip,我是紅色圈中的,可以都試一下,一般都是倒數第二個長得像ip的這個,port在服務端主函數中設置,可以是任何數,8019為常用端

Android socket如何實現文件列表動態訪問

以上就是Android socket如何實現文件列表動態訪問的詳細內容,更多關于Android socket實現列表動態訪問的資料請關注好吧啦網其它相關文章!

標簽: Android
相關文章:
主站蜘蛛池模板: 日本理论片免费高清影视在线观看 | 国产成人精品久久综合 | 中文字幕有码在线播放 | 99福利网 | 一区二区三区在线免费看 | 日本阿v精品视频在线观看 日本阿v视频在线观看高清 | 国产成人99久久亚洲综合精品 | 国产欧美va欧美va香蕉在线 | 精品久久久久久国产免费了 | 日本三级香港三级人妇r | 亚洲三级大片 | 亚洲一区二区在线免费观看 | 97影院理伦在线观看 | 狠狠色丁香九九婷婷综合五月 | 57pao强力打造手机版 | 成年大片免费视频播放二级 | 色视频网站大全免费 | 国产午夜精品理论片 | 国产成人亚洲精品影院 | 日日碰日日操 | 国产一区二区三区四区在线观看 | 国产成人精品一区二区免费视频 | 亚洲欧美综合视频 | 91啦丨国产丨 | 久久成人免费网站 | 午夜毛片不卡高清免费 | 成人中文在线 | 男人操美女 | 亚洲视频中文字幕在线 | 亚洲韩精品欧美一区二区三区 | 国产三级日本三级日产三 | 美女张开腿给男人捅 | avtt加勒比手机版天堂网 | 国内精品久久久久久久久蜜桃 | 日本a级毛片视频播放 | 国产亚洲欧美一区二区三区 | 国产女人伦码一区二区三区不卡 | 夜色1网站| 九九九热视频 | 京东一热本色道久久爱 | 视频亚洲一区 |