android网络编程_socket(一)
转载http://www.eoeandroid.com/thread-97477-1-1.html
小知识点:UDP协议和TCP协议的不同。UDP是把数据都打成数据包,数据包上自带通信的地址,但是数据包发出去之后UDP协议不能保证你能否收到。而TCP协议要求接收方收到数据后给个回应,当发送重要数据的时候就可以选择TCP协议。UDP发送数据的量是有限的,而TCP是没有限制的,当然这导致UDP很快,TCP相对慢点。根据不同的情况,有不同的选择。TCP能保证数据传输的成功性,UDP只传输,不保证传输的正确性。
一、通信的基本结构:客户端和服务器端
客户端这边是Socket类:客户端指定给某个服务器端上的某个端口发送消息。比如向56.152.16.5这台机器的19001号端口发送消息。
服务器端是ServiceSocket类:服务器端就在19001号这个端口上监听,一旦有消息来立刻捕捉还可以有所回应。
客户端通过OutputStream向服务器端发送数据,服务器端通过InputStream获取数据,即OutputStream(发)——>InputStream(收)。以字节流的方式获取数据。
如果服务器端想回发消息也是同样的道理。
二、实例讲解编写服务器端和客户端
1. 服务器端:这是个纯java的project,单独在一个工程。
01.import java.io.BufferedReader;
02.import java.io.IOException;
03.import java.io.InputStreamReader;
04.import java.net.ServerSocket;
05.import java.net.Socket;
06.
07.public class ServerSocketText {
08.
09. public static void main(String[] args) {
10. new ServerThread().start();
11.
12. }
13.
14.}
15. 16.// 创建一个线程在后台监听
17.class ServerThread extends Thread {
18. private static int Port = 19001;
19. ServerSocket serversocket = null;
20. 21. public void run() {
22. 23. try {
24. // 创建一个serversocket对象,并让他在Port端口监听
25. serversocket = new ServerSocket(Port);
26. while (true) {
27. // 调用serversocket的accept()方法,接收客户端发送的请求
28. Socket socket = serversocket.accept();
29. BufferedReader buffer = new BufferedReader(
30. new InputStreamReader(socket.getInputStream()));
31. // 读取数据
32. String msg = buffer.readLine();
33. System.out.println("msg:" + msg);
34. }
35. 36. } catch (IOException e) {
37. e.printStackTrace();
38. } finally {
39. try {
40. serversocket.close();
41. } catch (IOException e) {
42. e.printStackTrace();
43. }
44. }
45. }
46.}
2. 客户端:这是个android的客户端,用于发送消息。
01.import java.io.BufferedWriter;
02.import java.io.IOException;
03.import java.io.OutputStreamWriter;
04.import java.io.PrintWriter;
05.import java.net.InetAddress;
06.import java.net.NetworkInterface;
07.import java.net.Socket;
08.import java.net.SocketException;
09.import java.net.UnknownHostException;
10.import java.util.Enumeration;
11.
12.import android.app.Activity;
13.import android.os.Bundle;
14.import android.util.Log;
15.import android.view.View;
16.import android.view.View.OnClickListener;
17.import android.widget.Button;
18.import android.widget.EditText;
19.
20.public class Client extends Activity {
21. private static String IpAddress = "56.152.16.5";
22. private static int Port = 10000;
23. private EditText edittext = null;
24. private Button send = null;
25. Socket socket = null;
26.
27. @Override
28. public void onCreate(Bundle savedInstanceState) {
29. super.onCreate(savedInstanceState);
30. setContentView(R.layout.main);
31. edittext = (EditText) findViewById(R.id.edittext);
32. send = (Button) findViewById(R.id.send);
33. send.setOnClickListener(new OnClickListener() {
34.
35. @Override
36. public void onClick(View v) {
37. sendMsg();
38.
39. }
40. });
41. }
42.
43. // 发送信息
44. public void sendMsg() {
45.
46. try {
47. // 创建socket对象,指定服务器端地址和端口号
48. socket = new Socket(IpAddress, Port);
49. // 获取 Client 端的输出流
50. PrintWriter out = new PrintWriter(new BufferedWriter(
51. new OutputStreamWriter(socket.getOutputStream())), true);
52. // 填充信息
53. out.println(edittext.getText());
54. System.out.println("msg=" + edittext.getText());
55. // 关闭
56.
57. } catch (UnknownHostException e1) {
58. e1.printStackTrace();
59. } catch (IOException e1) {
60. e1.printStackTrace();
61. } finally {
62. try {
63. socket.close();
64. } catch (IOException e) {
65. e.printStackTrace();
66. }
67. }
68.
69. }
70.}
3. 注意事项:
记得在AndroidManifest.xml中添加你的网络权限
<uses-permission android:name="android.permission.INTERNET"/>
activity布局就是一个edittext和已个button,所以没贴出代码。
运行时最好先android在服务器端,这样客户端发消息时才方便查看。
4. 疑问:
既然本例中socket建立的是TCP连接,那么客户端发完数据后socket关闭,服务器端socket也应该关闭,也就是不能再继续监听了,是这样吗?可能是,服务器的一个主线程在10000口监听,接受到一个客户端的请求则建立连接,并将该连接分配给一个线程,后主线程继续监听其他线程的请求。分配的线程接过连接大棒,与客户端交互。一旦客户端关闭连接,则该线程也关闭连接,结束。
android网络编程_socket(一)的更多相关文章
- Android网络编程只局域网传输文件
Android网络编程之局域网传输文件: 首先创建一个socket管理类,该类是传输文件的核心类,主要用来发送文件和接收文件 具体代码如下: package com.jiao.filesend; im ...
- Android网络编程基础
Android网络编程只TCP通信 TCP 服务器端工作的主要步骤如下.步骤1 调用ServerSocket(int port)创建一个ServerSocket,并绑定到指定端口上.步骤2 调用acc ...
- Android网络编程系列 一 TCP/IP协议族
在学习和使用Android网路编程时,我们接触的仅仅是上层协议和接口如Apache的httpclient或者Android自带的httpURlconnection等等.对于这些接口的底层实现我们也有必 ...
- Android网络编程系列 一 Socket抽象层
在<Android网络编程>系列文章中,前面已经将Java的通信底层大致的描述了,在我们了解了TCP/IP通信族架构及其原理,接下来我们就开始来了解基于tcp/ip协议层的Socket抽 ...
- Android 网络编程 Socket
1.服务端开发 创建一个Java程序 public class MyServer { // 定义保存所有的Socket,与客户端建立连接得到一个Socket public static List< ...
- Android网络编程概述
Android网络编程概述 首先,应该了解的几个问题: 1)Android平台网络相关API接口 a) java.net.*(标准Java接口) java.net.*提供与联网有关的类,包括流.数据包 ...
- Android网络编程http派/申请服务
最近的研究Android网络编程知识,这里有一些想法,今晚学习.与您分享. 在实际的应用程序的开发非常需要时间appserver请求数据,那么app怎样发送请求呢?以下的代码就是当中的一种情况.使用H ...
- 转 Android网络编程之使用HttpClient批量上传文件 MultipartEntityBuilder
请尊重他人的劳动成果,转载请注明出处:Android网络编程之使用HttpClient批量上传文件 http://www.tuicool.com/articles/Y7reYb 我曾在<Andr ...
- Android网络编程要学的东西与Http协议学习
本节引言: 本节开始我们来学习Android网络编程相关的一些东西:Android端网络编程是要干嘛?http协议的学习,使用自带扣脚Json解析类解析Json,XML解析常用的几种方式,HttpUr ...
随机推荐
- GIS基础软件及操作(十)
原文 GIS基础软件及操作(十) 练习十.网络分析 (1) 加深对网络分析基本原理.方法的认识:(2) 熟练掌握ARCGIS下进行道路网络分析的技术方法:(3) 结合实际.掌握利用网络分析方法解决地学 ...
- mysql自动化安装脚本(二进制安装)
为了日后安装数据库方便,遂写了一个自动安装MySQL的脚本: 测试可以安装mariadb和MySQL-5.7.X 安装前配置好对应的my.cnf文件放在/tmp路径下 将启动脚本mysql3306放在 ...
- BooleanToColorConverter
public class BooleanToColorConverter : IValueConverter { public object Convert(object value, Type ta ...
- Android零基础入门第43节:ListView优化和列表首尾使用
原文:Android零基础入门第43节:ListView优化和列表首尾使用 前面连续几期都在学习ListView的各种使用方法,如果细心的同学可能会发现其运行效率是有待提高的,那么本期就来一起学习有哪 ...
- Redaht7/Oracle Linux7 + ORA11g : ohasd fails to start(Doc ID 1959008.1)
APPLIES TO: Oracle Database - Standard Edition - Version 11.2.0.4 to 12.1.0.1 [Release 11.2 to 12.1] ...
- delphi多版本安装方法
delphi tokyo和其他版本并存的安装方法 1.安装delphi 10.2 tokyo 破解后写入D:\Program Files (x86)\Embarcadero\Studio\19.0\b ...
- Qt4.8.6与VS2008的集成开发环境的安装配置
一.安装编译Qt 1. 在Windows下用Qt做开发,编译器可以用mingw的gcc/g++,也可以用VS. 2. 安装VS2008集成开发环境(完全安装). 3. 安装qt4.8.6(qt-op ...
- QTcpSocket 对连接服务器中断的不同情况进行判定
http://blog.csdn.net/goforwardtostep/article/details/52300335
- Spark学习之路(十三)—— Spark Streaming 与流处理
一.流处理 1.1 静态数据处理 在流处理之前,数据通常存储在数据库,文件系统或其他形式的存储系统中.应用程序根据需要查询数据或计算数据.这就是传统的静态数据处理架构.Hadoop采用HDFS进行数据 ...
- Kafka 学习之路(四)—— Kafka消费者详解
一.消费者和消费者群组 在Kafka中,消费者通常是消费者群组的一部分,多个消费者群组共同读取同一个主题时,彼此之间互不影响.Kafka之所以要引入消费者群组这个概念是因为Kafka消费者经常会做一些 ...