Hi,

Can you try url encoding the POST data before sending it? I believe
that will solve the problem.

Thanks,
Dan

On Apr 9, 1:17 pm, Khai <[email protected]> wrote:
> On the browser / javascript side I have:
>
> var params = {};
> params[gadgets.io.RequestParameters.CONTENT_TYPE] =
> gadgets.io.ContentType.JSON;
> params[gadgets.io.RequestParameters.AUTHORIZATION] =
> gadgets.io.AuthorizationType.SIGNED;
> params[gadgets.io.RequestParameters.METHOD] =
> gadgets.io.MethodType.POST;
> params[gadgets.io.RequestParameters.POST_DATA] =
> 'contributor=ag9hc3RvdW5kbGVhcm5pbmdyEQsSCkN1c3RvbVVzZXIY_Q0M&contributor=ag9hc3RvdW5kbGVhcm5pbmdyEQsSCkN1c3RvbVVzZXIYvA0M
> &contributor=ag9hc3RvdW5kbGVhcm5pbmdyEQsSCkN1c3RvbVVzZXIYvw0M&contributor=ag9hc3RvdW5kbGVhcm5pbmdyEQsSCkN1c3RvbVVzZXIYlw4M
> &setKey=ag9hc3RvdW5kbGVhcm5pbmdyDwsSCFN0dWR5U2V0GO0NDA';
>
> var callback = function(){};
> var url = 'http://kdoan.dyndns.org/ajax/adContributor.json';
> gadgets.io.makeRequest(url,callback,params);
>
> On the server (python, GAE), I have:
>
> def _isValidSignature(self):
>             publicKeys = {}
>             publicKeys['www.google.com']  =
> """0x00d0515eee9087c88b16e890738d18c5bdf9e77413d5f89bdf48f2ea4f429de202da88bd6b3b5c26c06c6ab3407d6a5fd634d21ad0e514508fc388ded46242cfca7f319639dbcba48939a17a5d4f9f2d838165621e5f6e1228568567e06bed4a32a6245b2833c351b442472f569677ef9d5f39108c4b0d7015f042f7c36f46276d"""
>             public_key_str = publicKeys[consumerKey]
>             public_key_long = long(public_key_str, 16)
>             public_key = RSA.construct((public_key_long, exponent))
>
>             # Rebuild the message host locally
>             oauth_request = oauth.OAuthRequest(http_method =
> self.request.method,
>                     http_url=self.request.url,
>                     parameters=self.request.params.mixed())
>             message = '&'.join((oauth.escape
> (oauth_request.get_normalized_http_method()),
>                 oauth.escape(oauth_request.get_normalized_http_url()),
>                 oauth.escape(oauth_request.get_normalized_parameters
> ()),))
>             local_hash = hashlib.sha1(message).digest()
>
>             # Apply the public key to the signature from the remote
> host
>             sig = base64.decodestring(urllib.unquote
> (self.request.params.mixed()["oauth_signature"]))
>             remote_hash = public_key.encrypt(sig,'')[0][-20:]
>
>             # Verify that the locally-built value matches the value
> from the remote server.
>             if local_hash == remote_hash:
>                 return True
>             else:
>                 logging.info('Either oauth_consumer_key: ' +
> consumerKey + ' does not exist in publicKeys or the container changed
> its public key' + "\n")
>                 return False
>
> This code is modified 
> fromhttp://wiki.opensocial.org/index.php?title=Building_an_OpenSocial_App...
>
> My POST data is constructed from a form which include multiple
> checkboxes with the same name being 'contributor'.  If I only select
> one checkbox, everything works fine.  If I select multiple checkboxes,
> then my _isValidSignature method return False.  What am I doing wrong?
--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups 
"iGoogle Developer Forum" group.
To post to this group, send email to [email protected]
To unsubscribe from this group, send email to 
[email protected]
For more options, visit this group at 
http://groups.google.com/group/Google-Gadgets-API?hl=en
-~----------~----~----~----~------~----~------~--~---

Reply via email to