今天用Jsp和ajax结合写了个小程序。下面是遇到的一些问题和解决方案,是为了自己的学习做笔记。

一、连接mysql数据库出现了问题,

检查下是否加入了mysql的jar包,要注意也要把这个jar加入到、tomcat的lib目录下。

二、ajax

应用ajax的步骤
1、创建XMLHttpRequest。要注意浏览器的兼容性问题:
 //创建XMLHttpRequest对象
function createXMLHttpRequest(){
if(typeof XMLHttpRequest !="undefined"){
return new XMLHttpRequest();
}else if(typeof ActiveXObject !="undefined"){
var versions = ["MSXML2.XMLHttp.6.0","MSXML.XMLHttp.3.0","MSXML2.XMLHttp"],
i,len;
for(i=0,len=versions.length;i<len;i++){
try{
new ActiveXObject(version[i]);
arguments.callee.activeXString = version[i];
break;
}catch(ex){

}
}
return new ActiveXObject(arguments.callee.activeXString);
}else{
throw new Error("No XHR object avaiable");
}


 }2、发送请求函数
先创建XMLHttpRequest对象,在调用对象的open(url,method,true),第一个参数是url地址,第二个是‘’get‘。或者“post”方法,第三个是表示是否为Asynchronous.
然后定义处理函数,processResponse ,在调用、send();
//发送请求函数
function sendRequest(url){
XMLHttpReq = createXMLHttpRequest();
//XMLHttpReq.open("post","SignUpAction",true);
XMLHttpReq.open("get",url,true);

XMLHttpReq.onreadystatechange = processResponse;
//XMLHttpReq.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
//XMLHttpReq.send('uname='+uname+'&psw'+psw);
XMLHttpReq.send(null);


 }3、处理函数定义(在本方法中还遇到了。XMLHttpRequest.responserXML为null的情况)
//处理返回信息
function processResponse(){
if(XMLHttpReq.readyState==4){
alert(XMLHttpReq.status==200);
if(XMLHttpReq.status==200){

//.getElementsByTagName("res")[0].firstChild.data;
var resText = XMLHttpReq.responseText;
alert(resText);
//var res = XMLHttpReq.responseXML;
//.getElementsByTagName().length;
var res = XMLHttpReq.responseXML.getElementsByTagName("res")[0].firstChild.data;
window.alert(res);
}else{
window.alert("你所请求的页面不存在");
}
}


 }4\事件处理函数 --------/注册函数,这个函数中通过sendRequest将参数传递到服务器端的servlet
function signUp(){

uname = document.myform.uname.value;
psw = document.myform.psw.value;
var psw2 = document.myform.psw2.value;

if(uname==""){
window.alert("用户名不能为空 ");
document.myform.uname.focus();
return false;
}
else if(psw!=psw2){
window.alert("两次输入的密码不相同 ");
document.myform.psw.focus();
return false;
}
else {

sendRequest('/SignUp/servlet1?uname='+uname+'&psw='+psw);

}
 }

三、XMLHttpRequest.responserXML为null的情况,解决方法

1. 那就是没有设置返回的内容格式,只要在write前添加response.setContentType("text/xml;charset=utf-8");就可以了

2. xml的内容格式不正确,可以通过将xml的内容输出,好好检查xml的格式是否正确

还有就是XML格式内容前不能有其他的内容输出

四、servlet配置出现问题

出现404错误
 是servelt 的、<url-pattern>配置出现问题
 在<url-pattern>中要有可以写
  <servlet-mapping>
   <servlet-name>SignUpAction</servlet-name>
     <url-pattern>/servlet1</url-pattern>
  </servlet-mapping> 但在jsp文件中时 
 要这样: 
sendRequest('/SignUp/servlet1?uname='+uname+'&psw='+psw);
前面要加上项目的名字。
五,MySql中自动增长字段
create table user(id int(10) not null auto_increment,
name varchar(20) )
aut0_increment=200;
insert into user values(null,"n");

自动增长字段从200开始,插入时,自动增长字段可以插入null。


六、当出现undefined is not  a function时要检查函数内部是否语法错误。比如调用了没有大属性或者方法等。

七、加载图片时,会出现readyState缓慢的出现4的情况。

八、js中null和undefined的区别

undefined(不存在)出现的情况:1、变量没有申明或者初始化;2、对象没有该属性

null出现的情况:1、变量存在但是没有初始化2、赋值为null

一个对象中没有指定的变量,而要使用,会出现 undefined 
Html中没有的元素,通过document.getElementById("")查找的结果为: null 
Html中有的元素,但是没有任何值,通过document.getElementById("")查找的结果为:” ”; 不是null