zoukankan      html  css  js  c++  java
  • FastAPI 学习之路(四十七)WebSockets(三)登录后才可以聊天

     之前我们是通过前端自动生成的,这次我们通过注册登录,保存到本地去实现。我们可以应该如何实现呢,首先我们实现一个登录界面。放在templates文件下。

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <title>Title</title>
        <script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js">
    </script>
    </head>
    <body>
    <div>
        <p><input id="username" placeholder="用户名"></p>
        <p><input id="password" placeholder="密码" type="password"></p>
        <button id="login">登录</button>
    </div>
    <script>
        $('#login').click(function () {
            $.ajax({
                type: "post",
                url: "/token",
                 contentType: "application/json; charset=utf-8",
                data: JSON.stringify({
                    email: $("#username").val(),
                    password: $("#password").val()
                }),
                success: function (data) {
                    if (data['msg'] == "pass") {
                        window.localStorage.setItem("token", data['token'])
                        window.location.href="/"
                    }else {
                        alert(data['msg'])
                    }
                }
            })
    
        })
    </script>
    </body>
    </html>

    我们在后端去编写一个返回静态文件的页面,一个返回token的方法、

    @app.get("/login")
    async def login(request: Request):
        return templates.TemplateResponse(
            "login.html",
            {
                "request": request
            }
        )
    @app.post('/token')
    def token(user: UserCreate, db: Session = Depends(get_db)):
        db_crest = get_user_emai(db, user.email)
        fake_hashed_password = user.password + "notreallyhashed"
        if db_crest:
            if fake_hashed_password==db_crest.hashed_password:
                return {"token":"leizishuoceshi",'msg':'pass'}
        return {'msg':'fail'}

    然后我们可以去启动下,当我们启动完成登录后发现本地存了token,那么这个时候我们需要改造下webchat.html,我们的取本地的 token,同时也实现了一个退出的功能。

    <!DOCTYPE html>
    <html>
    <head>
        <title>Chat</title>
    </head>
    <body>
    <h1>WebSocket 聊天</h1>
    <form action="" onsubmit="sendMessage(event)">
        <input type="text" id="messageText" autocomplete="off"/>
        <button>Send</button>
    </form>
    <button onclick="logout()">退出</button>
    <ul id='messages'>
    </ul>
    <script>
        var  token=window.localStorage.getItem("token")
        if (token==null ){
            window.location.href="/login"
        }
        var ws = new WebSocket("ws://localhost:8000/items/ws?token="+token);
    
        ws.onmessage = function (event) {
    
            var messages = document.getElementById('messages')
    
            var message = document.createElement('li')
    
            var content = document.createTextNode(event.data)
    
            message.appendChild(content)
    
            messages.appendChild(message)
    
        };
    
        function sendMessage(event) {
    
            var input = document.getElementById("messageText")
    
            ws.send(input.value)
    
            input.value = ''
    
            event.preventDefault()
    
        }
        function logout() {
            window.localStorage.removeItem("token")
            window.location.href='/login'
        }
    </script>
    
    </body>
    
    </html>

      这样我们就可以登录后,然后去获取登录产生的token,然后和后端发发送消息,这样我们完成了一个登录聊天,退出后无法聊天的功能。我们如果直接访问聊天的页面,也是可以直接去定向到我们的登录的界面呢,我们的聊天是依赖于我们的登录的。

     

     成功后才可以发送聊天内容

     点击退出,直接退出

     本地存储也无任何

    文章首发在公众号,欢迎关注。

  • 相关阅读:
    架构的上层是系统,是系统要素的组织形式
    计数与方法论、哲学
    网络编程--会话层、表示层、应用层
    面向中间件编程--草稿
    泛型:基于类型组合的算法和结构构建---数据结构与算法
    面向对象:消息机制更适合描述;
    类型的连接:实连接、虚连接
    数据库 = filesystem + transcation + dsl + dslengine
    一文看透浏览器架构
    代码的结合性:继承 扩展 组合 变换--swift暗含的四根主线
  • 原文地址:https://www.cnblogs.com/leiziv5/p/15416872.html
Copyright © 2011-2022 走看看