论坛首页 编程语言技术论坛

在Python3.0中处理web请求7-文件上传(使用cgi.FieldStorage)

浏览 3819 次
精华帖 (0) :: 良好帖 (1) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2009-04-12   最后修改:2009-04-12

 

    winput=env["wsgi.input"]
    params=cgi.FieldStorage(fp=io.StringIO(winput.read(int(env.get("CONTENT_LENGTH","0"))).decode("ISO-8859-1")),environ=env,keep_blank_values=1)
    print(params["file"].name)
    print(params["file"].filename.encode("ISO-8859-1").decode("UTF-8"))
    print(params["file"].value.encode("ISO-8859-1"))
params=cgi.FieldStorage(fp=io.StringIO(winput.read(int(env.get("CONTENT_LENGTH","0"))).decode("ISO-8859-1")),environ=env,keep_blank_values=1)

 这句代码有必要解释一下:

1、不能直接用winput。如果直接使用wsgi.input,readline出来的都是bytes,而在cgi.FieldStorage里判断全部用的是字符串,在bytes隐式转换为str时会自动加b'',导致判断不成功,知道最后一条readline语句,服务器一直等待输入。。

2、必须使用decode对wsgi.input读取的数据进行解码,不能用str(),原因同上

3、FieldStorage解释完成后得到的value是字符串,如果你上传的是图片或者其他二进制数据,就要再将字符串encode成bytes

4、在上面的代码中filename被FieldStorage解释完毕后是被decode成ISO-8859-1编码的字符串,如果存在中文,就必须用encode再decode

总结:

  FieldStorage里的代码好象还是2.x时候的代码,没有考虑到wsgi.input获取到的是bytes的情况。自己处理编码确实很麻烦。哪位仁兄写个增强版的出来请告诉我。

论坛首页 编程语言技术版

跳转论坛:
Global site tag (gtag.js) - Google Analytics