【flask】 前后端通信方式 原生js的ajax,总结

前端接收参数

python 复制代码
#如果是路径参数如:/auth/<email>
#渲染模版并向html页面传参数
@app.route('/blog/<blog_id>')
def blog_detail(blog_id):
    return render_template('blog_detail.html',blog_id=blog_id)
    
#如果 methods是post说明参数在请求体里面,
request.form['参数key'] 
Request.form.get['key']

#如果 methods 是get 说明参数在url路径里面
request.args.get('key')
request.values.get('key')

例子是前端需要给邮箱发送验证码。所以需要填写邮箱,然后点击按钮,发送验证码给所填写的邮箱。

前段传递给后段数据(ajax)

这里的例子是js的ajax,js部分逻辑:

首先是获取到按钮,给按钮添加点击事件。点击事件内部逻辑为获取到邮箱输入框中所输入的邮箱,并将其传递给后端。

js中的ajax如果要传递参数,如果是get参数直接在url后面填写即可;如果是post参数,需要在xhr.send()方法后面添加所要传递的参数。参数之间用'&'连接

python 复制代码
#发送post参数
xhr.send("email="+email+"&username="+username);

整体js代码

python 复制代码
window.onload=function(){
    var getVerificationCodeButton = document.getElementById("captcha-btn");
    getVerificationCodeButton.addEventListener('click',function(){
        var inputElement = document.getElementById("exampleInputEmail1");
        var email = inputElement.value;
        //1.创建对象
        const xhr = new XMLHttpRequest();
        //2.初始化xhr对象
        xhr.open('POST','/auth/sendVerificationCode');
        //设置请求头
        xhr.setRequestHeader('Content-type','application/x-www-form-urlencoded'); //固定语法
        //3.发送请求,在这里,可以传请求体参数
        xhr.send("email="+email);
        //4.事件绑定 处理服务器端返回的结果
        //on when
        //readystate是xhr对象中的属性,表示状态
        //0未初始化,刚开始
        //1表示open调用完毕,2表示send方法调用完毕
        //3表示服务端返回部分结果,4表示返回全部结果
        xhr.onreadystatechange = function(){
            //判断服务器已经返回了所有结果
            if(xhr.readyState === 4){
                if(xhr.status >= 200 && xhr.status<300){
                    //处理结果 行 头 空行 体
                    console.log(xhr.status);//响应状态码
                    console.log(xhr.statusText);//状态字符串
                    console.log(xhr.getAllResponseHeaders);//所有响应头
                    console.log(xhr.response);//响应体
                }
            }
        }
    })
}

后端接收参数代码

python 复制代码
#发送验证码到邮箱 ---这个auth是使用蓝图的哦
@auth.route("/sendVerificationCode",methods=["POST","GET"])
def send_verification_code():
    email = request.form.get("email")
    print(email)
    message = Message(subject="发送验证码测试", recipients=[email], body="邮箱发送验证码测试");
    mail.send(message);
    return "发送验证码"
相关推荐
love530love6 小时前
LiveTalking 数字人项目 Windows 部署完全指南(EPGF 架构)
人工智能·windows·python·架构·livetalking·epgf
遇事不決洛必達6 小时前
【Python基础】GIL 锁是什么及其对爬虫的影响
爬虫·python·线程·进程·gil锁
星辰徐哥7 小时前
Spring Boot 微服务架构设计与实现
spring boot·后端·微服务
星辰徐哥7 小时前
Spring Boot 数据导入导出与报表生成
spring boot·后端·ui
明夜之约7 小时前
Spring Boot 自动装配源码
java·spring boot·后端
Leaton Lee7 小时前
Spring Boot分层架构详解:从Controller到Service再到Mapper的完整流程
java·spring boot·后端·架构
Micro麦可乐7 小时前
Spring Boot 实战:从零设计一个短链系统(含完整代码与数据库设计)
数据库·spring boot·后端·哈希算法·雪花算法·短链系统
Jinkxs7 小时前
Resilience4j- 与 Spring Boot 快速集成:自动配置与基础注解使用
java·spring boot·后端
毕设源码_郑学姐7 小时前
计算机毕业设计springboot网络相册设计与实现 基于Spring Boot框架的在线相册管理系统开发与应用 Spring Boot驱动的网络影集设计与实践
spring boot·后端·课程设计
辣机小司7 小时前
【踩坑记录:Spring Boot 配置文件读取值不一致?警惕 YAML 的“八进制陷阱”与 SnakeYAML 版本之谜】
java·spring boot·后端·yaml·踩坑记录