JSONP 跨域 & 制作手机号归属地查询

一、跨域

同源策略指域名,协议,端口相同。所谓“同源策略“,简单的说就是基于安全考虑,当前域不能访问其他域的东西。

同源策略

Ajax 请求 $.get(url,callback); URL的内容只能是同源策略的东西。如果想请求不是同源的东西只能进行跨域JSONP(JSON with padding)请求。
使用方法在index.html 文件引包 js 文件。但是,调用JavaScript文件好像没有受到跨域的影响(其实但凡只要拥有src属性的都拥有跨域的能力,例如<\script>、<\img>、<\iframe>)

方法

index.html文件跨域引包的文件必须放在下面,因为函数无法提升。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>跨域JSONP</title>
</head>
<body>

    <script>
        //定义函数
        function fun(str){
            alert("成功跨域!");
        }
    </script>
    <!-- 跨域引包 -->
    <script src="js/JSONP.js"></script>
</body>
</html>

js 文件

fun();//如果在fun的括号里放入json,是不是妥妥的Ajax请求到了json

实验结果


实验结果

说明:本例也可以把定义和调用函数调换。引包位置可以任意,也就是讲函数可以提升。

演示不同源请求数据

index.html文件跨域引包的文件必须放在下面,因为函数无法提升。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>跨域JSONP</title>
</head>
<body>

    <script>
        //定义函数
        function fun(str){
            alert(str.name);
        }
    </script>
    <!-- 跨域引包 -->
    <script src="js/JSONP.js"></script>
</body>
</html>

js 文件

fun({"name":"跨域","age":18});
结果

说明: 引包的地址换成你想要的任何网址,不就可以偷别人的借口了。哈哈哈哈哈

二、制作手机号归属地查询

浏览器提示错误:

  • Warning: file_get_contents(www.163.com): failed to open stream: No such file or directory in D:\PHPstudy\WWW\12\phone.php on line 5
<?php
echo file_get_contents("www.163.com");  
?>

解决办法:www.163.comhttp://www.163.com

  • Warning: file_get_contents(): Unable to find the wrapper "https" - did you forget to enable it when you configured PHP? in D:\PHPstudy\WWW\12\phone.php on line 5
    Warning: file_get_contents(https://chongzhi.jd.com/json/order/search_searchPhone.action?mobile=18297806543): failed to open stream: No error in D:\PHPstudy\WWW\12\phone.php on line 5
    一共两个错误,其实只有第一个有用。错误显示HTTPS未启动,其实就是不支持HTTPS。

解决办法:我使用的本地服务器模拟软件是PHPstudy,我们只需要找到phpstudy的安装目录下的PHP文件夹,打开正在使用的PHP版本文件夹,找到 php.ini 文件,在文件中找到“;extension=php_openssl.dll”,去掉前面的分号重启软件就可以了。

补充:如果我们输入的网址是http://chongzhi.jd.com/json/order/search_searchPhone.action?mobile=18297806543
会提示如下错误,错误信息不一样但解决办法一样,如上。
Warning: file_get_contents(http://chongzhi.jd.com/json/order/search_searchPhone.action?mobile=18297806543): failed to open stream: Unable to find the socket transport "ssl" - did you forget to enable it when you configured PHP? in D:\PHPstudy\WWW\12\phone.php on line 5

  • 完成上步输出结果为:{"area":"14","areaName":"����","providerName":"�ƶ�","provider":1}
<?php
//字体乱码,设置字体
header("Content-Type:application/json;charset=GBK");
echo file_get_contents("https://chongzhi.jd.com/json/order/search_searchPhone.action?mobile=18297806543");
?>

解决办法:字体乱码,设置字体

接下来看看是如何实现的点击查询功能的。

phone.php

<?php
    //字体乱码,设置字体
    header("Content-Type:application/json;charset=GBK");
    //得到用户输入的手机号
    $phone=$_GET["num"];
    //得到查询结果
    $result = file_get_contents("https://chongzhi.jd.com/json/order/search_searchPhone.action?mobile=".$phone);
    //输出查询结果
    echo $result;   
?>

展示给用户的页面

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>免费手机号归属地查询</title>
</head>
<body>
    <h3>免费手机号归属地查询</h3>
     <form action="">
        <p>
            <!-- 输入手机号 -->
            请输入你的手机号:<input type="text" id ="user_in"><br><br>
            <p id="reg"></p>
            <!-- 点击查询获得结果 -->
            <input type="button" value="点击查询" id="btn">
            <!-- 展示结果 -->
            <p class="result"></p>
            <!-- 引包 -->
            <script src="js/jquery-1.12.3.min.js"></script>
            <script>
                
                <!-- 点击查询 -->
                $("#btn").click(function(){
                    // 获取用户输入的值
                    var Phone_num = $("#user_in").val();
                    //正则检查输入的数据是否是手机好
                    if(!/^[0-9]{11}$/.test(Phone_num)){
                        //显示错误
                        $("#reg").html("错误的手机号!๑•ᴗ•๑");
                        return;
                    }       
                    console.log(Phone_num);
                    // Ajax发送请求
                    $.get("phone.php",{"num":Phone_num},function(data){
                        //移除错误
                        $("#reg").html("");
                        //得到json拼接结果后返回
                        $(".result").html(data.areaName+data.providerName)
                    });
                });
                
            </script>
        </p>
     </form>
</body>
</html>

文件已经上传到服务器上测试结果:https://www.52world.club/shoujihaoquery/

测试结果

总结:跨域请求一共两种方法

  • JSONP跨域,通过引包的方式实现。最好使用Ajax实现
    $.ajax({
        "dataType" : "jsonp",
        "url" : "www.163.com",    //jsonp的网址
        "jsonpCallback" : "haha",     //jsonp的网址是一句调用,所以这里要在window对象上注册一个函数,和jsonp那个调用同名。
        "success" : function(data){   //成功的回调函数
              console.log(data);
        }
    });
  • PHP跨域,通过Ajax请求PHP文件的方式来实现。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容