package com.example.esp8266;

import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.PrintStream;
import java.net.Socket;

import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.Toast;

public class MainActivity extends Activity {
    private EditText edSend, edReceive;
    private Button btnConnect, btnSend;
    private Handler myHandler;
    private SendThread SendThread;
    private boolean isReceive = false;
    private boolean isConnect = false;
    private static final String HOST = "192.168.4.1";
    private static final int PORT = 333;
    String strMessage;
    Socket socket = null;

@Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        edSend = (EditText) findViewById(R.id.edSend);
        edReceive = (EditText) findViewById(R.id.edReceive);
        btnConnect = (Button) findViewById(R.id.btConnect);
        btnSend = (Button) findViewById(R.id.btSend);
        // 连接
        btnConnect.setOnClickListener(new View.OnClickListener() {

public void onClick(View v) {
                // TODO Auto-generated method stub
                if (!isConnect) {
                    new Thread(connectThread).start();
                    isConnect = true;
                }
            }
        });
        // 发送
        btnSend.setOnClickListener(new View.OnClickListener() {

public void onClick(View v) {
                // 启动发送线程
                new Thread(SendThread).start();
            }
        });
        myHandler = new Handler() {// UI主线程消息处理函数
            
            public void handleMessage(Message msg) {
                Bundle bundle = msg.getData();
                String string = bundle.toString();
                edReceive.setText(string);
            }
        };
    }

