python项目实战 查询手机号码归属地源码

get_mobile_from.py

python 复制代码
# 引入框架
import requests
from lxml import etree
from flask import Flask, render_template, request

# 创建一个app
app = Flask(__name__)


def get_phone_from(phone):
    # 发送请求的地址
    url = f"https://www.ip138.com/mobile.asp?mobile={phone}&action=mobile"

    # 直接请求会被网站屏蔽报错 需要伪装一下自己
    headers = {
        "User-Agent": "Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/130.0.0.0 Safari/537.36 Edg/130.0.0.0"
    }

    # 发送请求
    resp = requests.get(url, headers=headers)

    # 设置字符集 中文显示
    resp.encoding = "utf-8"
    # 解析响应
    # print(resp.text)

    # 解析数据
    e = etree.HTML(resp.text)
    # xpath

    result = e.xpath("//tbody//tr//a[1]/text()")

    return result


# 主页
@app.route("/index")
def index():
    return render_template("/index.html")


# 定义路由地址
@app.route("/getPhoneFrom")
def getPhoneFrom():
    phone = request.args.get("phone")
    result = get_phone_from(phone)
    return render_template("index.html", result=result)


# 启动web服务
app.run(debug=True)

index.html

html 复制代码
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <form action="/getPhoneFrom" method="get">
        手机号:<input type="text" name="phone" id="">
        <input type="submit" value="查询">
    </form>
    <table border="">
        <tr>
            <td>手机号:</td>
            <td>{{result[0]}}</td>

        </tr>
        <tr>
            <td>归属地:</td>
            <td>{{result[1]}}</td>
        </tr>
        <tr>
            <td>运营商:</td>
            <td>{{result[2]}}</td>
        </tr>
        <tr>
            <td>区号:</td>
            <td>{{result[3]}}</td>
        </tr>
        <tr>
            <td>邮编:</td>
            <td>{{result[4]}}</td>
        </tr>
    </table>
</body>

</html>
相关推荐
尼丝1 分钟前
Token是如何保证安全不被篡改
前端·后端
一枚前端小能手4 分钟前
JavaScript数组操作的5个高效技巧
前端·javascript
小酒星小杜4 分钟前
我和女神有个约会之差点因为二维码太丑搞砸了🔥
前端·javascript·算法
OpenTiny社区11 分钟前
“Performance面板”一文通,解锁前端性能优化工具基础用法!
前端·javascript·性能优化
盏灯15 分钟前
💭单点登录, 用户状态到底存session还是cookie还是jwt?
前端
泉城老铁16 分钟前
在 Element UI 中将 el-radio-group改为纵向排列
前端·vue.js
Ratten18 分钟前
【CSS】---- CSS 实现超过固定高度后出现展开折叠按钮
前端
用户500937683903921 分钟前
基于Electron的Web打印解决方案:web-print-pdf技术分享
前端
书中曾有的故事_21 分钟前
mcp-faker-json
前端·mcp
Ratten22 分钟前
【CSS】---- CSS 变量,实现样式和动画函数复用
前端