【从零学习python 】91. 使用装饰器和字典管理请求路径的简洁Web应用

简介: 【从零学习python 】91. 使用装饰器和字典管理请求路径的简洁Web应用

导入必要的模块

from wsgiref.simple_server import make_server
from utils import load_html, load_template

这两行代码首先导入了make_server函数和自定义的load_htmlload_template函数,以便后续使用。

创建路由字典

g_url_route = {}

定义了一个全局变量g_url_route作为路由字典,用于保存请求路径和处理函数之间的对应关系。

装饰器函数route

def route(url):
    def handle_action(action):
        g_url_route[url] = action
        def do_action(start_response):
            return action(start_response)
        return do_action
    return handle_action

route是一个装饰器函数,在定义路由时使用。它接受一个url参数,并返回一个内部函数handle_action。在内部函数中,它将请求路径url与处理函数action进行关联,并定义了一个新的函数do_action,该函数接受start_response参数并执行action函数。最后返回do_action函数。

路由定义及处理函数

@route('/index.html')
@route('/')
def show_home(start_response):
    return load_html('/index.html', start_response)

这是一个示例,使用route装饰器定义了两个路由:/index.html/,并将它们分别与show_home函数关联起来。当请求路径匹配到这两个路由之一时,将执行show_home函数。

@route('/test.html')
def show_test(start_response):
    start_response('200 OK', [('Content-Type', 'text/html;charset=utf-8')])
    return ['我是一段普通的文字'.encode('utf-8')]

这是另一个示例,使用route装饰器定义了一个路由/test.html,并将其与show_test函数关联起来。当请求路径匹配到该路由时,将执行show_test函数。该函数设置了响应头信息,并返回一段普通的文字作为响应内容。

@route('/info.html')
def show_info(start_response):
    return load_template('/info.html', start_response, name='张三', age=18)

同样使用route装饰器定义了一个路由/info.html,并将其与show_info函数关联起来。当请求路径匹配到该路由时,将执行show_info函数。该函数使用load_template函数加载/info.html模板,并传入nameage参数进行渲染。

请求处理函数application

def application(environ, start_response):
    file_name = environ.get('PATH_INFO')
    try:
        return g_url_route[file_name](start_response)
    except Exception:
        start_response('404 NOT FOUND', [('Content-Type', 'text/html;charset=utf-8')])
        return ['对不起,界面未找到'.encode('utf-8')]

application函数是WSGI应用程序的入口点。它接受environstart_response两个参数,用于处理HTTP请求。首先,获取请求路径file_name。然后,尝试从路由字典中找到匹配的处理函数,并执行该函数。如果找不到对应的处理函数,则返回404状态码及相应的错误信息。

服务器启动并监听

if __name__ == '__main__':
    httpd = make_server('', 8000, application)
    print("Serving HTTP on port 8000...")
    httpd.serve_forever()

这部分代码用于启动服务器并监听指定端口(8000)。当程序被直接运行时(而不是作为模块导入),将创建一个WSGI服务器并调用application函数来处理请求。同时打印提示信息表示服务器正在运行,并通过httpd.serve_forever()实现持续监听。

完整代码

from wsgiref.simple_server import make_server
from utils import load_html, load_template
g_url_route = {}
def route(url):
    def handle_action(action):
        g_url_route[url] = action
        def do_action(start_response):
            return action(start_response)
        return do_action
    return handle_action
@route('/index.html')
@route('/')
def show_home(start_response):
    return load_html('/index.html', start_response)
@route('/test.html')
def show_test(start_response):
    start_response('200 OK', [('Content-Type', "text/html;charset=utf-8")])
    return ['我是一段普通的文字'.encode('utf-8')]
@route('/info.html')
def show_info(start_response):
    return load_template('/info.html', start_response, name='张三', age=18)
def application(environ, start_response):
    file_name = environ.get('PATH_INFO')
    try:
        return g_url_route[file_name](start_response)
    except Exception:
        start_response('404 NOT FOUND', [('Content-Type', 'text/html;charset=utf-8')])
        return ['对不起,界面未找到'.encode('utf-8')]
if __name__ == '__main__':
    httpd = make_server('', 8000, application)
    print("Serving HTTP on port 8000...")
    httpd.serve_forever()

