Хранилище Web SQL в iphone - PullRequest
       11

Хранилище Web SQL в iphone

1 голос
/ 01 февраля 2012

Можно ли использовать хранилище Web SQL в iPhone

В настоящее время мой следующий код приводит к ошибке

 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
  "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
  <head>
  <meta http-equiv="Content-type" content="text/html; charset=utf-8" />
  <title>Web Storage</title>
  <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.6.2/jquery.min.js"></script>
  <script type="text/javascript" language="javascript" charset="utf-8">

    var sessionDB = {}
    sessionDB.webdb = {};
    sessionDB.webdb.db = null;

    function init() {
     console.log("Loading");
     sessionDB.webdb.open();
     sessionDB.webdb.createTable();
     sessionDB.webdb.addRecord("_session_id=9943d50d1b8fdc3794137f5446e94a6e");
     sessionDB.webdb.getSession();
    }

    sessionDB.webdb.open = function() {
      var dbSize = 1 * 1024 * 1024; 
      sessionDB.webdb.db = openDatabase("sessionDB", "1.0", "Session Database", dbSize);
    }

    sessionDB.webdb.createTable = function() {
      var db = sessionDB.webdb.db;
      db.transaction(function(tx) {
        // make id auto Increment
        tx.executeSql("CREATE TABLE IF NOT EXISTS sessions(ID INTEGER PRIMARY KEY ASC, session_id TEXT, added_on DATETIME)", [],successCallbacks,errorCallbacks);
       });
    }

    sessionDB.webdb.addRecord = function(session_id) {
        var db = sessionDB.webdb.db;
        db.transaction(function(tx){
          var addedOn = new Date();
            tx.executeSql("INSERT INTO sessions(session_id, added_on) VALUES (?,?)",
              [session_id,addedOn],successCallbacks,errorCallbacks);

         });
      }  

    successCallbacks = function(transaction,sqlResult) {
       console.log("SUCCESS :)");
    } 

    errorCallbacks = function(transaction,error) {
       console.log(error.message + " -- " + error.code);
       console.log("ERROR !!!");
     }

    sessionDB.webdb.getSession = function() {
      var db = sessionDB.webdb.db;
      db.transaction(function(tx) {
        tx.executeSql("SELECT session_id FROM sessions limit 1 ;", [], resultSets);
      });
   }   

   resultSets = function (transaction,sqlResult) {
     $("#resultSet").text(sqlResult.rows.item(0).session_id)
   }

  </script>   
</head>
 <body onload="init();">
   <h1> WEB STORAGE EXAMPE </h1>
   <div id="resultSet"> </div>

 </body>

Сообщение об ошибке с указанием « не авторизовано » с ошибкой код 5

Идея состоит в том, чтобы сохранить session_id в таблицах сеансов, и я не могу приблизиться к localStorage из-за this

Приложение не является нативным приложением, это традиционное клиент-серверное приложение с сервером, возвращающим указанный выше фрагмент HTML в браузер iPhone (браузер Safari)

Примечание: Вышеупомянутый код отлично работает в браузере Desktop с возможностями Web SQL

Спасибо Viren

1 Ответ

1 голос
/ 15 февраля 2012

Очевидно, что Safari на iOS имеет некоторые проблемы с обработкой БД.Это работает, если вы создаете ярлык на своем трамплине для запуска в качестве WebApp.

...