Tools om het web vast te leggen en te converteren

Handler met Python

Python API

Omschrijving

Heeft u problemen met het debuggen van uw handler? Probeer de Callback Handler-testtool.

De hier beschreven handler verwerkt callbacks van de GrabzIt-screenshotwebservice. De URL van deze handler wordt doorgegeven aan GrabzIt in de callBackURL parameter van de Save methode. Deze techniek werkt echter alleen als de handler toegankelijk is via de Internet.

De volgende parameters worden als GET-parameters aan de handler doorgegeven.

Als u alle toegang tot de handler wilt blokkeren, behalve GrabzIt, gebruikt u dit beveiligingstechniek.

Voorbeeld

Onthoud dat dit terugbellen niet werkt als uw toepassing zich op localhost bevindt.

Dit voorbeeld laat zien hoe de GrabzIt Python-handler kan worden geïmplementeerd. Dit legt zes parameters vast die eraan zijn doorgegeven vanuit de GrabzIt-service, inclusief de unieke ID van de schermafbeelding die wordt doorgegeven aan de GetResult methode.

Deze methode retourneert vervolgens de screenshot, wat is saved in de resultatenmap. Maar als een null waarde wordt geretourneerd door de GetResult methode geeft dit aan dat er een fout is opgetreden.

import os
import cgi
from GrabzIt import GrabzItClient
from ConfigParser import SafeConfigParser

form = cgi.FieldStorage()

message = form.getvalue("message")
customId = form.getvalue("customid")
id = form.getvalue("id")
filename = form.getvalue("filename")
format = form.getvalue("format")
targeterror = form.getvalue("targeterror")

# Custom id can be used to store user ids or whatever is needed for the later processing of the
# resulting screenshot

grabzIt = GrabzItClient.GrabzItClient("Sign in to view your Application Key", "Sign in to view your Application Secret")%>")
result = grabzIt.GetResult(id)

if result != None:
        # Ensure that the application has the correct rights for this directory.
        fo = open("results" + os.sep + filename, "wb")
        fo.write(result)
        fo.close()
        
print "Status: 200 OK"
print