android13(T) 以太网设置工具类

这篇具有很好参考价值的文章主要介绍了android13(T) 以太网设置工具类。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

13 版本的以太网设置和以前版本有所变动,在 AS 中就能直接调用对应 API

将 build.gradle 版本修改 compileSdkVersion 31, 即可直接调用 EthernetManager 相关,

设置静态等方法可以通过反射调用设置。

以下是核心设置静态和动态参数工具类,界面大家可以自由发挥,

以太网电源开关和你们驱动协商写个节点啥的都ok文章来源地址https://www.toymoban.com/news/detail-687640.html

import android.content.ContentResolver;
import android.content.Context;
import android.net.ConnectivityManager;
import android.net.EthernetManager;
import android.net.IpConfiguration;
import android.net.LinkAddress;
import android.net.LinkProperties;
import android.net.RouteInfo;
import android.net.StaticIpConfiguration;
import android.provider.Settings;
import android.provider.Settings.System;
import android.text.TextUtils;
import android.util.Log;

import java.io.FileOutputStream;
import java.lang.reflect.InvocationTargetException;
import java.lang.reflect.Method;
import java.net.Inet4Address;
import java.net.InetAddress;
import java.util.ArrayList;
import java.util.List;

import static android.content.Context.CONNECTIVITY_SERVICE;

public class EthernetUtil {
    private static final String TAG = "EthernetUtil";

    public static final String IS_ETHERNET_OPEN = "isEthernetOpen";
    public static final String IS_ETHERNET_STATUC_OPEN = "isEthernetStaticOpen";
    public static final String ETHERNET_STATIC_DNS1 = "ethernet_static_dns1";
    public static final String ETHERNET_STATIC_DNS2 = "ethernet_static_dns2";
    public static final String ETHERNET_STATIC_GATEWAY = "ethernet_static_gateway";
    public static final String ETHERNET_STATIC_IP = "ethernet_static_ip";
    public static final String ETHERNET_STATIC_NETMASK = "ethernet_static_netmask";

    EthernetManager mEthernetManager;
    Context mContext;
    private static EthernetUtil ethernetUtil;

    public static EthernetUtil getInstance() {
        if (ethernetUtil == null) {
            ethernetUtil = new EthernetUtil();
        }
        return ethernetUtil;
    }

    public void setContext(Context context) {
        mContext = context;
    }

	
    public void saveEthernetConfig() {
        boolean isOpen = isEthernetEnabled();
        boolean isStatic = isStaticEnabled();
        Log.d(TAG, "saveEthernetConfig isOpen=" + isOpen + " isStatic=" + isStatic);
        mEthernetManager = (EthernetManager) mContext.getSystemService(Context.ETHERNET_SERVICE);
        IpConfiguration mIpConfiguration = new IpConfiguration();
        StaticIpConfiguration.Builder staticIpConfiguration = new StaticIpConfiguration.Builder();
        ContentResolver mContentResolver = mContext.getContentResolver();
        if (isOpen) {
            if (isStatic) {
                try {
                    String ip = System.getString(mContentResolver, ETHERNET_STATIC_IP);
                    String gateWay = System.getString(mContentResolver, ETHERNET_STATIC_GATEWAY);
                    String netMask = System.getString(mContentResolver,  ETHERNET_STATIC_NETMASK);
                    String dns1 = System.getString(mContentResolver,  ETHERNET_STATIC_DNS1);
                    String dns2 = System.getString(mContentResolver,  ETHERNET_STATIC_DNS2);
                    staticIpConfiguration.setIpAddress(new LinkAddress(InetAddress.getByName(ip),
                            getNetMaskInt(netMask)));
                    staticIpConfiguration.setDomains(netMask);
                    staticIpConfiguration.setGateway(InetAddress.getByName(gateWay));
                    ArrayList<InetAddress> dnsAddresses = new ArrayList<>();
                    dnsAddresses.add((Inet4Address) InetAddress.getByName(TextUtils.isEmpty(dns1) ? "8.8.8.8" : dns1));
                    dnsAddresses.add((Inet4Address) InetAddress.getByName(TextUtils.isEmpty(dns2) ? "114.114.114.114" : dns2));
                    staticIpConfiguration.setDnsServers(dnsAddresses);
                } catch (Exception e) {
                    e.printStackTrace();
                }
                Log.d(TAG, "IpAssignment.STATIC =" + IpConfiguration.IpAssignment.STATIC);
                mIpConfiguration.setIpAssignment(IpConfiguration.IpAssignment.STATIC);
                mIpConfiguration.setProxySettings(IpConfiguration.ProxySettings.STATIC);
                mIpConfiguration.setStaticIpConfiguration(staticIpConfiguration.build());
            } else {
                mIpConfiguration.setIpAssignment(IpConfiguration.IpAssignment.DHCP);
                mIpConfiguration.setProxySettings(IpConfiguration.ProxySettings.NONE);
                mIpConfiguration.setStaticIpConfiguration(null);
                Log.d(TAG, "IpAssignment.DHCP =" + IpConfiguration.IpAssignment.DHCP);
            }
            setConfiguration("eth0", mIpConfiguration);
			setEthernetEnabled(true);
            Log.d(TAG, "setEthernet true");
        } else {
			setEthernetEnabled(false);
            Log.d(TAG, "setEthernet false");
        }
    }

