The POST data is already url encoded.

Thanks
Khai

On Thu, Apr 9, 2009 at 4:28 PM, Dan (Google) <[email protected]> wrote:
>
> 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