благодаря Паукообразному насекомому для ответа - это работало, как предложено
, вот упрощенная копия кода, в случае, если полезно следующему человеку, который попробует!
import os
import urllib
import urllib2
import cookielib
users_email_address = "billy.bob@gmail.com"
users_password = "billybobspassword"
target_authenticated_google_app_engine_uri = 'http://mylovelyapp.appspot.com/mylovelypage'
my_app_name = "yay-1.0"
# we use a cookie to authenticate with Google App Engine
# by registering a cookie handler here, this will automatically store the
# cookie returned when we use urllib2 to open http://currentcost.appspot.com/_ah/login
cookiejar = cookielib.LWPCookieJar()
opener = urllib2.build_opener(urllib2.HTTPCookieProcessor(cookiejar))
urllib2.install_opener(opener)
#
# get an AuthToken from Google accounts
#
auth_uri = 'https://www.google.com/accounts/ClientLogin'
authreq_data = urllib.urlencode({ "Email": users_email_address,
"Passwd": users_password,
"service": "ah",
"source": my_app_name,
"accountType": "HOSTED_OR_GOOGLE" })
auth_req = urllib2.Request(auth_uri, data=authreq_data)
auth_resp = urllib2.urlopen(auth_req)
auth_resp_body = auth_resp.read()
# auth response includes several fields - we're interested in
# the bit after Auth=
auth_resp_dict = dict(x.split("=")
for x in auth_resp_body.split("\n") if x)
authtoken = auth_resp_dict["Auth"]
#
# get a cookie
#
# the call to request a cookie will also automatically redirect us to the page
# that we want to go to
# the cookie jar will automatically provide the cookie when we reach the
# redirected location
# this is where I actually want to go to
serv_uri = target_authenticated_google_app_engine_uri
serv_args = {}
serv_args['continue'] = serv_uri
serv_args['auth'] = authtoken
full_serv_uri = "http://mylovelyapp.appspot.com/_ah/login?%s" % (urllib.urlencode(serv_args))
serv_req = urllib2.Request(full_serv_uri)
serv_resp = urllib2.urlopen(serv_req)
serv_resp_body = serv_resp.read()
# serv_resp_body should contain the contents of the
# target_authenticated_google_app_engine_uri page - as we will have been
# redirected to that page automatically
#
# to prove this, I'm just gonna print it out
print serv_resp_body
сначала, извините за мой плохой английский
весной, если имя параметра будет похоже на object [0] [field], они будут рассматривать его как тип класса, подобный sub
public class Test {
private List<Map> field;
/**
* @return the field
*/
public List<Map> getField() {
return field;
}
/**
* @param field the field to set
*/
public void setField(List<Map> field) {
this.field = field;
}
}
, поэтому пружина сгенерирует исключение, сказавшее что-то «не является ни массивом, ни списком, ни картой».
только когда имя параметра равно object [0] .field, spring будет обрабатывать его как поле класса.
вы можете найти константы def в org.springframework.beans.PropertyAccessor
, поэтому мое решение - написать новый плагин param для jquery, как показано ниже:
(function($) {
// copy from jquery.js
var r20 = /%20/g,
rbracket = /\[\]$/;
$.extend({
customParam: function( a ) {
var s = [],
add = function( key, value ) {
// If value is a function, invoke it and return its value
value = jQuery.isFunction( value ) ? value() : value;
s[ s.length ] = encodeURIComponent( key ) + "=" + encodeURIComponent( value );
};
// If an array was passed in, assume that it is an array of form elements.
if ( jQuery.isArray( a ) || ( a.jquery && !jQuery.isPlainObject( a ) ) ) {
// Serialize the form elements
jQuery.each( a, function() {
add( this.name, this.value );
});
} else {
for ( var prefix in a ) {
buildParams( prefix, a[ prefix ], add );
}
}
// Return the resulting serialization
return s.join( "&" ).replace( r20, "+" );
}
});
/* private method*/
function buildParams( prefix, obj, add ) {
if ( jQuery.isArray( obj ) ) {
// Serialize array item.
jQuery.each( obj, function( i, v ) {
if (rbracket.test( prefix ) ) {
// Treat each array item as a scalar.
add( prefix, v );
} else {
buildParams( prefix + "[" + ( typeof v === "object" || jQuery.isArray(v) ? i : "" ) + "]", v, add );
}
});
} else if (obj != null && typeof obj === "object" ) {
// Serialize object item.
for ( var name in obj ) {
buildParams( prefix + "." + name, obj[ name ], add );
}
} else {
// Serialize scalar item.
add( prefix, obj );
}
};
})(jQuery);
, я просто измените код с
buildParams( prefix + "[" + name + "]", obj[ name ], traditional, add );
на
buildParams( prefix + "." + name, obj[ name ], add );
и используйте $ .customParam вместо $ .param при выполнении запроса ajax.