uniapp获取设备的IP地址(已踩坑,开箱即用)

**业务背景:**我司出现了一个同一个APP安装包需要在不同的设备跳转到不同的首页,我也是头一次遇到,于是只能通过设备的IP地址去判断了 ,当我踩坑完毕后发现挺简单的。

下面三个方法可以获取到无线网、以太网、以及国内公网的IP地址,任君选择亲测有效

限制:只限于APP环境包括平板并且设备是安卓,IOS就要另行想办法了(Objective-C代码)

步骤一 :首先去项目的源码配置里面添加如下代码(在manifest.jsonapp-plus下配置网络权限)

"permissions": {

"network": {

"description": "用于获取网络状态和IP地址"

}

},

我仍了两个地方,一个是在快应用上面和app里面我都写了,目前测试多写一个并不影响,如果你们测试了可以保留一个欢迎在评论区留言

步骤二:复制下面对应的函数就可以调用了(这个是无线网也就是WIFI模式的)

javascript 复制代码
function getWifiIp() {
    const MainActivity = plus.android.runtimeMainActivity();
    const Context = plus.android.importClass('android.content.Context');
    plus.android.importClass('android.net.wifi.WifiManager');
    plus.android.importClass('android.net.wifi.WifiInfo');
 
    const wifiManager = MainActivity.getSystemService(Context.WIFI_SERVICE);
    const wifiInfo = wifiManager.getConnectionInfo();
    const ipAddress = wifiInfo.getIpAddress();
    
    // 将Android的int型IP转换为点分十进制格式
    const wifiIp = (
        (ipAddress & 0xff) + '.' + 
        ((ipAddress >> 8) & 0xff) + '.' + 
        ((ipAddress >> 16) & 0xff) + '.' + 
        ((ipAddress >> 24) & 0xff)
    );
    return wifiIp;
}

// 调用示例

const wifiIp = getWifiIp();

console.log('Wi-Fi IP:', wifiIp);

以上就可以获取到 下面的IP地址了

方法二:这个是拿公网IP地址的还会返回你的地区位置

javascript 复制代码
uni.request({
    url: 'http://myip.ipip.net', // 国内可访问的IP查询服务
    success: (res) => {
        const publicIp = res.data.trim(); // 返回的IP可能是纯文本,需trim()处理
        console.log('公网IP:', publicIp);
    },
    fail: (err) => {
        console.error('获取公网IP失败:', err);
    }
});

方法三:这个是拿以太网的也就是网线

javascript 复制代码
function getLanIp() {
    const MainActivity = plus.android.runtimeMainActivity();
    const Context = plus.android.importClass('android.content.Context');
    plus.android.importClass('android.net.ConnectivityManager');

    const lanManager = MainActivity.getSystemService(Context.CONNECTIVITY_SERVICE);
    const lanInfo = lanManager.getLinkProperties(lanManager.getActiveNetwork());
    const lanIpAddresses = plus.android.invoke(lanInfo, 'getLinkAddresses');
    
    // 解析LinkAddresses对象(可能包含多个IP,需根据需求筛选)
    const lanIpStr = lanIpAddresses.toString();
    const lanIpArray = lanIpStr.split(',');
    const lanIp = lanIpArray[0].split('/')[0]; // 取第一个IP的地址部分
    return lanIp;
}

// 调用示例
const lanIp = getLanIp();
console.log('有线网络IP:', lanIp);

网络有很多坑

1.网络上说有用https://api.ipify.org?format=json这个地址、[http://pv.sohu.com/cityjson?ie=utf-8](http://pv.sohu.com/cityjson?ie=utf-8 "http://pv.sohu.com/cityjson?ie=utf-8") 还有搜狐这个我都没返回成功,还有就是一直返回128.0.0的

2.https://api.ipify.org?format=json这个地址可能是要翻墙才能

相关推荐
CHB10 小时前
uni-app,你的最佳vibe coding搭子
uni-app·vibecoding
怀君13 小时前
Uniapp——Android离线打包自定义基座教程
android·uni-app
李慕婉学姐17 小时前
【开题答辩过程】以《基于uni-app框架的助学管理系统的设计与实现》为例,不知道这个选题怎么做的,不知道这个选题怎么开题答辩的可以进来看看
微信小程序·uni-app
爱吃的强哥17 小时前
uni-app 开发微信小程序注意点
微信小程序·小程序·uni-app
2501_915918411 天前
TCP 抓包分析在复杂网络问题中的作用,从连接和数据流层面理解系统异常行为
网络·网络协议·tcp/ip·ios·小程序·uni-app·iphone
じòぴé南冸じょうげん1 天前
APP本地调试正常,但是打包后出现账号密码解析错误,且前端未使用加密解密
小程序·uni-app·web app
快起来搬砖了2 天前
UniApp 路由配置实战:从全局守卫到 404 页面优雅处理
uni-app
5335ld2 天前
uniapp-APP端table列表左侧第一列固定、头部固定
windows·uni-app
一个假的前端男2 天前
uni-app App 端长按录音的工程级实现
uni-app
无名前端小白2 天前
uniapp 安卓离线打包, 无法调起系统安装应用
uni-app