1

在 web2by 构建的缩短器中,我想首先验证 url,如果它无效返回到第一页并显示错误消息。这是我在控制器(mvc 架构)中的代码,但我不明白出了什么问题..!!

import urllib

def index():
    return dict()

def random_maker():
    url = request.vars.url
    try:
        urllib.urlopen(url)
        return dict(rand_url = ''.join(random.choice(string.ascii_uppercase +
                    string.digits + string.ascii_lowercase) for x in range(6)),
                    input_url=url)
    except IOError:
        return index()
4

1 回答 1

1

您不能使用 httplib 检查 http 响应代码吗?如果它是 200,那么页面是有效的,如果它是其他任何东西(如 404)或错误,那么它是无效的。

请参阅此问题:从 URL 获取 HTTP 响应代码的最佳方法是什么?

更新:

根据您的评论,您的问题似乎是您如何处理错误。您只处理 IOError 问题。在您的情况下,您可以通过切换到以下方式单独处理所有错误:

except:
    return index()

您还可以通过覆盖 http_default_error 来构建自己的异常处理程序。有关详细信息,请参阅如何在 urllib.urlretrieve 中捕获 404 错误

或者您可以切换到具有特定错误的 urllib2,然后您可以处理 urllib2 抛出的特定错误,如下所示:

from urllib2 import Request, urlopen, URLError
req = Request('http://jfvbhsjdfvbs.com')
try:
    response = urlopen(req)
except URLError, e:
    if hasattr(e, 'reason'):
        print 'We failed to reach a server.'
        print 'Reason: ', e.reason
    elif hasattr(e, 'code'):
        print 'The server couldn\'t fulfill the request.'
        print 'Error code: ', e.code
else:
    print 'URL is good!'

上面的代码将返回:

We failed to reach a server.
Reason:  [Errno 61] Connection refused

每个异常类的细节都包含在 urllib.error api 文档中。

我不确定如何将其插入您的代码中,因为我不确定您到底要做什么,但 IOError 不会处理 urllib 抛出的异常。

于 2012-08-15T18:27:22.590 回答