Android编程实现简单的UDP Client实例

 更新时间:2016年04月08日 11:47:07   作者:bluebbc  
这篇文章主要介绍了Android编程实现简单的UDP Client,结合实例形式分析了Android实现UDP Clinet客户端的实现技巧,需要的朋友可以参考下

本文实例讲述了Android编程实现简单的UDP Client。分享给大家供大家参考,具体如下:

该代码在4.2.2内调试通过

1.记得加权限

<uses-permission android:name="android.permission.INTERNET"/>

注意:Android 4.0之后,就不能在主线程进行socket通信,否则会抛异常。

2.代码

MainActivity.java:

package mao.example.quicksend;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.os.Handler;
import android.util.Log;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.Button;
import android.widget.TextView;
import android.widget.Toast;
import android.view.View;
public class MainActivity extends Activity {
  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    InitUI();
    //获得Button对象
    Button btnConnect = (Button) findViewById(R.id.buttonConnect);
    btnConnect.setOnClickListener(new Button.OnClickListener() {
      public void onClick(View v)
      {
        //这里处理事件
        //ConnectServer();
        //UDPClient udpET = new UDPClient("192.168.0.14","123");
        //udpET.start();
        //DisplayToast("点击了\"连接\"按钮");
      }
    });
    //发送Button
    btnConnect = (Button) findViewById(R.id.buttonSend);
    btnConnect.setOnClickListener(new Button.OnClickListener() {
      public void onClick(View v)
      {
        //这里处理事件
        SendText();
      }
    });
  }
  @Override
  public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.main, menu);
    return true;
  }
  @Override
  public boolean onOptionsItemSelected(MenuItem item) {
    // Handle action bar item clicks here. The action bar will
    // automatically handle clicks on the Home/Up button, so long
    // as you specify a parent activity in AndroidManifest.xml.
    int id = item.getItemId();
    if (id == R.id.action_settings) {
      return true;
    }
    return super.onOptionsItemSelected(item);
  }
  /* 显示Toast */
  public void DisplayToast(String str)
  {
    Toast.makeText(this, str, Toast.LENGTH_SHORT).show();
  }
  public void InitUI()
  {
    TextView text=(TextView)findViewById(R.id.editTextIP);
    text.setText("192.168.0.14");
    text = (TextView)findViewById(R.id.editTextFilePath);
    text.setText("Udp Client Send Test");
  }
  // connect server
  public void SendText() 
  {
    TextView editIP=(TextView)findViewById(R.id.editTextIP);
    TextView editText=(TextView)findViewById(R.id.editTextFilePath);
    String message = editText.getText().toString() + "\r\n"; 
    UDPClient udpET = new UDPClient(editIP.getText().toString(), message);
    udpET.start();
  }
}

UDPClient.java:

package mao.example.quicksend;
import java.io.IOException;
import java.net.DatagramPacket;
import java.net.DatagramSocket;
import java.net.InetAddress;
import java.net.SocketException;
import java.lang.String;
public class UDPClient extends Thread{
  public String m_serverIP;
  public String m_text;
  public UDPClient(String strServerIP, String strText)
  {
    m_serverIP = strServerIP;
    m_text = strText;
  }
  @Override
  public void run() {
    // TODO Auto-generated method stub
    int TIMEOUT = 3000;
    int servPort = 8800;
    byte[] bytesToSend = m_text.getBytes();//"test_client".getBytes();
    try {
      InetAddress serverAddress = InetAddress.getByName(m_serverIP);
      DatagramSocket socket = new DatagramSocket();
      socket.setSoTimeout(TIMEOUT);
      DatagramPacket sendPacket = new DatagramPacket(bytesToSend,bytesToSend.length,serverAddress,servPort);
      socket.send(sendPacket);
      socket.close();
    } catch (SocketException e){
      e.printStackTrace();
    }catch(IOException e){
      e.printStackTrace();
    }
  }
}

