发送手机验证码通过调用第三方网易云信API(flask项目)

论坛 期权论坛 脚本     
匿名技术用户   2020-12-29 10:03   11   0

一、 获取验证码:
1. 输入手机号码
2. 通过ajax发送请求
3. 后端: 获取手机号码
使用requests向第三方的服务端(网易云信)发送请求

官方文档 https://dev.yunxin.163.com/docs/product/%E7%9F%AD%E4%BF%A1/%E7%9F%AD%E4%BF%A1%E6%8E%A5%E5%85%A5%E7%A4%BA%E4%BE%8B


4.获取响应对象:
res.text 文本内容
res.content 二进制

5. 转成json对象
r = json.loads(res.text)

r.obj ---> 验证码

保存到缓存中: cache.set(phone,r.obj)

6. 返回json结果给ajax


二、登录验证:
获取手机号码和验证码进行验证
phone = request.form.get('phone')
validate = request.form.get('valiadate')
code = cache.get(phone)
if code == validate:
user = User.query.filter(User.phone == phone).first()
cache.set('uname', user.username)
session['uname'] = user.username
return redirect(url_for('blog.index'))
else:
flash('手机验证码错误')
return render_template('login_phonecode.html')

调用即可实现网易云信api


# 获取手机号码,并向网易云信发送请求
@blog_bp.route('/send', endpoint='send')
def send_request():
    # 获取phone
    phone = request.args.get('phone')
    url = 'https://api.netease.im/sms/sendcode.action'  # 网易云信接口
    headers = {}
    headers['Content-Type'] = 'application/x-www-form-urlencoded;charset=utf-8'
    AppSecret = '111111111111111'
    Nonce = '111111222222333333333'
    CurTime = str(time.time())
    headers['AppKey'] = '972115c8e25fe6ff97ffdcbf0c894bbb111'
    headers['Nonce'] = Nonce
    headers['CurTime'] = CurTime
    s = AppSecret + Nonce + CurTime
    headers['CheckSum'] = hashlib.sha1(s.encode('utf-8')).hexdigest().lower()
    res = requests.post(url, data={'mobile': phone}, headers=headers)
    print(res.text, type(res.text))
    json_obj = json.loads(res.text)  # 字典
    cache.set(phone, json_obj.obj)
    # print(res.content)
    if json_obj.code == 200:
        return {'msg': 'ok'}
    else:
        return {'msg': 'fail'}

前端.html

{% extends 'base.html' %}
{% block title %} 用户登录 {% endblock %}

{% block content %}
<div class="container">
    <p>
        {% with messages = get_flashed_messages() %}
        {% if messages %}
    <ul class="flash">
        {% for message in messages %}
        <div class="alert alert-success" style="text-align: center">
            <button aria-hidden="true" data-dismiss="alert" class="close" type="button">×</button>
            <strong>{{ message }}</strong></div>
        {% endfor %}
    </ul>
    {% endif %}
    {% endwith %}
    </p>
    <form action="{{ url_for('blog.login') }}" method="post">
        <input type="hidden" name="csrf_token" value="{{csrf_token()}}">
        <div class="form-group">
            <label class="col-sm-2 control-label">手机号码</label>
            <div class="col-sm-10">
                <input type="text" class="form-control" id="phone" placeholder="phone"
                       name="phone">
            </div>
        </div>

        <div class="form-group">
            <label class="col-sm-2 control-label">验证码</label>
            <div class="col-sm-8">
                <input type="text" class="form-control" id="valiadate" placeholder="valiadate" name="valiadate">
            </div>
            <div class="col-sm-2">
                <input type="button" value="获取验证码" class="btn btn-warning" id="getCode">
            </div>
        </div>
        <div class="form-group">
            <div class="col-sm-offset-2 col-sm-10">
                <button type="submit" class="btn btn-info">用户登录</button>
            </div>
        </div>

    </form>

</div>
{% endblock %}

{% block myjs %}
    <script>
        $('#getCode').click(function(){
            // 获取手机号码文本框的值
            var  phone = $('#phone').val();

            flag=(phone!=''&&phone.length==11);
            console.log(phone+"---"+flag);
            if(flag){
                // 向服务器发送请求
                $.getJSON("{{url_for('blog.send')}}",{phone:phone},function(data){

                });
            }else{
              alert('手机号码不能为空,长度必须11位')
            }
        })



    </script>

{% endblock %}

分享到 :
0 人收藏
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

积分:7942463
帖子:1588486
精华:0
期权论坛 期权论坛
发布
内容

下载期权论坛手机APP