I'm trying to access google fusion service by using CURL library from a NDK application this is my code:
jstring Java_com_AnalyticToolC_AnalyticToolActivity_JNISendData( JNIEnv* env,jobject entryObject,jstring webpageJStr,jstring loginHeaderJStr,jstring insertJStr)
{
pageInfo_t page;
CURL *curl;
CURLcode res;
char *buffer;
const jbyte *webpage;
webpage = (*env)->GetStringUTFChars(env, webpageJStr, NULL);
if (webpage == NULL) {
return NULL; /* OutOfMemoryError already thrown */
}
page.data = (char *)malloc(16 * 1024);
page.len = 0;
if (page.data)
memset(page.data, 32, 16 * 1024);
buffer = (char *)malloc(1024);
curl = curl_easy_init();
if(curl) {
curl_easy_setopt(curl, CURLOPT_URL, webpage);
curl_easy_setopt(curl, CURLOPT_WRITEFUNCTION, HTTPData);
curl_easy_setopt(curl, CURLOPT_WRITEDATA, &page);
curl_easy_setopt(curl, CURLOPT_POST, 1);
const jbyte *insert;
insert = (*env)->GetStringUTFChars(env, insertJStr, NULL);
//post field to request
curl_easy_setopt(curl, CURLOPT_POSTFIELDS, insert);
curl_easy_setopt(curl, CURLOPT_POSTFIELDSIZE, sizeof(insert));
struct curl_slist *headers = NULL;
const jbyte *auth;
auth = (*env)->GetStringUTFChars(env, loginHJStr, NULL);
headers = curl_slist_append(headers, auth);
// attach headers to this request
curl_easy_setopt(curl, CURLOPT_HTTPHEADER, headers);
res = curl_easy_perform(curl);
/* always cleanup */
curl_easy_cleanup(curl);
(*env)->ReleaseStringUTFChars(env, webpageJStr, webpage);
if(res == 0) {
if (buffer) {
page.data[page.len < 256 ? page.len : 256] = '\0';
sprintf(buffer, "pagedata(%d): %s. done.\n", page.len, page.data);
return (*env)->NewStringUTF(env, buffer);
}
}
sprintf(buffer, "Result %d", res);
return (*env)->NewStringUTF(env, buffer);
}
else
{
return (*env)->NewStringUTF(env, "Unable to init cURL");
}
}
typedef struct pageInfo_t {
char *data;
int len;
};
static size_t HTTPData(void *buffer, size_t size, size_t nmemb, void *userData) {
int len = size * nmemb;
pageInfo_t *page = (pageInfo_t *)userData;
if (buffer && page->data && (page->len + len < (16 * 1024)) ) {
memcpy(&page->data[page->len], buffer, len);
page->len += len;
}
return len;
}
these are values of strings android application pass to the method
1-webpageJStr="http://www.google.com/fusiontables/api/query"
2-loginHeaderJStr="Authorization: GoogleLogin Auth=dddnjb...."
// I have the token value of my user
3-insertJStr="sql=INSERT INTO 2887732 (App_Name,Device_Model,Execute_Date) VALUES ('test','test','02/02/2011')"
the problem is I always get response string
"Sql paramater can not be empty Error 400"
can anyone help me, what is wrong with my request header or content or may be I have problem with CURL option I'm stuck from 2 day in this.
A few things to try: