调试一个ajax要吐血了
写了一个英汉词典,具体流程:
1. 把本地文件按照{English: Chinese}的格式写入memcached服务器
2. 通过ajax提交英语单词,并返回中文释义
遇到的问题: 查询对应的单词,可以通过file_put_contents函数写入本地,证明查询到了相应的单词,在客户端,通过readyState属性可以依次看到返回1,2,3,4,但是在window.alert(type res)时显示未定义。
<br /><br />//这部分代码是OK的,用于读取并解析本地的txt格式词典<br /><?php <br />class Word<br />{<br /> private $query_en='#\w+\b#i';<br /> private $query_ch='#[\x{4e00}-\x{9fa5}][\x{4e00}-\x{9fa5},\)\.\( \w]*#u';<br /> private $arr_word=array();<br /> private $recycle_num=100;<br /> private $fp=null;<br /> <br /> public function __construct($fileName)<br /> {<br /> $this->fp=fopen($fileName,'r') or die('打开ciba失败');<br /> }<br /> <br /> <br /> public function readWord()<br /> {<br /> while(!feof($this->fp))<br /> {<br /> $word=fgets($this->fp);<br /> $word=trim($word);<br /> if($word=='') continue;<br /> <br /> $en=$this->parseEn($word);<br /> $ch=$this->parseCh($word);<br /> $this->arr_word["$en"]=$ch;<br /> <br /> /* $this->recycle_num--;<br /> if($this->recycle_num==0) return; */<br /> <br /> <br /> }<br /> }<br /> public function parseEn(&$word)<br /> {<br /> if(preg_match($this->query_en, $word, $en))<br /> {<br /> return $en[0];<br /> }<br /> else<br /> {<br /> echo "match english word failed<br />";<br /> }<br /> }<br /> public function parseCh(&$word)<br /> {<br /> if(preg_match($this->query_ch, $word, $ch))<br /> {<br /> return $ch[0];<br /> }<br /> else<br /> {<br /> echo "match chinese failed<br />";<br /> }<br /> }<br /> <br /> public function getWord()<br /> {<br /> return $this->arr_word;<br /> }<br /> <br /> public function __destruct()<br /> {<br /> fclose($this->fp);<br /> }<br />}<br /><br />//$word=new Word('ciba.txt');<br />//$word->readWord();<br />//echo "<pre class="brush:php;toolbar:false">";<br />//print_r($word->getWord());<br />//echo ""; */
?>
//这部分代码也是OK的,用于将词条写入memcached
require_once('parseWord.php');
class MemStore
{
private $mem=null;
private $pat='#^[a-zA-Z]+\b#i';
public function __construct()
{
$this->mem=new Memcache();
$this->mem->connect("127.0.0.1", 11211) or die("connect memcached failed!!!
");
}
public function __destruct()
{
$this->mem->close();
}
public function addWord()
{
$word=new Word('ciba.txt');
$word->readWord();
$result=$word->getWord();
//echo count($result)."字符
";
//exit();
foreach($result as $en => $ch)
{
$this->mem->add($en, $ch, MEMCACHE_COMPRESSED, time()+10*24*3600) or die("添加词条失败". __LINE__ ."
");
}
}
public function setWord($en,$ch)
{
//控制器判断输入是否合法
$en=$this->filterWord($en);
$en=$this->mem->get($en) or die("找不到词条 $en");
$this->mem->set($en, $ch, MEMCACHE_COMPRESSED, time()+31*24*3600) or die("添加词条$en失败");
}
public function getWord($en)
{
//控制器判断输入是否合法
$en=$this->filterWord($en);
$ch=$this->mem->get($en) or die("找不到词条 $en");
return $ch;
}
public function replaceWord($en,$ch)
{
//控制器判断输入是否合法
$en=$this->filterWord($en);
$en=$this->mem->get($en) or die("找不到词条 $en");
$this->mem->replace($en, $ch, MEMCACHE_COMPRESSED, time()+31*24*3600) or die("替换词条$en失败");
}
public function deleteWord($en)
{
//控制器判断输入是否合法
$en=$this->filterWord($en);
$this->mem->delete($en,0) or die("删除词条$en失败");
}
//过滤掉中文,包括空格的词组,长度大于20的词条
public function filterWord($en)
{
$en=trim($en);
if(preg_match('#[\x{4e00}-\x{9fa5},\)\.\(]+#u', $en))
{
//echo '暂时不支持中文查询
';
if(preg_match('#\b[a-z]+\b#i', $en, $res))
{
if(strlen($res[0])>20)
{
//echo "字符过长
";
return strtolower(substr($res[0], 0,20));
}
return strtolower($res[0]);
}
}
else if(preg_match('#\s+#', $en))
{
//$en=explode(' ', $en);
//echo "含有空格
";
$res=null;
if(preg_match('#[a-z]+#i', $en, $res))
{
if(strlen($res[0])>20)
{
//echo "字符过长
";
return strtolower(substr($res[0], 0,20));
}
return strtolower($res[0]);
}
}
else if(preg_match('#[—_\+\?\*\^\$\#\%\&\/\\,\.!@=\`\'\"\"""]#',$en, $res))
{
//
//echo '含有非法字符
';
if(preg_match('#[a-z]+#i', $en, $res))
{
if(strlen($res[0])>20)
{
echo "字符过长
";
return strtolower(substr($res[0], 0,20));
}
return strtolower($res[0]);
}
}
else if(strlen($en)>20)
{
//echo "字符过长
";
return strtolower(substr($en, 0,20));
}
else
{
return $en;
}
}
public function flushAll()
{
$this->mem->flush();
}
public function getTime()
{
if (function_exists("micro_time"))
{
list($usec, $sec) = explode(" ", microtime());
return ((float)$usec + (float)$sec);
}
else
{
return time();
}
}
}
//$mem=new MemStore();
//$mem->addWord();
//$mem->flushAll();
//$mem->replaceWord('abandon', 100000000);
//$mem->deleteWord('abandon');
//echo $mem->getWord('_*&^%abandon^%$#');
//echo "ok";
?>
//下面这段代码也是OK的,根据客户端提交的英语单词,可以成功查询到对应的中文,并写入本地文件成功过
header("content-type: text/xml; charset=utf-8");
header("Cache-Control: no-cache");
require_once "storeWord.php";
if(!empty($_GET['enword']))
{
$en=$_GET['enword'];
//file_put_contents('aword.txt', $en."\t\t",FILE_APPEND);
$mem=new MemStore();
$ch=$mem->getWord($en);
$en=$mem->filterWord($en);
$res="
file_put_contents('aword.txt', $res."\r\n",FILE_APPEND);//这里是OK的
echo $res;
//echo '{'.$en.':'.$res.'}';
}
else
{
file_put_contents('aword.txt', "receive NON data \r\n",FILE_APPEND);
}
?>
//我估计问题出在下面这段代码,,但是就是找不出问题所在,一直显示undefined
<script><br /><br />function getXMLHttpRequest()<br />{<br /> var xmlhttp=null;<br /> if(window.ActiveXObject)<br /> {<br /> xmlhttp = new ActiveXObject("Microsoft.XMLHttp");<br /> }<br /> else<br /> {<br /> xmlhttp=new XMLHttpRequest();<br /> }<br /> return xmlhttp;<br />}<br /><br />function query()<br />{<br /> var url="/ciba/process.php";<br /> var data="?enword="+$('enWord').value+"&rand="+Math.random();<br /> $('enWord').value="";<br /> //var url+=data;<br /> //window.alert(url+data);<br /> <br /> xmlhttp=getXMLHttpRequest();<br /> if (xmlhttp)<br /> {<br /> <br /> xmlhttp.open("get", url+data,true);<br /> <br /> <br /> xmlhttp.onreadystatechange=function()<br /> {<br /> //window.alert(xmlhttp.readyState);<br /> if (xmlhttp.readyState==4 && xmlhttp.status==200)<br /> {<br /> var res=xmlhttp.responseXML;<br /> window.alert(typeof $res);//这个位置一直显示undefined<br /> var en=res.getElementsByTagName("en")[0].childNodes[0].nodeValue;<br /> <br /> var ch=res.getElementsByTagName("ch")[0].childNodes[0].nodeValue;<br /> $("chWord").innerText= en+": 的中文意思是: "+ch; <br /> }<br /> } <br /> xmlhttp.send(null); <br /> }<br /> <br />}<br /><br />function $(id)<br />{<br /> return document.getElementById(id);<br />}<br /></script>
ajax调试要吐血了
------解决思路----------------------
var res=xmlhttp.responseXML;
window.alert(typeof $res);
一样吗?不一样当然不行
------解决思路----------------------
sublime or notepad++

PHP和Python各有优势,选择应基于项目需求。1.PHP适合web开发,语法简单,执行效率高。2.Python适用于数据科学和机器学习,语法简洁,库丰富。

PHP不是在消亡,而是在不断适应和进化。1)PHP从1994年起经历多次版本迭代,适应新技术趋势。2)目前广泛应用于电子商务、内容管理系统等领域。3)PHP8引入JIT编译器等功能,提升性能和现代化。4)使用OPcache和遵循PSR-12标准可优化性能和代码质量。