    private void setEthernetEnabled(boolean enabled) {
        try {
            Class<? extends EthernetManager> c = mEthernetManager.getClass();
            Method method = c.getMethod("setEthernetEnabled", boolean.class);
            EthernetManager tempManager = mEthernetManager;
            method.setAccessible(true);

            Log.e(TAG, "get setEthernetEnabled Method: " + (method == null));
            method.invoke(tempManager, enabled);
        } catch (IllegalAccessException | InvocationTargetException | NoSuchMethodException e) {
            Log.e(TAG, "getDeclaredMethod: " + e.getMessage());
        }
    }

    private void setConfiguration(String iface, IpConfiguration config) {
        try {
            Class<? extends EthernetManager> c = mEthernetManager.getClass();
            Method method = c.getMethod("setConfiguration", String.class, IpConfiguration.class);
            EthernetManager tempManager = mEthernetManager;
            method.setAccessible(true);

            Log.e(TAG, "get setConfiguration Method: " + (method == null));
            method.invoke(tempManager, iface, config);

        } catch (Exception e) {
            Log.e(TAG, "getDeclaredMethod: " + e.getMessage());
        }
    }

    private String interMask2String(int prefixLength) {
        String netMask = null;
        int inetMask = prefixLength;

        int part = inetMask / 8;
        int remainder = inetMask % 8;
        int sum = 0;

        for (int i = 8; i > 8 - remainder; i--) {
            sum = sum + (int) Math.pow(2, i - 1);
        }

        if (part == 0) {
            netMask = sum + ".0.0.0";
        } else if (part == 1) {
            netMask = "255." + sum + ".0.0";
        } else if (part == 2) {
            netMask = "255.255." + sum + ".0";
        } else if (part == 3) {
            netMask = "255.255.255." + sum;
        } else if (part == 4) {
            netMask = "255.255.255.255";
        }

        return netMask;
    }

    public boolean isValidIpAddress(String value) {
        int start = 0;
        int end = value.indexOf('.');
        int numBlocks = 0;

        while (start < value.length()) {

            if (-1 == end) {
                end = value.length();
            }

            try {
                int block = Integer.parseInt(value.substring(start, end));
                if ((block > 255) || (block < 0)) {
                    Log.w(TAG, "isValidIpAddress() : invalid 'block', block = " + block);
                    return false;
                }
            } catch (NumberFormatException e) {
                Log.w(TAG, "isValidIpAddress() : e = " + e);
                return false;
            }

            numBlocks++;

            start = end + 1;
            end = value.indexOf('.', start);
        }

        return numBlocks == 4;
    }

    private int getNetMaskInt(String netMask) {
        Log.d(TAG, "netMask =" + netMask);
        StringBuffer sbf;
        String str;
        int prefixLength = 0, count = 0;
        String[] split = netMask.split("\\.");
        for (int n = 0; n < split.length; n++) {
            sbf = toBin(Integer.parseInt(split[n]));
            str = sbf.reverse().toString();
            //Log.e("net", split[n] + "===" + str);
            count = 0;
            for (int i = 0; i < str.length(); i++) {
                i = str.indexOf('1', i);
                if (i == -1) {
                    break;
                }
                count++;
            }
            prefixLength += count;
        }
        return prefixLength;
    }

    private StringBuffer toBin(int x) {
        StringBuffer result = new StringBuffer();
        result.append(x % 2);
        x /= 2;
        while (x > 0) {
            result.append(x % 2);
            x /= 2;
        }
        return result;
    }

    public String getSaveIp(){
        return Settings.System.getString(mContext.getContentResolver(), ETHERNET_STATIC_IP);
    }
    public String getSaveNetMask(){
        return Settings.System.getString(mContext.getContentResolver(), ETHERNET_STATIC_NETMASK);
    }
    public String getSaveGateway(){
        return Settings.System.getString(mContext.getContentResolver(), ETHERNET_STATIC_GATEWAY);
    }
    public String getSaveDns1(){
        return Settings.System.getString(mContext.getContentResolver(), ETHERNET_STATIC_DNS1);
    }
    public String getSaveDns2(){
        return Settings.System.getString(mContext.getContentResolver(), ETHERNET_STATIC_DNS2);
    }

    public boolean isEthernetEnabled() {
        return Settings.System.getInt(mContext.getContentResolver(), IS_ETHERNET_OPEN, 0) == 1;
    }

    public boolean isStaticEnabled() {
        return Settings.System.getInt(mContext.getContentResolver(), IS_ETHERNET_STATUC_OPEN, 0) == 1;
    }

    public void setEthernetEnabled(boolean flag) {
        Settings.System.putInt(mContext.getContentResolver(), IS_ETHERNET_OPEN, flag ? 1 : 0);
    }

    public void setStaticEnabled(boolean flag) {
        Settings.System.putInt(mContext.getContentResolver(), IS_ETHERNET_STATUC_OPEN, flag ? 1 : 0);
    }

  
}

