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 相关文章推荐
javascript中的onkeyup和onkeydown区别介绍
Apr 28 Javascript
搭建pomelo 开发环境
Jun 24 Javascript
学习JavaScript设计模式之状态模式
Jan 08 Javascript
canvas实现动态小球重叠效果
Feb 06 Javascript
浅析Javascript中双等号(==)隐性转换机制
Oct 27 Javascript
vue-router实现组件间的跳转(参数传递)
Nov 07 Javascript
Node.js搭建小程序后台服务
Jan 03 Javascript
vue-cli脚手架引入图片的几种方法总结
Mar 13 Javascript
VeeValidate在vue项目里表单校验应用案例
May 09 Javascript
vue axios整合使用全攻略
May 24 Javascript
js函数柯里化的方法和作用实例分析
Apr 11 Javascript
JS中作用域以及变量范围分析
Jul 18 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设计模式 Strategy(策略模式)
2011/06/26 PHP
PHP引用返回用法示例
2016/05/28 PHP
JQuery扩展插件Validate 5添加自定义验证方法
2011/09/05 Javascript
整理AngularJS中的一些常用指令
2015/06/16 Javascript
jquery判断checkbox是否选中及改变checkbox状态的实现方法
2016/05/26 Javascript
Three.js的使用及绘制基础3D图形详解
2017/04/27 Javascript
jQuery 实现双击编辑表格功能
2017/06/19 jQuery
vue.js 实现评价五角星组件的实例代码
2018/08/13 Javascript
小程序云开发部署攻略(图文教程)
2018/10/30 Javascript
vue实现axios图片上传功能
2019/08/20 Javascript
BootstrapValidator实现表单验证功能
2019/11/08 Javascript
在微信小程序中渲染HTML内容3种解决方案及分析与问题解决
2020/01/12 Javascript
javascript实现贪吃蛇小游戏
2020/07/28 Javascript
[01:00:30]完美世界DOTA2联赛循环赛 Inki vs Matador BO2第二场 10.31
2020/11/02 DOTA
python实现可将字符转换成大写的tcp服务器实例
2015/04/29 Python
Python实现把数字转换成中文
2015/06/29 Python
一篇文章快速了解Python的GIL
2018/01/12 Python
python简单商城购物车实例代码
2018/03/15 Python
Python3中内置类型bytes和str用法及byte和string之间各种编码转换 问题
2018/09/27 Python
Python的argparse库使用详解
2018/10/09 Python
Python:type、object、class与内置类型实例
2019/12/25 Python
Python内置函数及功能简介汇总
2020/10/13 Python
html5使用canvas绘制一张图片
2014/12/15 HTML / CSS
俄罗斯Sportmarket体育在线商店:用于旅游和户外活动
2019/11/12 全球购物
STP协议的主要用途是什么?为什么要用STP
2012/12/20 面试题
国家励志奖学金获奖感言
2014/01/09 职场文书
餐饮管理自我介绍信
2014/01/15 职场文书
最新会计专业求职信范文
2014/01/28 职场文书
护士自我评价
2014/02/01 职场文书
《自选商场》教学反思
2014/02/14 职场文书
《散步》教学反思
2014/03/02 职场文书
关于工作经历的证明书
2014/10/11 职场文书
秋菊打官司观后感
2015/06/03 职场文书
2016年世界人口日宣传活动总结
2016/04/05 职场文书
2019个人工作计划书的格式及范文!
2019/07/04 职场文书
Nginx域名转发https访问的实现
2021/03/31 Servers