maigeng 2023-03-22 21:16 采纳率: 80%
浏览 21
已结题

如何使用flutter和flask来实现登陆注册功能

我想使用flutter和python的flask框架来实现登陆和注册功能,flutter负责设计登陆和注册表单的页面,flask框架作为后端来处理前端发送表单的数据

那么,flask框架需要怎么设计,在获取前端表单的数据中是不是需要token和session的玩意,是必须要的吗。接着flask拿到数据后去mysql数据库查找是否符合,如果成功的话,flutter前端应该要怎么跳转到首页,是得到flask发送的成功结果后就路由跳转吗?要让flask设计api请求的东东吗,有没有参考例子。

  • 写回答

2条回答 默认 最新

  • devid008 2023-03-23 11:59
    关注

    要使用Flutter和Flask实现登录和注册功能,需要进行以下步骤:

    • 设计Flutter应用程序的登录和注册表单页面。可以使用Flutter的Material Design组件来构建漂亮的UI。
      在Flask中设计API接口,以便接收来自Flutter应用程序的表单数据。Flask需要使用Flask和flask_restful模块。
      在Flask中连接MySQL数据库,以便验证用户登录信息。
      在Flask中实现注册和登录功能的逻辑。
      在Flutter中处理来自API的响应,并根据响应结果导航到相应的屏幕。
      以下是一个简单的参考示例:

    Flask后端代码:

    from flask import Flask, request
    from flask_restful import Resource, Api
    from flask_cors import CORS
    import hashlib
    import pymysql
    
    app = Flask(__name__)
    api = Api(app)
    CORS(app)
    
    conn = pymysql.connect(host='localhost', user='root', password='password', db='test', charset='utf8mb4', cursorclass=pymysql.cursors.DictCursor)
    
    class Register(Resource):
        def post(self):
            data = request.json
            username = data.get('username')
            password = data.get('password')
            hash_password = hashlib.sha256(password.encode()).hexdigest()
            
            cursor = conn.cursor()
            cursor.execute('SELECT * FROM users WHERE username=%s', (username,))
            result = cursor.fetchone()
    
            if result:
                return {'message': 'User already exists.'}, 400
    
            cursor.execute('INSERT INTO users (username, password) VALUES (%s, %s)', (username, hash_password))
            conn.commit()
    
            return {'message': 'Registration successful.'}, 201
    
    class Login(Resource):
        def post(self):
            data = request.json
            username = data.get('username')
            password = data.get('password')
            hash_password = hashlib.sha256(password.encode()).hexdigest()
    
            cursor = conn.cursor()
            cursor.execute('SELECT * FROM users WHERE username=%s AND password=%s', (username, hash_password))
            result = cursor.fetchone()
    
            if not result:
                return {'message': 'Invalid credentials.'}, 401
    
            return {'message': 'Login successful.'}, 200
    
    api.add_resource(Register, '/register')
    api.add_resource(Login, '/login')
    
    if __name__ == '__main__':
        app.run(debug=True)
    
    
    

    Flutter前端代码:

    import 'dart:convert';
    import 'package:flutter/material.dart';
    import 'package:http/http.dart' as http;
    
    class RegisterScreen extends StatefulWidget {
      @override
      _RegisterScreenState createState() => _RegisterScreenState();
    }
    
    class _RegisterScreenState extends State<RegisterScreen> {
      final _formKey = GlobalKey<FormState>();
      final _usernameController = TextEditingController();
      final _passwordController = TextEditingController();
    
      Future<void> _register() async {
        final response = await http.post(
          Uri.parse('http://localhost:5000/register'),
          headers: <String, String>{
            'Content-Type': 'application/json; charset=UTF-8',
          },
          body: jsonEncode(<String, String>{
            'username': _usernameController.text,
            'password': _passwordController.text,
          }),
        );
    
        if (response.statusCode == 201) {
          Navigator.pushReplacementNamed(context, '/home');
        } else {
          ScaffoldMessenger.of(context).showSnackBar(
            SnackBar(content: Text(jsonDecode(response.body)['message'])),
          );
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 3月31日
  • 已采纳回答 3月23日
  • 创建了问题 3月22日

悬赏问题

  • ¥100 set_link_state
  • ¥15 虚幻5 UE美术毛发渲染
  • ¥15 CVRP 图论 物流运输优化
  • ¥15 Tableau online 嵌入ppt失败
  • ¥100 支付宝网页转账系统不识别账号
  • ¥15 基于单片机的靶位控制系统
  • ¥15 真我手机蓝牙传输进度消息被关闭了,怎么打开?(关键词-消息通知)
  • ¥15 装 pytorch 的时候出了好多问题,遇到这种情况怎么处理?
  • ¥20 IOS游览器某宝手机网页版自动立即购买JavaScript脚本
  • ¥15 手机接入宽带网线,如何释放宽带全部速度