python - socket發送的信息怎么在瀏覽器中顯示出來
問題描述
用socket模塊建立的socket服務端,比如監聽了本地的4399端口。用瀏覽器連接,但是顯示不了socket發來的字符。這該怎么辦?
問題解答
回答1:因為你的端口不是80, 所以瀏覽器沒法用http協議去解析你的請求, 因為它不認識4399是干嘛的, 所以如果你想用監聽4399,并且用瀏覽器看到socket服務端發送的消息, 你就必須自己構建http報文
import sockets = socket.socket(socket.AF_INET, socket.SOCK_STREAM) # tcp 報文s.bind((’localhost’, 4399))s.listen(2)req, req_info = s.accept()req.recv(65549)# http協議頭是文本形式, 以rn作為每個字段的分隔, 最后頭部以rn結束, 所以我們主要構造好 http頭, 瀏覽器就能識別的, 接下來的正文, 就能按照html的標準的編寫了req.send(’HTTP/1.1 200 OKrnrn<html><body>hello</body></html>’)回答2:
關于Python SOCKET, 如果你是想瀏覽器看到數據,那么你肯定要實現HTTP協議,不然瀏覽器怎么會知道你發來的啥,數據量有多大?關于Python Socket HTTP ,請看這里 https://github.com/thisforeda...
相關文章:
1. macOS Sierra 10.12 安裝mysql 5.7.1出現錯誤2. mysql - 拖拽重排序后怎么插入數據庫?3. android - 安卓做前端,PHP做后臺服務器 有什么需要注意的?4. javascript - 按鈕鏈接到另一個網址 怎么通過百度統計計算按鈕的點擊數量5. mysql 獲取時間函數unix_timestamp 問題?6. mysql - 僅僅只是把單引號與反斜杠轉義不用prepare statement能否避免sql注入?7. php - 生產環境下,給MySQL添加索引,修改表結構操作,如何才能讓線上業務不受影響?8. mysql主主同步,從庫不同步應該怎么解決?9. mysql在限制條件下篩選某列數據相同的值10. 新入手layuiadmin,部署到tp中。想用php自已寫一個后臺管理系統。
