Проверка подлинности таблицы Fusion теряется при записи специального символа в поле таблицы
Я очень новичок в скриптах приложений Google и таблицах Fusion. Я разрабатываю приложение CRM для своей компании, и для этого я использую сайты Google, сценарии приложений Google и таблицу fusion. Я также использую пример из книги "Google Script - Основы корпоративных приложений" от O'Reilly для создания своего приложения. Я использую таблицу Fusion в качестве базы данных для своего проекта, и я запускаю функцию doOAuth(), чтобы дать разрешение всем выполнять действия над таблицей Fusion (см. Код ниже, содержащий код doOAuth, полученный мной из книги). Приложение отлично работает для каждой команды, которую я делаю для таблицы Fusion. Я могу читать содержимое таблицы, я также могу выполнить поиск по ней, но когда дело доходит до записи новых данных или обновления существующих данных в таблице, я сталкиваюсь с досадной проблемой. У меня есть несколько текстовых полей в моем приложении, в которые я вставляю некоторые данные, и эти данные записываются в таблицу, пока проблем нет, когда я добавляю общий текст в эти текстовые поля, у меня нет проблем при обновлении данных или вставке данных в таблицу Fusion., Но когда я добавляю в эти текстовые поля какие-либо специальные символы, например: á,ã,à,ä,é,õ,í и т. Д., Я получаю сообщение о том, что для выполнения этого процесса необходима авторизация. Но я уже дал разрешение. Похоже, авторизация потеряна. И даже если я снова запускаю функцию doOAuth(), разрешение не дается. Функции insertFusionObj() и writeFusionObj() (перечисленные в приведенном ниже коде), похоже, имеют проблему, когда их параметры являются специальными символами. Я не знаю, является ли это проблемой из-за функций или это проблема вставки и обновления таблицы слияния. Я был бы очень признателен, если бы кто-то мог помочь мне в этой проблеме, потому что мое приложение предназначено для использования на португальском языке, который имеет некоторые специальные символы, и когда лицо, ответственное за добавление информации в приложение, использует его, он, вероятно, будет использовать специальные символы на вставка и обновление таблицы слияния.
Я с нетерпением жду некоторой помощи. С наилучшими пожеланиями Рафаэль Сетти Ногейра
Код:
/**
* ---FusionService---
*
* Copyright (c) 2011 James Ferreira
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
/**
* FusionService
* @author James Ferreira
* @documentation http://goo.gl/pBSvF
*
* @requires Script Insert ID: ?????
* ObjService http://goo.gl/JdEHW
*
* @requires The Fusion Table ID MUST be set in a Script property.
* This will allow you to change it at anytime using
* ScriptProperties.setProperty('FUSION_ID', '<your ID>');
*
*
* Search for records in a Fusion Table
*
* @params {string} target Quoted column name(s) ('First Name', 'Last Name') OR (*) for all
* @params {string} where valid statement see http://goo.gl/SkHI1
* 'Last Name' CONTAINS IGNORING CASE 'Ferr'
* AND 'First Name' CONTAINS IGNORING CASE 'J'"
*
* @returns {array} [[headers],[match row],[match row]...]
* If no match returns []
*/
function searchFusion(target, where){
var values = [];
if (target == '*'){
var headers = getFusionHeaders();
for(var i in headers){
values.push("'"+headers[i]+"'");
}
}else{
values.push(target);
}
var arrayResult = fusionRequest("get", "SELECT "+values.toString()+",ROWID FROM "+
FUSION_ID+" WHERE "+ where).split(/\n/);
for (var i in arrayResult){
arrayResult[i] = arrayResult[i].split(/,/);
}
arrayResult.splice(arrayResult.length-1, 1);
return arrayResult;
}
/**
* Updates a record in the Fusion table
* Note: fusionObj must contain rowid of Fusion table record
*
* @params {object} fusionObj object with properties from cameled column names
* @returns {string} OK if successful
*/
function writeFusionObj(fusionObj){
var values = [];
var headers = getFusionHeaders();
for(var i in headers){
if (fusionObj[camelString(headers[i])] != undefined)
values.push("'"+headers[i] +"'='"+fusionObj[camelString(headers[i])]+"'");
}
return fusionRequest("post", "UPDATE "+FUSION_ID+" SET "+values.toString()+
" WHERE ROWID = '"+fusionObj.rowid+"'")
}
/**
* Add a new record to a Fusion table
*
* @params {object} fusionObj object with properties from cameled column names
* @returns {integer} rowid useful for unique ID of record
*/
function insertFusionObj(fusionObj){
var values = [];
var columns =[];
var headers = getFusionHeaders();
for(var i in headers){
columns.push("'"+headers[i] +"'");
values.push("'"+fusionObj[camelString(headers[i])]+"'");
}
return parseInt(fusionRequest("post", "INSERT INTO "+FUSION_ID+
" ("+columns.toString()+") VALUES ("+values.toString()+")").substring(5));
}
/**
* Get the Fusion row ID for a given column header and unique value
*
* @returns {integer} Fusion ROWID for record
*/
function getFusionROWID(header, key){
return parseInt(fusionRequest("get", "SELECT ROWID FROM "+FUSION_ID+
" WHERE '"+header+"'='"+key+"'").substring(5));
}
/**
* get the column header names from Fusion Table
*
* @returns {array} [header, header, ...]
*/
function getFusionHeaders(){
var headers = [];
var result = fusionRequest("get", "DESCRIBE "+FUSION_ID).split(/\n/);
for (var i in result){
result[i] = result[i].split(/,/);
headers.push(result[i][1]);
}
headers.splice(0, 1);
headers.splice(headers.length-1, 1);
return headers;
}
/**
* Deletes a record in the Fusion Table
*
* @params {string} rowid the ID of a Fusion table row
*/
function deleteFusionRow(rowid){
fusionRequest("post", "DELETE FROM "+FUSION_ID+" WHERE ROWID = '"+rowid+"'");
}
/**
* The get or post request to the Fusion API
*
* @params {string} reqMethod get or post
* @params {string} sql String A sgl type request see http://goo.gl/aVP3B
* @returns {integer} Fusion rowid useful for unique ID of record
*/
function fusionRequest(method, sql) {
var url = "https://www.google.com/fusiontables/api/query";
if (USE_OAUTH){
var fetchArgs = googleOAuth_();
}else{
var fetchArgs = new Object();
fetchArgs.headers = {"Authorization": "GoogleLogin auth=" + getAuthToken_()};
}
fetchArgs.method = method;
if( method == 'get' ) {
url += '?sql='+sql;
fetchArgs.payload = null;
} else{
fetchArgs.payload = 'sql='+sql;
}
return UrlFetchApp.fetch(url, fetchArgs).getContentText();
}
/**
* @private for OAuth
*/
function googleOAuth_() {
var oAuthConfig = UrlFetchApp.addOAuthService('fusion');
oAuthConfig.setRequestTokenUrl("https://www.google.com/accounts/"+
"OAuthGetRequestToken?scope=https://www.google.com/fusiontables/api/query");
oAuthConfig.setAuthorizationUrl("https://www.google.com/accounts/OAuthAuthorizeToken");
oAuthConfig.setAccessTokenUrl("https://www.google.com/accounts/OAuthGetAccessToken");
oAuthConfig.setConsumerKey('anonymous');
oAuthConfig.setConsumerSecret('anonymous');
return {oAuthServiceName:'fusion', oAuthUseToken:"always"};
}
/**
* @private for client Auth
* @returns String(auth token for a user)
*/
function getAuthToken_() {
var response = UrlFetchApp.fetch("https://www.google.com/accounts/ClientLogin", {
method: "post",
payload: "accountType=GOOGLE" +
"&Email=" + ScriptProperties.getProperty('CUSTOMER_KEY') +
"&Passwd=" + encodeURIComponent(ScriptProperties.getProperty('CUSTOMER_SECRET'))+
"&service=fusiontables" +
"&Source=testing"
});
var responseStr = response.getContentText();
responseStr = responseStr.slice(responseStr.search("Auth=") + 5, responseStr.length);
responseStr = responseStr.replace(/\n/g, "");
return responseStr;
}
/**
* Used to authenticate to Fusion Tables
* Run it twice!
*/
function doOAuth(){
var method = 'get';
var sql = "SHOW TABLES";
Logger.log(fusionRequest(method,sql));
}
var USE_OAUTH = true;
var FUSION_ID = ScriptProperties.getProperty('FUSION_ID');