网页版长链接对话

websocket初级示例


import json
import os
from typing import Union
from tornado.web import url
import tornado.websocket
import tornado.web
import tornado.ioloop
import requests


class Client(tornado.web.RequestHandler):
    def get(self):
        return self.render('index.html')


class ServerHandle(tornado.websocket.WebSocketHandler):
    web_client = set()



    def open(self, *args: str, **kwargs: str):
        self.web_client.add(self)

    # 接受客户端信息
    def on_message(self, message: Union[str, bytes]):
        print(message)
        # 图灵机器人示例
        req = requests.post(url='请求地址',json={
            '请求参数(userinfo 必须有  perception 请求的问题)'
        })


        print(req.text)
        resdict = json.loads(req.text)
        print(resdict['results'][0]['values']['text'])
        # 返回信息给客户端,写进p标签
        self.write_message(resdict['results'][0]['values']['text'])

        # self.write('你好')
        

    def on_close(self):
        self.web_client.remove(self)

def main():
    app = tornado.web.Application(handlers=[
        url(r'/$',Client,name='index'),
        url(r'/ws/$',ServerHandle,name='ws'),
    ],
        debug=True,
        autoreload=True,
        template_path = os.path.join(os.path.dirname(__file__),'templates')
    )
    app.listen(8000)
    tornado.ioloop.IOLoop.current().start()

if __name__ == "__main__":
    main()

前端简单展示及jquery请求

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>联通</title>
</head>
<body>

<input type="text" name="message" id="content">
<input type="button" value="发送">

<hr>

<p id="result">

</p>
</body>
</html>
<!--引入js样式-->
<script src="********">

</script>

<script>

    var ws =new WebSocket('ws://localhost:8000/ws/')
//    接受服务器返回的信息(谁发送谁就是服务器)
    ws.onmessage = function (ev) {
        console.log(ev.data)
        
//        得到相应
        $('#result').append("<p>"+ev.data+"</p>")
    }

//    发送
    $('input[type="button"]').click(function () {
        content = $('#content').val()
        ws.send(content)
        
//        提出问题
        $('#result').append("<p>"+content+"</p>")
    })
</script>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值