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这个地址可能是要翻墙才能

相关推荐
不爱说话郭德纲2 小时前
告别漫长的HbuilderX云打包排队!uni-app x 安卓本地打包保姆级教程(附白屏、包体积过大排坑指南)
android·前端·uni-app
HashTang1 天前
【AI 编程实战】第 12 篇:从 0 到 1 的回顾 - 项目总结与 AI 协作心得
前端·uni-app·ai编程
JunjunZ1 天前
uniapp 文件预览:从文件流到多格式预览的完整实现
前端·uni-app
郑州光合科技余经理2 天前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
TT_Close2 天前
“啪啪啪”三下键盘,极速拉起你的 uni-app 项目!
vue.js·uni-app·前端工程化
特立独行的猫a2 天前
uni-app x跨平台开发实战:开发鸿蒙HarmonyOS影视票房榜组件完整实现过程
华为·uni-app·harmonyos·轮播图·uniapp-x
00后整顿职场2 天前
Hbuilderx APP真机无法识别iqoo Z9+手机设备解决方案
uni-app·uniapp真机调试·真机运行
前端小雪的博客.2 天前
【保姆级教程】uniAI 插件高效开发 uni-app 微信小程序(附实战案例)
微信小程序·uni-app·ai编程·uniai
T^T尚2 天前
一个完整的项目怎么打包成为一个app
前端·uni-app
阿巴资源站2 天前
uniapp加水印
java·前端·uni-app