3

私は2つのWebアプリケーションを持っています:parent_appとsub_app

たとえば、http://www.some.com/parent.pngはparent_appによって処理されます。

別のウェブサイトで参照されている場合、parent_appはHTTP_REFERERを取得します。たとえば、http : //www.other.com/path?query=valueです。

sub_appがこのHTTP_REFERERのパスとquery_stringを自分のパスとquery_stringとして受け取り、結果をparent_appに返すようにしたいので、parent_appのURLは変更されず、訪問者のブラウザーも303ジャンプを取得しません。

sub.py:

import web
class Sub(object):
    def GET(self):
        return web.input().query             # I want it to be 'value', from "query=value"
urls = (r'/path', 'Sub')
sub_app = web.application(urls, locals())

parent.py:

import web
from sub import sub_app
class Parent(object):
    def GET(self):
        return sub_app.request('/path?query=value').data  #=========(1)
urls = (
    r'/parent.png', 'Parent',
    r'', sub_app
    )
parent_app = web.application(urls, locals())

実行します:

>>>python parent.py

'http://www.some.com/parent.png'にアクセスすると?

これらのエラーが発生します:

Traceback (most recent call last):
  File "/home/netroyal/Documents/program/studame/web/wsgiserver/__init__.py", line 1245, in communicate
    req.respond()
  File "/home/netroyal/Documents/program/studame/web/wsgiserver/__init__.py", line 775, in respond
    self.server.gateway(self).respond()
  File "/home/netroyal/Documents/program/studame/web/wsgiserver/__init__.py", line 2018, in respond
    response = self.req.server.wsgi_app(self.env, self.start_response)
  File "/home/netroyal/Documents/program/studame/web/httpserver.py", line 306, in __call__
    return self.app(environ, xstart_response)
  File "/home/netroyal/Documents/program/studame/web/httpserver.py", line 274, in __call__
    return self.app(environ, start_response)
  File "/home/netroyal/Documents/program/studame/web/application.py", line 279, in wsgi
    result = self.handle_with_processors()
  File "/home/netroyal/Documents/program/studame/web/application.py", line 249, in handle_with_processors
    return process(self.processors)
  File "/home/netroyal/Documents/program/studame/web/application.py", line 246, in process
    raise self.internalerror()
  File "/home/netroyal/Documents/program/studame/web/application.py", line 473, in internalerror
    parent = self.get_parent_app()
  File "/home/netroyal/Documents/program/studame/web/application.py", line 458, in get_parent_app
    if self in web.ctx.app_stack:
AttributeError: 'ThreadedDict' object has no attribute 'app_stack'

/ home / netroyal / Documents / program / studame /web/はweb.pyパッケージパスです。

では、どうすれば(1)を正しく実行できますか?

(1)シェルで実行するのと同じ結果を取得したい:

>>> import web
>>> class Sub(object):
...     def GET(self):
...         return web.input().query
>>> urls = ('/path', 'Sub')
>>> sub_app = web.application(urls, locals())
>>> sub_app.request('/path?query=value').data             #=========(1)'
'value'
>>> 

私は知っています、私は使うことができます

web.seeother('/path?query=value') 

訪問者に結果を見せるためですが、ブラウザが別のURLにジャンプすることは望ましくありません。

おもう

urllib2.urlopen('http://www.some.com/path?query=value') 

動作しますが、単一のリクエストでそれを行うためのより良い方法はありますか?

助けてくれてありがとう!-----これを読んでくれてありがとう! ==========================================編集======= ===============================

OK、コードをハッキングした後、問題の一部を解決しました。

Simulation.pyを追加します。

import web, re
class Simulation(object):
    def __init__(self, urls, fvars):
        self._urls = urls
        self._fvars = fvars
    def request(self, localpart='/', method='GET', data=None, host='0.0.0.0:8080', headers=None, https=False):   
        #nnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnnn    
        # get path and args(parameters from new url)
        try:
            path, query = localpart.split('?', 1)
        except:
            path, query = (localpart, '')
        # get all arguments: args(parameters)
        parts = query.split('&')
        args = {}
        for part in parts:
            try:
                name, value = part.split('=')
            except:
                pass
            else:
                args[name] = value
        #uuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuuu
        patterns = [self._urls[2*i] for i in range(0, len(self._urls)/2)]
        for i in range(0, len(patterns)):
            result = re.match(patterns[i], path)
            if result:
                web.input = lambda: web.storage(args)
                Worker = self._fvars[self._urls[2*i + 1]]
                return Worker().GET(*result.groups())
        #----------------------------------------------------------------------------------------
        raise web.notfound()

および sub.py:

from simulation import *
class Sub(object):
    def GET(self):
        return web.input().query             # I want it to be 'value', from "query=value"
urls = (r'/path', 'Sub')
sub_app = web.application(urls, locals())
sub_sim = Simulation(urls, locals())         # new class to run request in parent_app

parent.pyのadn

import web
from sub import sub_app, sub_sim               #sub_sim is new
class Parent(object):
    def GET(self):
        return sub_sim.request('/path?query=value')  # sub_app changed to sub_sim, and no (.data)
urls = (
    r'/parent.png', 'Parent',
    r'', sub_app
    )
parent_app = web.application(urls, locals())

また、「/ sub」を使用してsub_appにアクセスし、スタンドアロンアプリケーションのままにすることもできます。

私は自分の問題を完全には解決しませんでしたが、ある種の困難を解決しました。私はそれを使うだけだと思います。時間があれば、別の方法を見つけます。より良い解決策があれば教えてください、ありがとう。

よろしくお願いします。

=========================================私は自分自身に話しかけているような気がします人はどこにいますか?

4

0 に答える 0