Vue跨域获取ip和ip位置城市等归属地信息

由于端口设置与查询服务器不一致,所以不能直接从ip138网上抓取,只能跨域查询。实现跨域查询,简单的方法是使用jsonp方式,只支持get请求,同时也需要查询的服务器支持jsonp。这时找到了腾讯位置服务。参考文章,代码有一些需要注意,看下文。

1.注册账号

首先在https://lbs.qq.com/console/setting.html这个网页中 , 申请你自己key,也就是密钥,有了这个密钥,你才有资格使用位置服务api;

2.添加key

申请后,然后在官网上设置你的key,找到  key管理--》启用产品--》WebServiceAPI 选择授权IP 内容输入0.0.0.0-255.255.255.255

key名称随意,因为后面发起jsonp时参数名必须为key

3、给ip定位接口添加配额

个人开发者可设置调用量最高10000,每天自动清零。

4、安装vue-jsonp

工程目录下运行cmd:

sh 复制代码
npm i vue-jsonp -S

在main.js中导入vue-jsonp

js 复制代码
import {VueJsonp} from 'vue-jsonp';   //注意:这里要加花括号
Vue.use(VueJsonp);

调用jsonp方法,获取数据

js 复制代码
	  //使用腾讯服务获取ip和归属地
	  getIpAddress(){
		  this.$jsonp('https://apis.map.qq.com/ws/location/v1/ip', {
			key:xxxxxx,//注意:这里使用key为键名
			output:'jsonp',
		  }).then(response => {
			console.log(response);
			console.log(response.result.ip);
			console.log(response.result.ad_info.nation);
			console.log(response.result.ad_info.province);
			console.log(response.result.ad_info.city);
		  }).catch(error => {
			console.error(error);
		  });
	  },
相关推荐
代码匠心21 分钟前
AI 自动编程:一句话设计高颜值博客
前端·ai·ai编程·claude
_AaronWong2 小时前
Electron 实现仿豆包划词取词功能:从 AI 生成到落地踩坑记
前端·javascript·vue.js
cxxcode2 小时前
I/O 多路复用:从浏览器到 Linux 内核
前端
用户5433081441942 小时前
AI 时代,前端逆向的门槛已经低到离谱 — 以 Upwork 为例
前端
JarvanMo2 小时前
Flutter 版本的 material_ui 已经上架 pub.dev 啦!快来抢先体验吧。
前端
恋猫de小郭2 小时前
AI 可以让 WIFI 实现监控室内人体位置和姿态,无需摄像头?
前端·人工智能·ai编程
哀木2 小时前
给自己整一个 claude code,解锁编程新姿势
前端
程序员鱼皮2 小时前
GitHub 关注突破 2w,我总结了 10 个涨星涨粉技巧!
前端·后端·github
UrbanJazzerati2 小时前
Vue3 父子组件通信完全指南
前端·面试
是一碗螺丝粉3 小时前
5分钟上手LangChain.js:用DeepSeek给你的App加上AI能力
前端·人工智能·langchain