Node.js和PHP根据ip获取地理位置的方法


Posted in Javascript onMarch 14, 2014

一、Node.js实现代码

var http = require('http');
var util = require('util');/**
 * 根据 ip 获取获取地址信息
 */
var getIpInfo = function(ip, cb) {
    var sina_server = 'http://int.dpool.sina.com.cn/iplookup/iplookup.php?format=json&ip=';
    var url = sina_server + ip;
    http.get(url, function(res) {
        var code = res.statusCode;
        if (code == 200) {
            res.on('data', function(data) {
                try {
                    cb(null, JSON.parse(data));
                } catch (err) {
                    cb(err);
                }
            });
        } else {
            cb({ code: code });
        }
    }).on('error', function(e) { cb(e); });
};
getIpInfo('220.181.111.85', function(err, msg) {
    console.log('城市: ' + msg.city);
    console.log('msg: ' + util.inspect(msg, true, 8));
})

请求结果:
城市: 徐州
{
    "ret": 1,
    "start": "49.68.0.0",
    "end": "49.68.255.255",
    "country": "中国",
    "province": "江苏",
    "city": "徐州",
    "district": "",
    "isp": "电信",
    "type": "",
    "desc": ""
}

二、PHP实现代码
<?$ip = "220.181.111.85";
$url = "http://int.dpool.sina.com.cn/iplookup/iplookup.php?format=json&ip=$ip";
$data = file_get_contents($url);
$result = json_decode($data);
echo "城市:" . $result->city . "<br>";
print_r($result);
?>

请求结果:
城市:徐州
stdClass Object
(
    [ret] => 1
    [start] => 49.68.0.0
    [end] => 49.68.255.255
    [country] => 中国
    [province] => 江苏
    [city] => 徐州
    [district] => 
    [isp] => 电信
    [type] => 
    [desc] =>
)

Javascript 相关文章推荐
jQuery 解析xml文件
Aug 09 Javascript
javascript 显示当前系统时间代码
Dec 28 Javascript
全面解析Bootstrap中tooltip、popover的使用方法
Jun 13 Javascript
浅谈JS运算符&amp;&amp;和|| 及其优先级
Aug 10 Javascript
Angular和百度地图的结合实例代码
Oct 19 Javascript
如何制作幻灯片(代码分享)
Jan 06 Javascript
详解vue-router基本使用
Apr 18 Javascript
深入理解JavaScript 参数按值传递
May 24 Javascript
浅谈Vue.js中ref ($refs)用法举例总结
Dec 19 Javascript
layui表格数据复选框回显设置方法
Sep 13 Javascript
微信小程序基于ColorUI构建皮皮虾短视频去水印组件
Nov 04 Javascript
linux服务器快速卸载安装node环境(简单上手)
Feb 22 Javascript
弹出窗口并且此窗口带有半透明的遮罩层效果
Mar 13 #Javascript
javascript回车完美实现tab切换功能
Mar 13 #Javascript
javasciprt下jquery函数$.post执行无响应的解决方法
Mar 13 #Javascript
JQuery中extend使用介绍
Mar 13 #Javascript
js中用window.open()打开多个窗口的name问题
Mar 13 #Javascript
javascript获取浏览器类型和版本的方法(js获取浏览器版本)
Mar 13 #Javascript
利用try-catch判断变量是已声明未声明还是未赋值
Mar 12 #Javascript
You might like
PHP 中执行系统外部命令
2006/10/09 PHP
php 禁止页面缓存输出
2009/01/07 PHP
在Windows XP下安装Apache+MySQL+PHP环境
2015/02/22 PHP
PHP SplObjectStorage使用实例
2015/05/12 PHP
php面试实现反射注入的详细方法
2019/09/30 PHP
很可爱的输入框
2008/08/03 Javascript
JS 控制CSS样式表
2009/08/20 Javascript
Javascript学习笔记9 prototype封装继承
2010/01/11 Javascript
用JavaScript对JSON进行模式匹配(Part 1-设计)
2010/07/17 Javascript
JQuery each()函数如何优化循环DOM结构的性能
2012/12/10 Javascript
DWZ刷新dialog解决方法
2013/03/03 Javascript
jQuery基本过滤选择器使用介绍
2013/04/18 Javascript
node.js+Ajax实现获取HTTP服务器返回数据
2014/11/26 Javascript
JS插件plupload.js实现多图上传并显示进度条
2016/11/29 Javascript
基于vue-resource jsonp跨域问题的解决方法
2018/02/03 Javascript
Vue自定义全局弹窗组件操作
2020/08/11 Javascript
[02:57]2014DOTA2国际邀请赛 选手辛苦解说更辛苦
2014/07/10 DOTA
利用python程序生成word和PDF文档的方法
2017/02/14 Python
Flask框架信号用法实例分析
2018/07/24 Python
详解使用python绘制混淆矩阵(confusion_matrix)
2019/07/14 Python
Python之数据序列化(json、pickle、shelve)详解
2019/08/30 Python
python实现输入三角形边长自动作图求面积案例
2020/04/12 Python
python如何编写win程序
2020/06/08 Python
LN-CC日本:高端男装和女装的奢侈时尚目的地
2019/09/01 全球购物
都柏林通行卡/城市通票:The Dublin Pass
2020/02/16 全球购物
Collection和Collections的区别
2016/05/02 面试题
介绍一下gcc特性
2012/01/20 面试题
给护士表扬信
2014/01/19 职场文书
农贸市场管理制度
2014/01/31 职场文书
企业口号大全
2014/06/12 职场文书
餐饮服务食品安全承诺书
2015/04/29 职场文书
费用申请报告范文
2015/05/15 职场文书
python基础详解之if循环语句
2021/04/24 Python
Python列表删除重复元素与图像相似度判断及删除实例代码
2021/05/07 Python
MySQL高速缓存启动方法及参数详解(query_cache_size)
2021/07/01 MySQL
分享提高 Python 代码的可读性的技巧
2022/03/03 Python