// 连接到服务器的接口
    Runnable connectThread = new Runnable() {
        
        public void run() {
            // TODO Auto-generated method stub
            try {
                socket = new Socket(HOST, PORT);
                if (socket != null)
                    Toast.makeText(getApplicationContext(), "连接成功",
                            Toast.LENGTH_LONG).show();
                else
                    Toast.makeText(getApplicationContext(), "连接失败",
                            Toast.LENGTH_LONG).show();
                // 初始化发送线程
                SendThread = new SendThread(socket);
            } catch (IOException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
    };
    // 接收消息的接口
    Runnable Receive = new Runnable() {
        InputStream inStream;
        private byte[] buffer;
        private String str = null;

public void run() {
            // TODO Auto-generated method stub
            while (!isReceive) {
                buffer = new byte[512];
                try {
                    inStream = socket.getInputStream();
                    inStream.read(buffer);
                } catch (IOException e) {
                    e.printStackTrace();
                }
                str = new String(buffer);
                Bundle bundle = new Bundle();
                bundle.get(str);
                Message message = new Message();
                message.setData(bundle);
                myHandler.sendMessage(message);
            }
        }
    };

// 发送线程
    private class SendThread extends Thread {
        private OutputStream outStream = null;

private String str = null;

SendThread(Socket socket) {
            try {
                outStream = socket.getOutputStream();
            } catch (IOException e) {
                e.printStackTrace();
            }
        }
        
        public void run() {
            // while(true){
            str = edSend.getText().toString().trim();
            PrintStream pt = new PrintStream(outStream);
            pt.print(str);
            new Thread(Receive).start();
            // }
        }
    }

protected void onDestroy() {
        // TODO Auto-generated method stub
        super.onDestroy();
        if (Receive != null) {
            isReceive = false;
            ((Thread) Receive).interrupt();
        }
    }

}

Android连接服务器端的Socket的更多相关文章

  1. Android连接热点的Socket文件传输

    最近把测试丢过来的种种BUG解决后,终于有时间去研究研究Socket通信,再加上以前做的WiFi连接和热点开启,于是有了现在的这篇博文:创建热点发送文件,让另一台手机连接热点接收文件. 效果图: 两台 ...

  2. Android连接socket服务器上传下载多个文件

    android连接socket服务器上传下载多个文件1.socket服务端SocketServer.java public class SocketServer { ;// 端口号,必须与客户端一致 ...

  3. Android学习六:Socket 使用

    1socket的作用 通过http去获取服务器的数据在有些情况下是行不通的,所有使用socket与服务器通信也是必须掌握的 2.代码 好了上代码,代码中有解释,首先是简单的服务端代码 package ...

  4. android开发系列之socket编程

    上周在项目遇到一个接口需求就是通讯系列必须是socket,所以在这篇博客里面我想谈谈自己在socket编程的时候遇到的一些问题. 其实在android里面实现一个socket通讯是非常简单的,我们只需 ...

  5. 基于libevent, libuv和android Looper不断演进socket编程 - 走向架构师之路 - 博客频道 - CSDN.NET

    基于libevent, libuv和android Looper不断演进socket编程 - 走向架构师之路 - 博客频道 - CSDN.NET 基于libevent, libuv和android L ...

  6. 轮询、长轮询、长连接、flash socket 的区别

    轮询:客户端定时向服务器发送Ajax请求,服务器接到请求后马上返回响应信息并关闭连接. 优点:后端程序编写比较容易. 缺点:请求中有大半是无用,浪费带宽和服务器资源. 实例:适于小型应用. 长轮询:客 ...

  7. android连接打印机

    android连接  网络打印,主要使用socket连接设备,发送指令给设备. 首先要有设备的IP,端口号一般默认的是9100 //打印设备网络IP etIp.setText("192.16 ...

  8. tcp连接是基于socket通信的吗

    https://zhidao.baidu.com/question/1305788160020716299.html ------ 网络七层协议 五层模型 TCP连接 HTTP连接 socket套接字 ...

  9. android 连接蓝牙打印机 BluetoothAdapter

    android 连接蓝牙打印机 BluetoothAdapter 源码下载地址:https://github.com/yylxy/BluetoothText.git public class Prin ...

随机推荐

  1. kindle完结书单

    1.一个人的好天气---青山七惠 2.嫌疑人X的献身---东野圭吾 3.活着---余华 4.最漫长的旅行---Nicholas Sparks 5.解忧杂货店---东野圭吾 6.追风筝的人---卡勒德· ...

  2. 常见的HTTP状态码(HTTP Status Code)说明

    作为一个互联网开发人员对于一些服务器返回的HTTP状态的意思都必须是了如指掌的,只有将这些状态码一一弄清楚,工作中遇到的各种问题才能够处理的得心应手.好了,下面就让我们来了解一下比较常见的HTTP状态 ...

  3. 压测过程中出现ops断崖式下跌原因及排解

    压测机器: 100台docker redis集群:16个分片 在开始压测的半个小时中,一直很稳定,ops稳定在20w左右.但是接下来突然ops断崖式下跌,ops降到了3w以下.然后持续一段时间,直至变 ...

  4. 略解ByteBuf

    说到ByteBuf,我们并不陌生,官网给的解释为,一个可以进行随机访问或者是顺序访问的字节集合,它是NIO buffers缓冲的底层抽象.既然是底层抽象,那么我们就可以基于其衍生出很多的具体实现出来, ...

  5. python-shogun安装问题

  6. Rhino学习教程——1.4

    状态栏 状态栏位于整个工作界面的下方,主要显示了一些系统操作时的信息. 根据不同的功能,可以将状态栏分成4个部分. 一.坐标系统 在状态栏左侧显示了当前所使用的坐标系统(“世界”或“工作平面”,可以通 ...

  7. sql排列组合

    一个表中4条记录,如何查询所有可能组成的结果. 例如: 1  2  3  4 四条记录,最后组成(12),(13),(14),(23),(24),(34) 最后sql如下: SELECT a.name ...

  8. 【webpack学习笔记】a01-基础构建

    webpack基于nodejs环境运行,首先确认已经安装了node.js. 基础构建流程 新建一个文件夹,这个就是你项目的根目录. 在命令行中使用npm init命令初始化npm,会得到一个 ==pa ...

  9. dev控件 xtraTabbedMdiManager 如何将关闭子窗体改为收回主窗体内

    前言 本文主要讲解 xtraTabbedMdiManager 如何将关闭子窗体改为收回主窗体内,顺便附上Float(浮动)的时候使窗体最大化,及指定只能某一个子窗体能浮动放大. 下面进入正题. 一.首 ...

  10. FastReport导出PDF乱码的问题

    1.电脑查看乱码,替换文本控件,使用RichObject,而不使用TextObject 2.电脑查看正常,手机查看乱码,导出的时候选择包含字体: Enbeded Fonts勾选框