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

相关推荐
游戏开发爱好者818 小时前
React Native iOS 代码如何加密,JS 打包 和 IPA 混淆
android·javascript·react native·ios·小程序·uni-app·iphone
2501_9159184119 小时前
iOS mobileprovision 描述文件管理,新建、下载和内容查看
android·ios·小程序·https·uni-app·iphone·webview
00后程序员张20 小时前
iOS 应用程序使用历史记录和耗能记录怎么查?
android·ios·小程序·https·uni-app·iphone·webview
学亮编程手记20 小时前
Mars-Admin 基于Spring Boot 3 + Vue 3 + UniApp的企业级管理系统
vue.js·spring boot·uni-app
万物得其道者成1 天前
uni-app CLI:APP 多环境打包(测试/正式)最简配置 + `import.meta.env` 为 `undefined` 的解决
uni-app
毕设源码-邱学长1 天前
【开题答辩全过程】以 基于 uni-app Node.js 的音乐系统设计与实现为例,包含答辩的问题和答案
uni-app
qq_316837751 天前
华为obs 私有桶 音频 使用uniapp 安卓端播放-99的问题
uni-app·音视频
凉辰2 天前
uniapp实现生成海报功能 (开箱即用)
javascript·vue.js·小程序·uni-app
笨笨狗吞噬者2 天前
【uniapp】小程序支持分包引用分包 node_modules 依赖产物打包到分包中
前端·微信小程序·uni-app
har01d2 天前
uni-app 自动更新检测弹窗,踩坑记录
uni-app