返回用户指定页面的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()

  

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

目录
相关文章
|
6天前
|
UED
判断iframe链接页面 服务器状态
判断iframe链接页面 服务器状态
99 58
|
21天前
|
存储
在 Web 中判断页面是不是刷新
【9月更文挑战第10天】在Web开发中,判断页面是否刷新有多种方法:1) 监听`popstate`事件,检测用户是否通过历史记录访问页面;2) 记录并比较页面加载时间戳,若相差极小,则可能为刷新;3) 利用本地存储设置特定值,若该值不存在或不符合预期,则页面可能被刷新。然而,这些方法并非绝对准确。
html,web页面朗读文字,朗读中文,朗读英文
html,web页面朗读文字,朗读中文,朗读英文
|
19天前
|
数据处理 Python
Django视图:构建动态Web页面的核心技术
Django视图:构建动态Web页面的核心技术
|
2月前
|
API C# 开发框架
WPF与Web服务集成大揭秘:手把手教你调用RESTful API,客户端与服务器端优劣对比全解析!
【8月更文挑战第31天】在现代软件开发中,WPF 和 Web 服务各具特色。WPF 以其出色的界面展示能力受到欢迎,而 Web 服务则凭借跨平台和易维护性在互联网应用中占有一席之地。本文探讨了 WPF 如何通过 HttpClient 类调用 RESTful API,并展示了基于 ASP.NET Core 的 Web 服务如何实现同样的功能。通过对比分析,揭示了两者各自的优缺点:WPF 客户端直接处理数据,减轻服务器负担,但需处理网络异常;Web 服务则能利用服务器端功能如缓存和权限验证,但可能增加服务器负载。希望本文能帮助开发者根据具体需求选择合适的技术方案。
67 0
|
2月前
|
Rust 安全 开发者
惊爆!Xamarin 携手机器学习,开启智能应用新纪元,个性化体验与跨平台优势完美融合大揭秘!
【8月更文挑战第31天】随着互联网的发展,Web应用对性能和安全性要求不断提高。Rust凭借卓越的性能、内存安全及丰富生态,成为构建高性能Web服务器的理想选择。本文通过一个简单示例,展示如何使用Rust和Actix-web框架搭建基本Web服务器,从创建项目到运行服务器全程指导,帮助读者领略Rust在Web后端开发中的强大能力。通过实践,读者可以体验到Rust在性能和安全性方面的优势,以及其在Web开发领域的巨大潜力。
34 0
|
2月前
|
Java 数据库 API
JSF与JPA的史诗级联盟:如何编织数据持久化的华丽织锦,重塑Web应用的荣耀
【8月更文挑战第31天】JavaServer Faces (JSF) 和 Java Persistence API (JPA) 分别是构建Java Web应用的用户界面组件框架和持久化标准。结合使用JSF与JPA,能够打造强大的数据驱动Web应用。首先,通过定义实体类(如`User`)和配置`persistence.xml`来设置JPA环境。然后,在JSF中利用Managed Bean(如`UserBean`)管理业务逻辑,通过`EntityManager`执行数据持久化操作。
38 0
|
20天前
|
数据可视化 图形学 UED
只需四步,轻松开发三维模型Web应用
为了让用户更方便地应用三维模型,阿里云DataV提供了一套完整的三维模型Web模型开发方案,包括三维模型托管、应用开发、交互开发、应用分发等完整功能。只需69.3元/年,就能体验三维模型Web应用开发功能!
41 8
只需四步,轻松开发三维模型Web应用
|
10天前
|
安全 API 开发者
Web 开发新风尚!Python RESTful API 设计与实现,让你的接口更懂开发者心!
在当前的Web开发中,Python因能构建高效简洁的RESTful API而备受青睐,大大提升了开发效率和用户体验。本文将介绍RESTful API的基本原则及其在Python中的实现方法。以Flask为例,演示了如何通过不同的HTTP方法(如GET、POST、PUT、DELETE)来创建、读取、更新和删除用户信息。此示例还包括了基本的路由设置及操作,为开发者提供了清晰的API交互指南。
44 6
下一篇
无影云桌面