相关文章
|
1天前
|
设计模式 存储 前端开发
18:JavaBean简介及其在表单处理与DAO设计模式中的应用-Java Web
18:JavaBean简介及其在表单处理与DAO设计模式中的应用-Java Web
12 4
|
1天前
|
存储 前端开发 安全
13:会话跟踪技术Session的深度应用与实践-Java Web
13:会话跟踪技术Session的深度应用与实践-Java Web
12 3
|
1天前
|
存储 前端开发 搜索推荐
12:会话跟踪技术Cookie的深度应用与实践-Java Web
12:会话跟踪技术Cookie的深度应用与实践-Java Web
12 4
|
1天前
|
XML 存储 Java
11:Servlet中初始化参数的获取与应用-Java Web
11:Servlet中初始化参数的获取与应用-Java Web
13 3
|
3天前
|
缓存 移动开发 前端开发
【专栏:HTML与CSS前端技术趋势篇】HTML与CSS在PWA(Progressive Web Apps)中的应用
【4月更文挑战第30天】PWA(Progressive Web Apps)结合现代Web技术,提供接近原生应用的体验。HTML在PWA中构建页面结构和内容,响应式设计、语义化标签、Manifest文件和离线页面的创建都离不开HTML。CSS则用于定制主题样式、实现动画效果、响应式布局和管理字体图标。两者协同工作,保证PWA在不同设备和网络环境下的快速、可靠和一致性体验。随着前端技术进步,HTML与CSS在PWA中的应用将更广泛。
|
3天前
|
前端开发 JavaScript 搜索推荐
【专栏:HTML 与 CSS 前端技术趋势篇】HTML 与 CSS 在 Web 组件化中的应用
【4月更文挑战第30天】本文探讨了HTML和CSS在Web组件化中的应用及其在前端趋势中的重要性。组件化提高了代码复用、维护性和扩展性。HTML提供组件结构,语义化标签增进可读性,支持用户交互;CSS实现样式封装、布局控制和主题定制。案例展示了导航栏、卡片和模态框组件的创建。响应式设计、动态样式、CSS预处理器和Web组件标准等趋势影响HTML/CSS在组件化中的应用。面对兼容性、代码复杂度和性能优化挑战,需采取相应策略。未来,持续发掘HTML和CSS潜力,推动组件化开发创新,提升Web应用体验。
|
3天前
|
缓存 前端开发 JavaScript
探索现代Web应用的性能优化策略移动应用开发的未来之路:跨平台与原生之争
【4月更文挑战第30天】随着互联网技术的迅猛发展,Web应用已成为信息交流和商业活动的重要平台。用户对Web应用的响应速度和稳定性有着极高的期望,这促使开发者不断寻求提升应用性能的有效途径。本文将深入探讨针对现代Web应用进行性能优化的关键策略,包括前端优化、后端优化以及数据库层面的调优技巧,旨在为开发者提供一套全面的优化工具箱,帮助他们构建更快速、更高效的Web应用。
|
3天前
|
机器学习/深度学习 数据采集 算法
【Python 机器学习专栏】机器学习在医疗诊断中的前沿应用
【4月更文挑战第30天】本文探讨了机器学习在医疗诊断中的应用,强调其在处理复杂疾病和大量数据时的重要性。神经网络、决策树和支持向量机等方法用于医学影像诊断、疾病预测和基因数据分析。Python作为常用工具,简化了模型构建和数据分析。然而,数据质量、模型解释性和伦理法律问题构成挑战,需通过数据验证、可解释性研究及建立规范来应对。未来,机器学习将更深入地影响医疗诊断,带来智能和精准的诊断工具,同时也需跨学科合作推动其健康发展。
|
3天前
|
机器学习/深度学习 自然语言处理 搜索推荐
【Python机器学习专栏】迁移学习在机器学习中的应用
【4月更文挑战第30天】迁移学习是利用已有知识解决新问题的机器学习方法,尤其在数据稀缺或资源有限时展现优势。本文介绍了迁移学习的基本概念,包括源域和目标域,并探讨了其在图像识别、自然语言处理和推荐系统的应用。在Python中,可使用Keras或TensorFlow实现迁移学习,如示例所示,通过预训练的VGG16模型进行图像识别。迁移学习提高了学习效率和性能,随着技术发展,其应用前景广阔。
|
3天前
|
机器学习/深度学习 传感器 自动驾驶
【Python机器学习专栏】深度学习在自动驾驶中的应用
【4月更文挑战第30天】本文探讨了深度学习在自动驾驶汽车中的应用及其对技术发展的推动。深度学习通过模拟神经网络处理数据,用于环境感知、决策规划和控制执行。在环境感知中,深度学习识别图像和雷达数据;在决策规划上,学习人类驾驶行为;在控制执行上,实现精确的车辆控制。尽管面临数据需求、可解释性和实时性挑战,但通过数据增强、规则集成和硬件加速等方法,深度学习将持续优化自动驾驶性能,并在安全性和可解释性上取得进步。