python的Web編程

首先看一下效果

在這里插入圖片描述

完整代碼

import socket
from multiprocessing import ProcessHTML_ROOT_DIR = ""def handle_client(client_socket):request_data = client_socket.recv(1024)print("request data:", request_data)response_start_line = "HTTP/1.0 200 OK\r\n"response_headers = "Server: My server\r\n"response_body = "hello world"response = response_start_line + \"\r\n" + response_bodyprint("response data:", response)client_socket.send(bytes(response, "utf-8"))client_socket.close()if __name__ == "__main__":server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)server_socket.bind(("127.0.0.1", 8080))server_socket.listen(128)while True:client_socket, client_address = server_socket.accept()handle_client_process = Process(target=handle_client, args=(client_socket,))handle_client_process.start()client_socket.close()

文章目錄

  • 首先看一下效果
  • 完整代碼
  • 服務器
    • socket
    • bind
    • listen
    • accept
    • 多進程處理任務

服務器

socket

server_socket = socket.socket(socket.AF_INET, socket.SOCK_STREAM)

AF_INET指定使用IPv4協議,如果要用更先進的IPv6,就指定為AF_INET6。SOCK_STREAM指定使用面向流的TCP協議,這樣,一個Socket對象就創建成功,但是還沒有建立連接。

bind

server_socket.bind(("127.0.0.1", 8080))

服務器可能有多塊網卡,可以綁定到某一塊網卡的IP地址上,也可以用0.0.0.0綁定到所有的網絡地址,還可以用127.0.0.1綁定到本機地址。127.0.0.1是一個特殊的IP地址,表示本機地址,如果綁定到這個地址,客戶端必須同時在本機運行才能連接,也就是說,外部的計算機無法連接進來。

listen

server_socket.listen(128)

調用listen()方法開始監聽端口,傳入的參數指定等待連接的最大數量

accept

等待并返回一個客戶端的連接,采用多進程來處理要做的事情

while True:client_socket, client_address = server_socket.accept()handle_client_process = Process(target=handle_client, args=(client_socket,))handle_client_process.start()client_socket.close()

多進程處理任務

def handle_client(client_socket):request_data = client_socket.recv(1024)print("request data:", request_data)response_start_line = "HTTP/1.0 200 OK\r\n"response_headers = "Server: My server\r\n"response_body = "hello world"response = response_start_line + "\r\n" + response_bodyprint("response data:", response)client_socket.send(bytes(response, "utf-8"))client_socket.close()

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/382494.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/382494.shtml
英文地址,請注明出處:http://en.pswp.cn/news/382494.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

mysql 學習筆記 02創建表

表結構的創建 比如: create table userinfo (id int unsigned comment id號name varchar(60) comment 用戶名password char(32),birthday date ) character set utf8 engine MyISAM;comment 表示注釋的意思 不同的存儲引擎,創建的表的文件不一樣

mysql 學習筆記03 常用數據類型

數值類型: a. 整數類型: 注意事項: 舉例:某個整型字段 ,不為空,且有默認值 create table test (age int unisigned not null default 1);zerofill的使用 b. bit類型的使用 c.小數類型 小數類型占用…

VMware的虛擬機連不上網

1.如果你發現在VMware下運行的虛擬機無法連接網絡,那下面的方法也許可以幫 到你。(前提是你的物理網絡是通的) 第一步:在VMware界面下 單擊“編輯“→”虛擬網絡編輯器” 第二步:單擊”更改設置” 獲取權限&#xff…

python三國演義人物出場統計

完整代碼 開源代碼 統計三國演義人物高頻次數 #!/usr/bin/env python # codingutf-8 #e10.4CalThreeKingdoms.py import jieba excludes {"來到","人馬","領兵","將軍","卻說","荊州","二人","…

mysql 學習筆記03修改表以及其他操作

首先創建一張表 在現有表的結構上增加字段 alter table users add image varchar(100) not null defalut comment 圖片路徑;修改某個字段的長度 alter table users modify job vachar(60) not null comment 工作;刪除某個字段 刪除sex這個字段 alter table users drop se…

