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

简介: import socketimport reimport osdef handle_client(socket_con): """ 接收来自客户端的请求,并接收请求报文,解析,返回 """ # 1、服务器接收客户端的请求报文 request = socket_con.
import socket
import re
import os

def handle_client(socket_con):
    """
     接收来自客户端的请求,并接收请求报文,解析,返回
    """
    # 1、服务器接收客户端的请求报文
    request = socket_con.recv(4096).decode()
    # 以行切割请求报文为列表
    res = request.split('\r\n')
    # 取第一位(请求行):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\r\n'
        response_head = 'Content-Type:text/html;charset=utf-8\r\n'
        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 + '\r\n' + response_body
        socket_con.send(response.encode())
        socket_con.close()
    # 路径大于一并取出之后判断资源是否存在
    if not os.path.exists(path):
        # 资源不存在则显示资源不存在界面
        response_line = 'HTTP/1.1 404 NOT FOUND\r\n'
        response_head = 'Content-Type:text/html;charset=utf-8\r\n'
        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 + '\r\n' + response_body
        socket_con.send(response.encode())
        socket_con.close()
        return
    else:
        # 资源存在以后判断是否是文件,是文件则直接读取
        if os.path.isfile(path):
            response_line = 'HTTP/1.1 200 OK\r\n'
            response_head = 'Server:skylark 2.0\r\n'
            response_head += 'Content-Type:*/*;charset:utf-8\r\n'
            f = open(path, 'rb')
            response_body = f.read()
            response = response_line.encode() + response_head.encode() + '\r\n'.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\r\n'
                         response_head = 'Server:skylark 2.0\r\n'
                         response_head += 'Content-Type:*/*;charset:utf-8\r\n'
                         f = open(path + 'index.html', 'rb')
                         response_body = f.read()
                         response = response_line.encode() + response_head.encode() + '\r\n'.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\r\n'
                         response_head = 'Server:skylark 2.0\r\n'
                         response_head += 'Content-Type:*/*;charset:utf-8\r\n'
                         f = open(path + 'default.html', 'rb')
                         response_body = f.read()
                         response = response_line.encode() + response_head.encode() + '\r\n'.encode() + response_body
                         socket_con.send(response)
                         socket_con.close()
                         return
                     else:
                         # 如果没有上述两个页面,则可以返回404错误,或者302重定向
                         response_line = "HTTP/1.1 404 Not Found\r\n"
                         response_head = "Server:skylark 2.0\r\n"
                         response_body = "index.html or default.html is not exist!!!"
                         response = response_line + response_head + "\r\n" + 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\r\n'
                         response_head = 'Server:skylark 2.0\r\n'
                         # 动态的拼接页面,将目录中的文件或者文件夹的名称以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 + "\r\n" + response_body
                         socket_con.send(response.encode())
                         socket_con.close()
                         return
            else:
                # 用户请求的路径没有斜线
                # 重定向到+斜线的目录下,并显示重定向以后的路径(此处可以增加有斜线目录处理方式也就是上面的方法)
                response_line = 'HTTP/1.1 302 Found\r\n'
                response_head = 'Server:skylark 2.0\r\n'
                response_head += 'Content-Type:text/html;charset=utf-8\r\n'
                response_body = '重定向' + path + '/'
                response = response_line + response_head + '\r\n' + 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()

  

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

目录
相关文章
|
1月前
|
消息中间件 监控
RabbitMQ的Web管理页面
RabbitMQ的Web管理页面
21 0
|
1月前
|
存储 缓存 网络协议
Web客户/服务器程序
Web客户/服务器程序
|
5天前
|
缓存 负载均衡 安全
深入探索Nginx高性能Web服务器配置与优化
【5月更文挑战第7天】本文深入探讨了Nginx的配置与优化,重点介绍了基础配置参数如`worker_processes`、`worker_connections`和`keepalive_timeout`,以及优化策略,包括使用epoll事件驱动模型、开启gzip压缩、启用缓存、负载均衡和安全配置。此外,还提到了性能调优工具,如ab、nginx-stats和nmon,以助于提升Nginx的性能和稳定性。
|
12天前
|
机器学习/深度学习 前端开发 数据可视化
数据分析web可视化神器---streamlit框架,无需懂前端也能搭建出精美的web网站页面
数据分析web可视化神器---streamlit框架,无需懂前端也能搭建出精美的web网站页面
|
14天前
|
中间件 Go API
Golang深入浅出之-Go语言标准库net/http:构建Web服务器
【4月更文挑战第25天】Go语言的`net/http`包是构建高性能Web服务器的核心,提供创建服务器和发起请求的功能。本文讨论了使用中的常见问题和解决方案,包括:使用第三方路由库改进路由设计、引入中间件处理通用逻辑、设置合适的超时和连接管理以防止资源泄露。通过基础服务器和中间件的代码示例,展示了如何有效运用`net/http`包。掌握这些最佳实践,有助于开发出高效、易维护的Web服务。
28 1
|
16天前
|
机器学习/深度学习 数据挖掘 Python
使用Python实现简单的Web服务器
使用Python内置的http.server模块,本文演示了创建基本Web服务器的步骤。通过编写简单的代码,实现响应GET请求并返回“Hello, World!”。此外,还展示了如何扩展服务器功能,处理不同URL路径,如根路径和/about路径,并实现404错误页面。这个基础教程为理解HTTP服务器原理和Python网络编程入门提供了帮助。对于复杂Web应用,建议使用Flask或Django等高级框架。
|
17天前
|
数据采集 资源调度 前端开发
React的服务器端渲染:使用ReactDOMServer进行高效页面预渲染
【4月更文挑战第25天】使用ReactDOMServer,React支持服务器端渲染以实现高效预渲染。通过在Node.js环境中将React组件转化为HTML字符串,减少客户端JavaScript负载和渲染时间。优点包括更快首屏加载、改善SEO和兼容无JavaScript环境,但也会增加服务器负载、复杂性和状态管理挑战。开发者需根据项目需求平衡SSR和CSR。
|
17天前
|
负载均衡 监控 Unix
[AIGC] Nginx:一个高性能的 Web 服务器和反向代理
[AIGC] Nginx:一个高性能的 Web 服务器和反向代理
|
23天前
|
Apache
web服务器(Apache)访问日志(access_log)详细解释
web服务器(Apache)访问日志(access_log)详细解释
|
27天前
|
开发框架 安全 搜索推荐
如何使用Python Flask发布web页面至公网并实现远程访问【内网穿透】
如何使用Python Flask发布web页面至公网并实现远程访问【内网穿透】