Как сделать управление сеансом в приложении js с flask в качестве бэкэнда? - PullRequest
0 голосов
/ 07 января 2020

Здравствуйте, я работаю над веб-приложением, созданным с помощью create-реагировать на приложение. Я использую flask в качестве бэкэнда. в flask я использую CORS и cross_origin. Мое приложение выглядит следующим образом:

import random
from flask import Flask, request, session, jsonify, Response
from dbconnect import POD_Admin_DB as dbAdmin 
from flask_cors import CORS, cross_origin

app = Flask(__name__)
CORS(app)
otp = "000000"
app.secret_key = b'_5#y2L"F4Q8z\n\xec]/'

@app.route('/api/requestOTP',methods=["POST", "OPTIONS"])
@cross_origin(supports_credentials=True)
def pod_requestOTP():
    print('requestOTP')    
    session['otp']=generate_code()
    print((session))
    print (session['otp'])
    #userPhone=request.json['userPhone']
    return session['otp']

@app.route('/api/verifyOTP',methods=["POST","OPTIONS"])
@cross_origin(supports_credentials=True)
def pod_verifyOTP():
    if request.method =="OPTIONS":
        print("here")
        return Response(headers={"Content-Type": "application/json charset=utf-8",
        "Allow": "POST, OPTIONS",
        "Access-Control-Allow-Origin": "*",
        "Access-Control-Allow-Headers": "Content-Type",
        "Access-Control-Allow-Methods": "DELETE, GET, HEAD, OPTIONS, PATCH, POST, PUT"
        })
    elif request.method == "POST":

        print("verifyOTP")
        print((session))
        #print(dir(request))
        print(request.data)
        otp = request.json['pod_Otp']
        print((otp))

        userPhone=request.json['userPhone']   
        print(userPhone)    
        if otp == session['otp']:
            print("otp matched")
            dbAdmin.connectToDb()
            dbAdmin.isClientAlreadyRegistered(userPhone)
            return jsonify({"ok":"success"})
        else:
            print("otp not matching")
            return jsonify({"Notok":"success"})

#some method that generates my otp
#def otp_generationMethod():
    ###code

Это мой код flask. Я получаю доступ к этим обоим маршрутам из своего приложения реакции. Каждый раз, когда я получаю метод pod_verifyOTP () после requestOTP () из моего сеанса из flask, он становится пустым. Я искал много ссылок для этой проблемы, но не мог исправить это. Как мне поддерживать эту сессию?

1 Ответ

0 голосов
/ 28 января 2020

Вот как я это сделал: изменения, которые я сделал в приведенном выше коде, следующие: я импортировал flask_session

from flask_session import Session

назначенный тип сеанса как "файловая система"

SESSION_TYPE = 'filesystem'

и затем добавил приложение в сессию s следующим образом, как добавил его в CORS

SESSION_TYPE = 'filesystem'
app.config.from_object(__name__)
Session(app)
CORS(app)

И я получил желаемый результат.

...