Android之Socket通讯

2024-08-31 09:48
文章标签 android 通讯 socket

本文主要是介绍Android之Socket通讯,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Android里面使用Socket与服务器之间进行通讯:

首先建立一个SocThread类

 
package com.junto.sockettest;import android.content.Context;
import android.content.SharedPreferences;
import android.os.Handler;
import android.os.Message;
import android.util.Log;import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.io.PrintWriter;
import java.net.Socket;
import java.net.UnknownHostException;/*** Created by WangJinyong on 2018/6/30.*/public class SocThread extends Thread {private String ip = "114.116.64.184";private int port = 9667;private String TAG = "socket thread";private int timeout = 10000;public Socket client = null;PrintWriter out;BufferedReader in;public boolean isRun = true;Handler inHandler;Handler outHandler;Context ctx;private String TAG1 = "===Send===";SharedPreferences sp;public SocThread(Handler handlerin, Handler handlerout, Context context) {inHandler = handlerin;outHandler = handlerout;ctx = context;Log.i(TAG, "创建线程socket");}/*** 连接socket服务器*/public void conn() {try {initdate();Log.i(TAG, "连接中……");client = new Socket(ip, port);client.setSoTimeout(timeout);// 设置阻塞时间Log.i(TAG, "连接成功");in = new BufferedReader(new InputStreamReader(client.getInputStream()));out = new PrintWriter(new BufferedWriter(new OutputStreamWriter(client.getOutputStream())), true);Log.i(TAG, "输入输出流获取成功");} catch (UnknownHostException e) {Log.i(TAG, "连接错误UnknownHostException 重新获取");e.printStackTrace();conn();} catch (IOException e) {Log.i(TAG, "连接服务器io错误");e.printStackTrace();} catch (Exception e) {Log.i(TAG, "连接服务器错误Exception" + e.getMessage());e.printStackTrace();}}public void initdate() {sp = ctx.getSharedPreferences("SP", ctx.MODE_PRIVATE);ip = sp.getString("ipstr", ip);port = Integer.parseInt(sp.getString("port", String.valueOf(port)));Log.i(TAG, "获取到ip端口:" + ip + ";" + port);}/*** 实时接受数据*/@Overridepublic void run() {Log.i(TAG, "线程socket开始运行");conn();Log.i(TAG, "1.run开始");String line = "";while (isRun) {try {if (client != null) {Log.i(TAG, "2.检测数据");while ((line = in.readLine()) != null) {Log.i(TAG, "3.getdata" + line + " len=" + line.length());Log.i(TAG, "4.start set Message");Message msg = inHandler.obtainMessage();msg.obj = line;inHandler.sendMessage(msg);// 结果返回给UI处理Log.i(TAG1, "5.send to handler");}} else {Log.i(TAG, "没有可用连接");conn();}} catch (Exception e) {Log.i(TAG, "数据接收错误" + e.getMessage());e.printStackTrace();}}}/*** 发送数据** @param mess*/public void Send(String mess) {try {if (client != null) {Log.i(TAG1, "发送" + mess + "至"+ client.getInetAddress().getHostAddress() + ":"+ String.valueOf(client.getPort()));out.println(mess);out.flush();Log.i(TAG1, "发送成功");Message msg = outHandler.obtainMessage();msg.obj = mess;msg.what = 1;outHandler.sendMessage(msg);// 结果返回给UI处理} else {Log.i(TAG, "client 不存在");Message msg = outHandler.obtainMessage();msg.obj = mess;msg.what = 0;outHandler.sendMessage(msg);// 结果返回给UI处理Log.i(TAG, "连接不存在重新连接");conn();}} catch (Exception e) {Log.i(TAG1, "send error");e.printStackTrace();} finally {Log.i(TAG1, "发送完毕");}}/*** 关闭连接*/public void close() {try {if (client != null) {Log.i(TAG, "close in");in.close();Log.i(TAG, "close out");out.close();Log.i(TAG, "close client");client.close();}} catch (Exception e) {Log.i(TAG, "close err");e.printStackTrace();}}
}
 

通讯的Activity类Client

package com.junto.sockettest;import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.util.Log;
import android.view.View;
import android.widget.Button;
import android.widget.EditText;
import android.widget.TextView;/*** Created by WangJinyong on 2018/6/30.*/public class Client extends Activity {private String TAG = "===Client===";private TextView tv1 = null;Handler mhandler;Handler mhandlerSend;EditText edtsendms;Button btnsend;private String sendstr = "";private Context ctx;SocThread socketThread;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.client);tv1 = (TextView) findViewById(R.id.tv1);btnsend = (Button) findViewById(R.id.button1);ctx = Client.this;edtsendms = (EditText) findViewById(R.id.editText1);mhandler = new Handler() {@Overridepublic void handleMessage(Message msg) {try {Log.i(TAG, "mhandler接收到msg=" + msg.what);if (msg.obj != null) {
//                        byte[] objStr2 = (byte[]) msg.obj;
//                        Log.e("tag","objStr2="+objStr2);String s = msg.obj.toString();if (s.trim().length() > 0) {Log.i(TAG, "mhandler接收到obj=" + s);Log.i(TAG, "开始更新UI");tv1.append("Server:" + s);Log.i(TAG, "更新UI完毕");} else {Log.i(TAG, "没有数据返回不更新");}}} catch (Exception ee) {Log.i(TAG, "加载过程出现异常");ee.printStackTrace();}}};mhandlerSend = new Handler() {@Overridepublic void handleMessage(Message msg) {try {Log.i(TAG, "mhandlerSend接收到msg.what=" + msg.what);String s = msg.obj.toString();if (msg.what == 1) {tv1.append("\n ME: " + s + "      发送成功");} else {tv1.append("\n ME: " + s + "     发送失败");}} catch (Exception ee) {Log.i(TAG, "加载过程出现异常");ee.printStackTrace();}}};startSocket();btnsend.setOnClickListener(new View.OnClickListener() {@Overridepublic void onClick(View v) {// 发送数据Log.i(TAG, "准备发送数据");sendstr = edtsendms.getText().toString().trim();socketThread.Send(sendstr);}});}public void startSocket() {socketThread = new SocThread(mhandler, mhandlerSend, ctx);socketThread.start();}private void stopSocket() {socketThread.isRun = false;socketThread.close();socketThread = null;Log.i(TAG, "Socket已终止");}@Overrideprotected void onStart() {super.onStart();Log.e(TAG, "start onStart~~~");}@Overrideprotected void onRestart() {super.onRestart();Log.e(TAG, "start onRestart~~~");startSocket();}@Overrideprotected void onResume() {super.onResume();Log.e(TAG, "start onResume~~~");}@Overrideprotected void onPause() {super.onPause();Log.e(TAG, "start onPause~~~");}@Overrideprotected void onStop() {super.onStop();Log.e(TAG, "start onStop~~~");stopSocket();}@Overrideprotected void onDestroy() {super.onDestroy();Log.e(TAG, "start onDestroy~~~");}}
client的XML布局文件
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_centerHorizontal="true"android:layout_centerVertical="true"android:text="接收到的信息" /><TextViewandroid:id="@+id/tv1"android:layout_width="150dp"android:layout_height="wrap_content"android:layout_centerHorizontal="true"android:layout_centerVertical="true"android:layout_weight="0.25"android:text="" /><TextViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_centerHorizontal="true"android:layout_centerVertical="true"android:text="请输入发送内容" /><EditTextandroid:id="@+id/editText1"android:layout_width="match_parent"android:layout_height="wrap_content"android:ems="10"><requestFocus /></EditText><LinearLayoutandroid:layout_width="match_parent"android:layout_height="wrap_content"><Buttonandroid:id="@+id/button1"android:layout_width="wrap_content"android:layout_height="wrap_content"android:text="发送" /></LinearLayout></LinearLayout>
在AndroidManifest.xml添加网络权限:
<uses-permission android:name="android.permission.INTERNET"/>

这篇关于Android之Socket通讯的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1123563

相关文章

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

android-opencv-jni

//------------------start opencv--------------------@Override public void onResume(){ super.onResume(); //通过OpenCV引擎服务加载并初始化OpenCV类库,所谓OpenCV引擎服务即是 //OpenCV_2.4.3.2_Manager_2.4_*.apk程序包,存

从状态管理到性能优化:全面解析 Android Compose

文章目录 引言一、Android Compose基本概念1.1 什么是Android Compose?1.2 Compose的优势1.3 如何在项目中使用Compose 二、Compose中的状态管理2.1 状态管理的重要性2.2 Compose中的状态和数据流2.3 使用State和MutableState处理状态2.4 通过ViewModel进行状态管理 三、Compose中的列表和滚动

Android 10.0 mtk平板camera2横屏预览旋转90度横屏拍照图片旋转90度功能实现

1.前言 在10.0的系统rom定制化开发中,在进行一些平板等默认横屏的设备开发的过程中,需要在进入camera2的 时候,默认预览图像也是需要横屏显示的,在上一篇已经实现了横屏预览功能,然后发现横屏预览后,拍照保存的图片 依然是竖屏的,所以说同样需要将图片也保存为横屏图标了,所以就需要看下mtk的camera2的相关横屏保存图片功能, 如何实现实现横屏保存图片功能 如图所示: 2.mtk

android应用中res目录说明

Android应用的res目录是一个特殊的项目,该项目里存放了Android应用所用的全部资源,包括图片、字符串、颜色、尺寸、样式等,类似于web开发中的public目录,js、css、image、style。。。。 Android按照约定,将不同的资源放在不同的文件夹中,这样可以方便的让AAPT(即Android Asset Packaging Tool , 在SDK的build-tools目

Android fill_parent、match_parent、wrap_content三者的作用及区别

这三个属性都是用来适应视图的水平或者垂直大小,以视图的内容或尺寸为基础的布局,比精确的指定视图的范围更加方便。 1、fill_parent 设置一个视图的布局为fill_parent将强制性的使视图扩展至它父元素的大小 2、match_parent 和fill_parent一样,从字面上的意思match_parent更贴切一些,于是从2.2开始,两个属性都可以使用,但2.3版本以后的建议使

Android Environment 获取的路径问题

1. 以获取 /System 路径为例 /*** Return root of the "system" partition holding the core Android OS.* Always present and mounted read-only.*/public static @NonNull File getRootDirectory() {return DIR_ANDR

Java Websocket实例【服务端与客户端实现全双工通讯】

Java Websocket实例【服务端与客户端实现全双工通讯】 现很多网站为了实现即时通讯,所用的技术都是轮询(polling)。轮询是在特定的的时间间隔(如每1秒),由浏览器对服务器发 出HTTP request,然后由服务器返回最新的数据给客服端的浏览器。这种传统的HTTP request 的模式带来很明显的缺点 – 浏 览器需要不断的向服务器发出请求,然而HTTP

Android逆向(反调,脱壳,过ssl证书脚本)

文章目录 总结 基础Android基础工具 定位关键代码页面activity定位数据包参数定位堆栈追踪 编写反调脱壳好用的脚本过ssl证书校验抓包反调的脚本打印堆栈bilibili反调的脚本 总结 暑假做了两个月的Android逆向,记录一下自己学到的东西。对于app渗透有了一些思路。 这两个月主要做的是代码分析,对于分析完后的持久化等没有学习。主要是如何反编译源码,如何找到