PHP的未来将通过适应新技术趋势和引入创新特性来实现:1)适应云计算、容器化和微服务架构,支持Docker和Kubernetes;2)引入JIT编译器和枚举类型,提升性能和数据处理效率;3)持续优化性能和推广最佳实践。

在PHP中,trait适用于需要方法复用但不适合使用继承的情况。1)trait允许在类中复用方法,避免多重继承复杂性。2)使用trait时需注意方法冲突,可通过insteadof和as关键字解决。3)应避免过度使用trait,保持其单一职责,以优化性能和提高代码可维护性。

依赖注入容器(DIC)是一种管理和提供对象依赖关系的工具,用于PHP项目中。DIC的主要好处包括:1.解耦,使组件独立,代码易维护和测试;2.灵活性,易替换或修改依赖关系;3.可测试性,方便注入mock对象进行单元测试。

SplFixedArray在PHP中是一种固定大小的数组,适用于需要高性能和低内存使用量的场景。1)它在创建时需指定大小,避免动态调整带来的开销。2)基于C语言数组,直接操作内存,访问速度快。3)适合大规模数据处理和内存敏感环境,但需谨慎使用,因其大小固定。

PHP通过$\_FILES变量处理文件上传,确保安全性的方法包括:1.检查上传错误,2.验证文件类型和大小,3.防止文件覆盖,4.移动文件到永久存储位置。

JavaScript中处理空值可以使用NullCoalescingOperator(??)和NullCoalescingAssignmentOperator(??=)。1.??返回第一个非null或非undefined的操作数。2.??=将变量赋值为右操作数的值,但前提是该变量为null或undefined。这些操作符简化了代码逻辑,提高了可读性和性能。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

DVWA
Damn Vulnerable Web App (DVWA) 是一个PHP/MySQL的Web应用程序,非常容易受到攻击。它的主要目标是成为安全专业人员在合法环境中测试自己的技能和工具的辅助工具,帮助Web开发人员更好地理解保护Web应用程序的过程,并帮助教师/学生在课堂环境中教授/学习Web应用程序安全。DVWA的目标是通过简单直接的界面练习一些最常见的Web漏洞,难度各不相同。请注意,该软件中

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。