这是我第一次使用phonegap和本地存储。所以,如果我问些愚蠢的话,我表示歉意。
我正在尝试为移动应用程序创建一个登录/注册页面。我在html / js / jquery中创建了一个前端页面,在php中创建了后端。
在php中,我们使用会话来存储一些数据,但是在html中,没有会话。但是我知道我们可以使用本地存储来存储这些值。这是我的用于身份验证的php代码。
<?php
session_start();
header("Access-Control-Allow-Origin: *");
header('Content-Type: application/json');
require_once('include/db.php');
require_once('functions.php');
$res=array();
$res['errors']=array();
if(isset($_POST)) {
if(empty($_POST['email'])) {
array_push($res['errors'], "Email could not be empty");
}
if(empty($_POST['password'])) {
array_push($res['errors'], "Password could not be empty");
}
if(!empty($_POST['email']) && !isValidEmail($_POST['email'])) {
array_push($res['errors'], "Invalid Email Format");
}
$email = $_POST['email'];
$password = $_POST['password'];
$now = date('Y-m-d H:i:s');
if(empty($res['errors'])) {
$result = $mysqli->prepare("SELECT uid,pic,fname,last_seen FROM users where email= ? and password = ? and status = '1'");
$result ->bind_param("ss", $email, $password);
$result->execute();
$result->store_result();
$result->bind_result($uid, $pic, $fname, $last_seen);
if($result->num_rows == 1){
while ($result->fetch()) {
$_SESSION['uid'] = $uid;
$_SESSION['pic'] = $pic;
$_SESSION['name'] = $fname;
$_SESSION['last_login'] = $last_seen;
}
$res['success'] = true;
}
else{
array_push($res['errors'], 'Invalid login details');
$res['success'] = false;
}
}else{
$res['success'] = false;
}
session_write_close();
echo json_encode($res);
}
?>
这是ajax代码。
<script type="text/javascript">
$('document').ready(function()
{
$("#login").on("submit", function(e) {
e.preventDefault;
var btn = $('#btn-login');
btn.button('loading');
$.ajax({
type: 'post',
url: 'loginexec.php',
cache: false,
dataType: 'json',
data: $('form#login').serialize(),
beforeSend: function() {
$("#validation-errors").hide().empty();
},
success: function(data) {
if(data.success == false)
{
var arr = data.errors;
$.each(arr, function(index, value)
{
if (value.length != 0)
{
$("#validation-errors").append('<div class="alert alert-danger"><strong>'+ value +'</strong><div>');
}
});
$("#validation-errors").show();
btn.button('reset');
} else {
localStorage.login="true";
localStorage.email=email;
localStorage.id=id;
window.location.href = 'user_profile.php';
}
},
error: function(xhr, textStatus, thrownError) {
alert('Something went to wrong.Please Try again later...');
btn.button('reset');
}
});
return false;
});
});
</script>
我想将这些值存储在本地存储中,但不确定如何执行此操作。
$uid;
$pic;
$fname;
$last_seen;
请指教。
我在这里看到的第一个错误是用法localStorage
错误:
使用window.localStorage.setItem("login",1);
而不是localStorage.login ="true";
然后使用它 window.localStorage.getItem("login");
但是,我认为这也不是一个好主意,localStorage
因为其他任何恶意应用程序都可以访问所有localStorage值,所以它还可以存储会话(甚至是电子邮件地址)之类的内容-为什么不在每个页面上执行单个ajax请求首先检查是否建立了有效的会话,以及是否未重定向到登录名。在这种情况下,也不需要存储last_seen
时间,会话和良好的身份验证应始终在服务器端进行。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句