到了这里,关于android13(T) 以太网设置工具类的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Android P 9.0 增加以太网静态IP功能

    1、vendormediatekproprietarypackagesappsMtkSettingsresxmlnetwork_and_internet.xml 在 mobile_network_settings 和 tether_settings 之间增加如上代码, 对应的 icon 资源文件是我从 SystemUI 中拷贝过来的,稍微调整了下大小,也贴给你们吧 2、vendormediatekproprietarypackagesappsMtkSettingsresdrawableic_ethern

    2024年02月22日
    浏览(42)
  • Android 11 Ethernet以太网架构分析(1)——初始化

    android中以太网常被用作共享网络,或者是定制化设备连接网线的需求。 本章将会详细分析该模块对以太网的逻辑实现,是大家对此有更深入认识。 初始化 Systemserver 在安卓系统中有一个关于以太网的服务,在systemserver中启动 frameworks/base/services/java/com/android/server/SystemServer.j

    2024年02月04日
    浏览(46)
  • 欧姆龙以太网模块如何设置ip连接 Kepware opc步骤

    在数字化和自动化的今天,PLC在工业控制领域的作用日益重要。然而,PLC通讯口的有限资源成为了困扰工程师们的问题。为了解决这一问题,捷米特推出了JM-ETH-CP转以太网模块,让即插即用的以太网通讯成为可能,不仅有效利用了PLC的通讯资源,还提高了数据传输的效率和稳

    2024年02月16日
    浏览(65)
  • ubuntu 没有网络,网络中或者右上角没有有线设置或以太网

    问题现象描述: 打开设置-网络模块,仅有VPN和网络代理,没有有线设置或以太网,网络正常的应该如下图所示 1、查看interfaces文件,该文件内容是否正常 查看内容是否如下图所示,如下图所示则正常,关闭即可; 2、修改NetworkManager.conf配置文件,将managed=false更改为managed=

    2024年01月22日
    浏览(43)
  • Vector-常用CAN工具 - 以太网工程更换环境无法打开解决

            通常来说每个VN5000都有自己本身的以太网硬件网络配置,因此当我们打开别人的以太网CANoe工程或CANape工程的时候,无法进行正常的功能使用或者log的无法正常的显示,那我们该如何处理呢?这种情况常见的有以下2种可能:         1、2个VN5000设备的硬件通道配置不

    2024年02月07日
    浏览(40)
  • Vector-常用CAN工具 - VN5000接口以太网包过滤

    一、什么是硬件过滤? 1、什么时候应该过滤硬件? 2、需要注意什么?  3、如何过滤VN5000接口上的以太网报文? (1)Vector Hardware Manager (2)Vector Hardware Config          启用硬件以太网包过滤器时,以太网包已经在硬件(即VN5000接口)上进行了过滤,不会从该接口的上

    2024年02月07日
    浏览(35)
  • [工业互联-12]:主流的工业以太网技术简介(PROFINET、POWERLINK、ETHERNET/IP、ETHERCAT、SERCOSIII、MODBUS TCP、CC-LINK IE)

    目录 前言: 1、工业通信要求 1.1 工业通信网络分层模型 1.2 工业控制的实时性要求 2.  以太网技术 2.1 协议分层 2.2 实时应用 3. 常见工业以太网技术 3.1 PROFINET通信 3.2 POWERLINK通信 3.3 EtherNet/IP通信 3.4 EtherCAT通信 3.5 SERCOSIII通信 4.  工业以太网技术比较 4.1 市场占有 4.2 实时性

    2024年02月10日
    浏览(37)
  • vivado 预设文件、IP设置(_P)、用户参数、以太网时钟处理、GT位置限制、当前可识别板的IP列表

    了解预设文件 预设文件有助于在特定配置中自定义IP核心。PS7、axi_emc和当linear_flash或DDR3_SDRAM 界面是在Vivado IP集成商的Board选项卡中选择的。预设文件使用XML格式。preset_file是为特定的Board文件定义的,可以是用于将预设应用于多个IP。 ip_presets schema=\\\"1.0\\\" ip_preset preset_proc_name=

    2024年01月23日
    浏览(37)
  • FPGA实现以太网(一)——以太网简介

    以太网(Ethernet)是当今现有局域网采用的最通用的通信协议标准, 该标准定义了在局域网中采用的电缆类型和信号处理方法。 以太网凭借其成本低、通信速率高、抗干扰性强等优点被广泛应用在网络远程监控、 交换机、工业自动化等对通信速率要求较高的场合。 以太网是一

    2024年02月03日
    浏览(42)
  • 【以太网通信】RS232 串口转以太网

    最近和 RK 研发同事在调试通信接口,排查与定位 RK3399 接收数据出错的问题。FPGA 与 RK3399 之间使用一路 RS232 串口进行通信,由于串口数据没有分包,不方便排查问题,想到可以开发一个 RS232 串口转以太网的工具,将串口接收到的数据封装为 UDP 数据报文,并通过网线传输到

    2024年02月11日
    浏览(48)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包