統計哈姆雷特文本中高頻詞的個數

統計哈姆雷特文本中高頻詞的個數 三國演義人物出場統計 開源代碼 講解視頻 kouubuntu:~/python$ cat ClaHamlet.py #!/usr/bin/env python # codingutf-8#e10.1CalHamlet.py def getText():txt open("hamlet.txt", "r").read()txt txt.lower()for ch…

mysql 學習筆記04 insert與update語句

1.插入數據 注意事項: 字符和日期類型, 要用 單引號 括起來 insert into (), (), () 例如: insert into goods values(1, abc, 2.2), (2, def, 3.3);這種形式添加多條記錄 insert 語句,如果沒有指定字段名,則values …

PyCharm怎么關閉端口,解決端口占用問題

在進行web開發遇到這個問題!

mysql 筆記05 select語句以及條件語句的使用

select語句 過濾重復語句(distinct) 舉例: 查詢學生的總分 select name, math English China as 總分 from students;在姓趙的學生總分基礎上, 增加60%, select name, round((math English China) * 1.6, 2) as …

python3 與 Django 連接數據庫:Error loading MySQLdb module: No module named 'MySQLdb'

解決方法:在 init.py 文件中添加以下代碼即可。 import pymysql pymysql.install_as_MySQLdb()

mysql 學習筆記05 統計函數的相關使用

合計函數count, 統計多少條記錄 統計共有多少學生 select count(*) from students;查詢數學成績大于等于90的學生數量 select count(*) from students where math > 90;查詢總分超過235分的學生的數量 select count(*) from students where (English math Ch…

Unknown column '' in 'field list'

Unknown column ‘’ in ‘field list’ 解決辦法 正確寫法:cursor.execute("update book set name%s where id%d" % (name, int(id))) 錯誤寫法:cursor.execute("update book set name%s where id%d" % (name, int(id)))你要獲取字…

mysql學習筆記06分組語句的使用

group by 子句 對列進行分組 有兩張表: 一張為部門表, 一張為員工表統計 每個部門的平均工資,與最高工資 select avg(salary), max(salary) from emp group by deptno;統計 每個部門的每個崗位的 平均工資與最低工資(注意這里的…

Django學習筆記《一》初始化pycharm和mysql數據庫及相關環境

真的不太好學啊!記錄一下筆記,要不有的東西老要查! CSRF驗證 防止偽造數據添加數據庫,關閉方式 MIDDLEWARE [django.middleware.security.SecurityMiddleware,django.contrib.sessions.middleware.SessionMiddleware,django.m…

mysql 學習筆記07日期相關函數01

函數基本介紹: 基本使用: 使用日期函數插入數據: 2. date函數的舉例: data_add函數舉例: data_sub函數舉例: datadiff函數舉例: 綜合案例: 3. 10分鐘之內發出的信息

Django學習筆記《二》圖書管理系統

掛載到阿里云方法 圖書館書籍管理系統

mysql 學習筆記08 日期相關函數2

基本介紹 now()函數舉例: 可以直接插入數據,數值為當前日期時間 year 函數的使用: 只統計2016年的數據信息 month函數的使用 只統計2016年6月份的數據信息 unix_timestamp函數的使用 返回一個秒數,的時間戳 可以作為數值&am…

Django學習筆記《一》圖書管理系統項目掛載到阿里云

項目示例 pycharm編譯好的項目 阿里云服務器域名 成果展示 如果不能訪問,可能端口已經關閉。 遇到的問題一大堆,大量使用網上文章,如有問題,進行留言聯系。 簡單做一個記錄供自己查閱和檢索,以備下次服務器搭建&a…

mysql 學習筆記09字符串相關函數

相關介紹: concat函數使用,拼接字符串 大小寫轉換函數 length函數,統計字符串長度(字節數) replace 函數,字符串內容替換: substring函數使用,字符串截取 綜合使用&#…