如何进行FaultWrapper解析

这篇文章将为大家详细讲解有关如何进行FaultWrapper解析,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

成都创新互联服务项目包括阿尔山网站建设、阿尔山网站制作、阿尔山网页制作以及阿尔山网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,阿尔山网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到阿尔山省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!

FaultWrapper解析

class FaultWrapper(base_wsgi.Middleware):#继承基础的WSGI中间件"""调用中间件堆栈,将exceptions封装成faults。"""    _status_to_type = {}@staticmethod    def status_to_type(status):
        #根据状态码转换成webob相应的类型实例if not FaultWrapper._status_to_type:for clazz in utils.walk_class_hierarchy(webob.exc.HTTPError):# 遍历HTTPError类层次结构 
                FaultWrapper._status_to_type[clazz.code] = clazzreturn FaultWrapper._status_to_type.get(
                                  status, webob.exc.HTTPInternalServerError)()def _error(self, inner, req):
        LOG.exception(_LE("Caught error: %s"), inner)

        safe = getattr(inner, 'safe', False)
        headers = getattr(inner, 'headers', None)
        status = getattr(inner, 'code', 500)if status is None:
            status = 500        msg_dict = dict(url=req.url, status=status)
        LOG.info(_LI("%(url)s returned with HTTP %(status)d"), msg_dict)
        outer = self.status_to_type(status)#调用exception转换方法if headers:
            outer.headers = headers# NOTE(johannes): We leave the explanation empty here on        # purpose. It could possibly have sensitive information        # that should not be returned back to the user. See        # bugs 868360 and 874472        # NOTE(eglynn): However, it would be over-conservative and        # inconsistent with the EC2 API to hide every exception,        # including those that are safe to expose, see bug 1021373        if safe:
            #处理翻译
            user_locale = req.best_match_language()
            inner_msg = translate(inner.message, user_locale)
            outer.explanation = '%s: %s' % (inner.__class__.__name__,
                                            inner_msg)

        notifications.send_api_fault(req.url, status, inner)#调用rpc发送api错误到消息队列return wsgi.Fault(outer) #返回webob.exc.HTTPException错误对象

    @webob.dec.wsgify(RequestClass=wsgi.Request)def __call__(self, req):try:return req.get_response(self.application) #执行wsgi应用程序except Exception as ex:return self._error(ex, req)#遇到exception后,调用此方法处理exception,封装成http错误返回

关于如何进行FaultWrapper解析就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。


文章标题:如何进行FaultWrapper解析
路径分享:http://csdahua.cn/article/psihch.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流