返回用户指定页面的web服务器

小编 2026-06-04 阅读:1866 评论:0
import socketimport reimport osdef handle_client...
import socketimport reimport osdef handle_client(socket_con):    """     接收来自客户端的请求,并接收请求报文,解析,返回    """    # 1、服务器接收客户端的请求报文    request = socket_con.recv(4096).decode()    # 以行切割请求报文为列表    res = request.split('
')    # 取第一位(请求行):GET / HTTP/1.1,并用正则切割GET / HTTP/1.1,取出路径位置    path = re.match('w+s(S+)',res[0])    path = path.group(1)    # 判断路径长度,大于一则拼接出路径,小于等于一则显示首页    if len(path) > 1:        # 路径取出,开始拼接资源路径(绝对路径自己填写)        path = '# 文件夹绝对路径' + path        print(path)    else:        # 显示首页代码        response_line = 'HTTP/1.1 200 OK
'        response_head = 'Content-Type:text/html;charset=utf-8
'        response_body = '''            <html>            <head>            <title>首页</title>            <style>            body {                    width: 35em;                    margin: 0 auto;                    font-family: Tahoma, Verdana, Arial, sans-serif;                 }            </style>            </head>            <body>            <h1>首页</h1>            <p>欢迎来到首页</p>            <p><em>感谢你的使用</em></p>            </body>            </html>'''        response = response_line + response_head + '
' + response_body        socket_con.send(response.encode())        socket_con.close()    # 路径大于一并取出之后判断资源是否存在    if not os.path.exists(path):        # 资源不存在则显示资源不存在界面        response_line = 'HTTP/1.1 404 NOT FOUND
'        response_head = 'Content-Type:text/html;charset=utf-8
'        response_body = '''            <html>            <head>            <title>错误</title>            <style>                body {                    width: 35em;                    margin: 0 auto;                    font-family: Tahoma, Verdana, Arial, sans-serif;                }            </style>            </head>            <body>            <h1>你请求的资源不存在!</h1>            <p>如果你想访问一个资源,请输入正确的资源路径</p>            <p><em>感谢你的使用</em></p>            </body>            </html>'''        response = response_line + response_head + '
' + response_body        socket_con.send(response.encode())        socket_con.close()        return    else:        # 资源存在以后判断是否是文件,是文件则直接读取        if os.path.isfile(path):            response_line = 'HTTP/1.1 200 OK
'            response_head = 'Server:skylark 2.0
'            response_head += 'Content-Type:*/*;charset:utf-8
'            f = open(path, 'rb')            response_body = f.read()            response = response_line.encode() + response_head.encode() + '
'.encode() + response_body            socket_con.send(response)            socket_con.close()            return        else:            if path.endswith('/'):                 # 如果是文件夹                 # 判断文件夹下是否有默认文件,如果有则返回,如果没有则判断服务器是否开启了目录浏览                 # 默认文件:index.html  default.html                 # 是否可以访问默认文件开关,True 开 ,False 关                 default_document = False                 if default_document:                     # 判断用户访问的文件夹下是否有index.html 或者 default.html                     if os.path.exists(path + 'index.html'):                         response_line = 'HTTP/1.1 200 OK
'                         response_head = 'Server:skylark 2.0
'                         response_head += 'Content-Type:*/*;charset:utf-8
'                         f = open(path + 'index.html', 'rb')                         response_body = f.read()                         response = response_line.encode() + response_head.encode() + '
'.encode() + response_body                         socket_con.send(response)                         socket_con.close()                         return                     elif os.path.exists(path + 'default.html'):                         response_line = 'HTTP/1.1 200 OK
'                         response_head = 'Server:skylark 2.0
'                         response_head += 'Content-Type:*/*;charset:utf-8
'                         f = open(path + 'default.html', 'rb')                         response_body = f.read()                         response = response_line.encode() + response_head.encode() + '
'.encode() + response_body                         socket_con.send(response)                         socket_con.close()                         return                     else:                         # 如果没有上述两个页面,则可以返回404错误,或者302重定向                         response_line = "HTTP/1.1 404 Not Found
"                         response_head = "Server:skylark 2.0
"                         response_body = "index.html or default.html is not exist!!!"                         response = response_line + response_head + "
" + response_body                         socket_con.send(response.encode())                         socket_con.close()                # 不能访问默认文件情况下,判断服务器是否开启了目录浏览                 else:                     dir_browsing = True                     if dir_browsing:                         # 把用户请求的文件夹中所有的文件和文件夹以目录的形式返回到页面中                         # 获取用户请求的文件夹                         list_names = os.listdir(path)                         response_line = 'HTTP/1.1 200 OK
'                         response_head = 'Server:skylark 2.0
'                         # 动态的拼接页面,将目录中的文件或者文件夹的名称以HTML页面的方式返回给浏览器                         response_body = '<html><head><body><ul>'                         for item in list_names:                             response_body += "<li><a href = '#'>" + item + "</a></li>"                         response_body += '</ul></body></head></html>'                         response = response_line + response_head + "
" + response_body                         socket_con.send(response.encode())                         socket_con.close()                         return            else:                # 用户请求的路径没有斜线                # 重定向到+斜线的目录下,并显示重定向以后的路径(此处可以增加有斜线目录处理方式也就是上面的方法)                response_line = 'HTTP/1.1 302 Found
'                response_head = 'Server:skylark 2.0
'                response_head += 'Content-Type:text/html;charset=utf-8
'                response_body = '重定向' + path + '/'                response = response_line + response_head + '
' + response_body                socket_con.send(response.encode())                socket_con.close()def main():    # 1、服务器创建负责监听的socket    socket_watch = socket.socket(socket.AF_INET,socket.SOCK_STREAM)    # 2、设置地址重用    socket_watch.setsockopt(socket.SOL_SOCKET, socket.SO_REUSEADDR, 1)    # 3、绑定监听的端口    socket_watch.bind(("",8888))    # 4、设置监听队列    socket_watch.listen(128)    # 5、通过循环,不停的接收来自客户端的连接请求    while True:        socket_con,con_adds = socket_watch.accept()        # 注意将con_adds转成字符串        print("客户端:%s连接成功!!!" % str(con_adds))        # 接收来自客户端的请求,并接收请求报文,解析,返回        handle_client(socket_con)if __name__ == '__main__':    main()

  

                                                                   -------  知识无价,汗水有情,如需搬运请注明出处,谢谢!

版权声明

本文仅代表作者观点,不代表百度立场。
本文系作者授权百度百家发表,未经许可,不得转载。

热门文章
  • 机房智能化温湿度解决方式之POE供电以太网温湿度传感器

    机房智能化温湿度解决方式之POE供电以太网温湿度传感器
    机房智能化温湿度解决方式之POE供电以太网温湿度传感器 北京盈创力和电子科技有限公司 智能型TCP网口温湿度记录仪 北京IP网络温湿度记录仪厂家,北京盈创力和 北京智能型TCP网口温湿度记录仪IP网络温湿度记录仪是一种新型的基于TCP/IP协议双绞线以太网标准温湿度采集模块,利用它可以实现现场温度值、相对湿度值的采集,同时利用其自身的RJ45通信接口可以方便地和机房监控主机或交换机集线器进行联网。 工作于-40℃~85℃工业级带...
  • Sequential Monte Carlo Methods (SMC) 序列蒙特卡洛/粒子滤波/Bootstrap Filtering

    Sequential Monte Carlo Methods (SMC) 序列蒙特卡洛/粒子滤波/Bootstrap Filtering
    Problem Statement 我们考虑一个具有马尔可夫性质、非线性、非高斯的状态空间模型(State Space Model):对于一个时间序列上的观测结果{yt,t∈N}\\{ y_t , t \\in N \\}{yt​,t∈N},我们认为每个观测结果yty_tyt​的生成依赖于一个无法直接观察的隐变量xt∈{xt,t∈N}x_t \\in \\{x_t , t \\in N \\}xt​∈{xt​,t∈N},即:p(...
  • HTTP状态保持的原理

    HTTP状态保持的原理
    a)在用户登录之后,浏览器返回响应的时候会在响应中添加上cookieb)浏览器接收到cookie之后会自动保存c)当用户再次请求同一服务器中的其他网页的时候,浏览器会自动带上之前保存的cookied)服务接收到请求之后可以请 request 对象中取到cookie 判断当前用户是否登录  Http是无状态的,就是连接时数据互通,关闭后...
  • Hive 系统函数及示例

    Hive 系统函数及示例
    查看所有系统函数 show functions; 函数分类 内置函数【系统函数】 数学函数: floor、round、ceil、cos、log2等 字符串函数: length、reverse、trim、lower、get_json_object、repeat等 收集函数: size 转换函数: cast 日期函数: year、month、datediff、date、date_add等 条件函数: coalesce、case…w...
  • CSRF的原理和防范措施

    CSRF的原理和防范措施
    a)攻击原理:i.用户C访问正常网站A时进行登录,浏览器保存A的cookieii.用户C再访问攻击网站B,网站B上有某个隐藏的链接或者图片标签会自动请求网站A的URL地址,例如表单提交,传指定的参数iii.而攻击网站B在访问网站A的时候,浏览器会自动带上网站A的cookieiv.所以网站A在接收到请求之后可判断当前用户是登录状态,所以...
标签列表