PHP提交表单失败后如何保留已经填写的信息
本文介绍PHP提交表单失败后如何保留填写的信息一些方法总结,其中最常用的就是使用缓存方式了,这种方法如果网速慢是可能出问题的,最好的办法就是使用ajax了。
1.使用header头设置缓存控制头Cache-control。
PHP代码如下:
header('Cache-control:private,must-revalidate');//支持页面回跳
2.使用session_cache_limiter方法。
PHP代码如下:
session_cache_limiter('private,must-revalidate');//要写在session_start方法之前
下面介绍一下session_cache_limiter参数:
session_cache_limiter内的几个参数意义是:
nocache:当然是不缓存(比如:表单信息被清除),但公共变量可以缓存
private:私有方式缓存(比如:表单信息被保留,但在生存期内有效)
private_no_cache:私有方式但不过期(表单信息被保留)
publice:公有方式,(表单信息也被保留)
设置缓存过期时间:session_cache_expire函数设置,缺省是180分钟。
常遇见问题:
1.session_cache_limiter("private");表单信息是保留了,但是如果我修改已经提交的信息,表单页面所呈现的信息还是缓存里信息,没能及时自动刷新,如果不用session_cache_limiter("private");又不能保留表单信息
解决方案:
在session_start前面加上
session_cache_limiter("private,must-revalidate");
即可。
2.另一种办法我们可以使用ajax来实例
index.html模板文件大致内容如下:
<html>
<head>
<title>jQueryAjax实例演示</title>
</head>
<scriptsrc="./js/jquery.js"type="text/javascript"></script>
<scripttype="text/javascript">
$(document).ready(function(){//这个就是jQueryready,它就像C语言的main所有操作包含在它里面
$("#button_login").mousedown(function(){
login();//点击ID为"button_login"的按钮后触发函数login();
});
functionlogin(){//函数login();
varusername=$("#username").val();//取框中的用户名
varpassword=$("#password").val();//取框中的密码
$.ajax({//一个Ajax过程
type:"post",//以post方式与后台沟通
url:"login.php",//与此php页面沟通
dataType:'json',//从php返回的值以JSON方式解释
data:'username='+username+'&password='+password,//发给php的数据有两项,分别是上面传来的u和p
success:function(json){//如果调用php成功
//alert(json.username+'n'+json.password);//把php中的返回值(json.username)给alert出来
$('#result').html("姓名:"+json.username+"<br/>密码:"+json.password);//把php中的返回值显示在预定义的result定位符位置
}
});
}
//$.post()方式:
$('#test_post').mousedown(function(){
$.post(
'login.php',
{
username:$('#username').val(),
password:$('#password').val()
},
function(data)//回传函数
{
varmyjson='';
eval_r('myjson='+data+';');
$('#result').html("姓名1:"+myjson.username+"<br/>密码1:"+myjson.password);
}
);
});
//$.get()方式:
$('#test_get').mousedown(function(){
$.get(
'login.php',
{
username:$('#username').val(),
password:$('#password').val()
},
function(data)//回传函数
{
varmyjson='';
eval_r("myjson="+data+";");
$('#result').html("姓名2:"+myjson.username+"<br/>密码2:"+myjson.password);
}
);
});
});
</script>
<body>
<divid="result"style="background:orange;border:1pxsolidred;width:300px;height:200px;"></div>
<formid="formtest"action=""method="post">
<p><span>输入姓名:</span><inputtype="text"name="username"id="username"/></p>
<p><span>输入密码:</span><inputtype="text"name="password"id="password"/></p>
</form>
<buttonid="button_login">ajax提交</button>
<buttonid="test_post">post提交</button>
<buttonid="test_get">get提交</button>
</body>
</html>
login.php文件的内容如下:
<?php
echojson_encode(array('username'=>$_REQUEST['username'],'password'=>$_REQUEST['password']));
?>
这样的话我们提交不需要刷新页面了,如果失败就直接会有提交了,这样可以100%保存提交失败后数据不被丢失了。