2

我是 Web 开发的新手,我只是将我的第一个 django Web 应用程序拼凑在一起,并使用 mod_wsgi 与 apache 集成。该应用程序有大约 15 个参数,您可以在这些参数上查询多个 SQL 服务器数据库,并且可以将结果下载为 .xls 文件;已经在公司网络上部署了相同的。

问题是当我在一台机器上访问网络应用程序并设置查询参数时,当我尝试从另一台机器(网络客户端)打开它时,在网络应用程序中设置了相同的参数。就像只有一个全局对象被提供给所有 Web 客户端一样。

我正在使用 django 模板标签在应用程序的 html 页面中设置值。

不使用 django 项目中的任何模型,因为我正在查询已经构建的 SQL 服务器数据库。

我的views.py中的查询功能看起来像

def query(self,request):
    """
    """
    print "\n\n\t inside QUERY PAGE:",request.method,"\n\n"

    self.SummaryOfResults_list = []
    if self.vmd_cursor != -1:
        self.vmd_cursor.close()

    if request.method == 'POST':
        QueryPage_post_dic = request.POST
        print "\n\nQueryPage_post_dic   :",QueryPage_post_dic

        self.err_list = []
        self.err_list = db_qry.validate_entry(QueryPage_post_dic)

        if len(self.err_list):
            return HttpResponseRedirect('/error/')
        else:
            channel_numbers,JPEG_Over_HTTP,Codec,format,rate_ctrl,transport,img_sz,BuildInfo_versions, self.numspinner_values_dic = db_qry.process_postdata(QueryPage_post_dic, self.numspinner_values_dic)


            return self.get_result(request,channel_numbers,JPEG_Over_HTTP,Codec,format,rate_ctrl,transport,img_sz,BuildInfo_versions)

    else:
        print "\nself.Cam_Selected_list inside qry  :",self.Cam_Selected_list
        if (len(self.Cam_Selected_list) != 1):
            return HttpResponseRedirect('/error/')

        self.tc_dic,self.chnl_dic,self.enbl_dic,self.frmt_dic,self.cdectyp_dic,self.imgsz_dic,self.rtctrl_dic,self.jpg_ovr_http_dic,self.trnsprt_dic,self.cdec_dic,self.typ_dic,self.resolution_dic, self.vmd_cursor = populate_tbls.Read_RefTbls(self.Cam_Selected_list[0])



        c = self.get_the_choices(self.Cam_Selected_list[0])
        c['camera_type']= self.Cam_Selected_list[0]

        for k,v in self.numspinner_values_dic.items():
            c[k] = v

        self.vmd_cursor.execute("SELECT DISTINCT [GD Build Info] FROM MAIN")
        res_versions = self.vmd_cursor.fetchall()
        version_list = []
        ver_list = ['',' ']
        for version in res_versions:
            tmp_ver = version[0].encode()
            if (tmp_ver not in ver_list):
                version_list.append(tmp_ver)
        c['build_info'] = version_list
        print "\n\n c dic   :",c
        c.update(csrf(request))
        return render_to_response('DBQuery.html',c)

并且传递给 render_to_response 的字典包含设置复选框和多选框(dojo)的值

谢谢

4

2 回答 2

2

就像只有一个全局对象被提供给所有 Web 客户端一样。

你所说的可能正是正在发生的事情。除非您正在self为每个请求重新构建该示例代码中的任何对象,否则它实际上将在客户端之间随机共享。

于 2012-06-18T17:18:43.940 回答
0

您可以将全局变量存储在您正在使用的 SQL DB 中。这样,您可以在请求 -> 响应周期中保留变量的值/状态。

如果您需要更快的响应时间,请探索内存数据存储(如 redis)中的 Key->Value Pair。

要添加 AKX 提到的内容,我建议您阅读 HTTP 请求 -> HTTP 响应周期和 Web 应用程序的工作原理。

于 2012-06-18T18:00:53.157 回答