小说为txt文本形式,需要分成比较小的块,使用户能够通过wap浏览。 每页自定义大小为800k算上分页导航的话有1k左右。分页导航实现了页面跳转:首页 下一页 上一页 尾页 跳到页 。跳页需要wml表单提交,类似于html的表单提交。幸亏我blog中有资料可查,扒拉出来看了看,还能用,需要注意的是 <postfield name="p" value="$(p)"/> 这里的 $(p) 看仔细了,不是php的变量,由于我当时头有点昏,愣是以为是php的变量,调试了半天,结果老是不对。 $page_nav ='<br/><anchor title="link">跳至<go method="post" href="s.php?f='.$_REQUEST['f'].'"><postfield name="p" value="$(p)"/></go></anchor>页<input name="p" type="text" value="'.$page.'" format="*m" maxlength="5" emptyok="false" />'; 显示方面,输出wml的头,汉字gbk转换为utf8,也没啥可说的了。最后测试却发现了一个问题。txt文本比较大,我事先把它拆成n个小文件,一个文件是一个wap页面的内容,然后用程序读取显示。但是在拆分小文件的时候,恰好把一个汉字拆成两半了,显示就乱套了。比如:每个文件20k,如果有10个汉字正好。但是不巧的是有9个汉字加一个字母后面又是汉字这样的话,这个汉字就被拆成两半了。 这样的文件经过iconv之后会导致页面显示错误。试了好几种办法,在公司直到10点多,后来确实脑子不转了,乱七八糟的,害得我星际也没心思打。今天早上在公交车上想出了个办法。我可以按字符读入,如果是汉字读双字节,如果不是则读单字节不就完了么呵呵。于是乎,就写了个函数,搞定。
function readBook($book,$size=""){ if($size=="") $size = PAGE_SIZE; $handle = fopen ("$book", "r"); while (false !== ($char = fgetc($handle))) { if(preg_match("/[/x80-/xff]/",$char)) { $str .= $char.fgetc($handle); } else $str .= $char; if(strlen($str) >= ceil($size/2)) { $arr[] = $str; $str = ""; } } $arr[] = $str; return $arr;}