3. activity_main.xml:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  xmlns:tools="http://schemas.android.com/tools"
  android:id="@+id/LinearLayout1"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:orientation="vertical"
  android:paddingBottom="@dimen/activity_vertical_margin"
  android:paddingLeft="@dimen/activity_horizontal_margin"
  android:paddingRight="@dimen/activity_horizontal_margin"
  android:paddingTop="@dimen/activity_vertical_margin"
  tools:context="mao.example.quicksend.MainActivity" >
  <EditText
    android:id="@+id/editTextIP"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:hint="@string/text_IP" />
  <Button
    android:id="@+id/buttonConnect"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:text="@string/text_connect" />
  <EditText
    android:id="@+id/editTextFilePath"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:hint="@string/text_filePath" >
    <requestFocus />
  </EditText>
  <Button
    android:id="@+id/buttonFileSel"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:text="@string/text_sel" />
  <Button
    android:id="@+id/buttonSend"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:text="@string/text_send" />
</LinearLayout>

更多关于Android相关内容感兴趣的读者可查看本站专题:《Android通信方式总结》、《Android调试技巧与常见问题解决方法汇总》、《Android开发入门与进阶教程》、《Android多媒体操作技巧汇总(音频,视频,录音等)》、《Android基本组件用法总结》、《Android视图View技巧总结》、《Android布局layout技巧总结》及《Android控件用法总结

希望本文所述对大家Android程序设计有所帮助。

相关文章

  • Android Flutter实现评分组件的示例代码

    Android Flutter实现评分组件的示例代码

    在很多应用中,我们都需要收集用户的评分,比如商品满意度、配送满意度、应用使用体验等等。本文就利用flutter_rating_bar实现简易的评分组件,感兴趣的可以
    2022-11-11
  • android中Activity详解(生命周期、以各种方式启动Activity、状态保存,完全退出等)

    android中Activity详解(生命周期、以各种方式启动Activity、状态保存,完全退出等)

    本篇文章详细的介绍了Activity,包括生命周期、以各种方式启动Activity、状态保存,完全退出等,有兴趣的可以了解一下。
    2016-11-11
  • Android字体设置及Roboto字体使用方法

    Android字体设置及Roboto字体使用方法

    这篇文章主要介绍了Android字体设置及Roboto字体使用方法,较为详细的分析了自定义字体及RoBoto的具体用法,非常具有实用价值,需要的朋友可以参考下
    2015-01-01
  • Android酷炫动画效果之3D星体旋转效果

    Android酷炫动画效果之3D星体旋转效果

    本文要实现的3D星体旋转效果是从CoverFlow演绎而来,不过CoverFlow只是对图像进行转动,我这里要实现的效果是要对所有的View进行类似旋转木马的转动
    2018-05-05
  • Android Fragment源码分析Add方法

    Android Fragment源码分析Add方法

    Fragment是Android3.0后引入的一个新的API,他出现的初衷是为了适应大屏幕的平板电脑, 当然现在他仍然是平板APP UI设计的宠儿,而且我们普通手机开发也会加入这个Fragment, 我们可以把他看成一个小型的Activity,又称Activity片段
    2022-08-08
  • Flutter实现购物车功能(代码+逻辑)

    Flutter实现购物车功能(代码+逻辑)

    本文主要介绍了Flutter实现购物车功能,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-03-03
  • Android开发实现应用层面屏蔽状态栏的方法小结

    Android开发实现应用层面屏蔽状态栏的方法小结

    这篇文章主要介绍了Android开发实现应用层面屏蔽状态栏的方法,结合实例形式分析了Android屏蔽状态栏的相关函数调用、权限控制及函数重写等相关操作技巧,需要的朋友可以参考下
    2017-08-08
  • Android编程获取网络连接方式及判断手机卡所属运营商的方法

    Android编程获取网络连接方式及判断手机卡所属运营商的方法

    这篇文章主要介绍了Android编程获取网络连接方式及判断手机卡所属运营商的方法,涉及Android针对网络的判断及本机信息的获取技巧,需要的朋友可以参考下
    2016-01-01
  • Flexbox+ReclyclerView实现流式布局

    Flexbox+ReclyclerView实现流式布局

    这篇文章主要为大家详细介绍了Flexbox+ReclyclerView实现流式布局,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-11-11
  • Android对话框使用方法详解

    Android对话框使用方法详解

    这篇文章主要介绍了Android对话框使用方法,包括提示对话框、单选对话框、复选对话框、列表对话框等,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-09-09

最新评论