Archive for the ‘Web’ Category

关于wml的文本框缓存问题

星期一, 6月 23rd, 2008

普通情况下:
<%
String msg = request.getParameter(”msg”);
String emo= request.getParameter(”emo”);
msg=msg+emo;
%>
文本框写成: <input name=”msg” value=”<%=msg%>” type=”text” emptyok=”true”/><br/>

表单定义成

<go href=”/test.jsp” method=”post”>
<postfield name=”msg” value=”$msg”/>

<postfield name=”emo” value=”test”/>
</go>添加表情</anchor>

表单是提交给当前页面的。

测试步骤如下:

在消息框输入内容“汉字”,提交表单。

预期结果为:文本框显示为“汉字test”,但是实际情况却是依然只显示“汉字”.

经过多次测试验证,发现这是手机浏览器或Opera等的表单缓存问题。

解决办法为:

将文本框的name定义成随机的。表单中关联到随机的文本框变量名,

修改后的代码如下:

<%
String msgName=”m”+rd.nextInt(65536*6);//随机数产生input名字
String msg = request.getParameter(”msg”);
String emo= request.getParameter(”emo”);
msg=msg+emo;
%>
文本框写成: <input name=”<%=msgName %>” value=”<%=msg%>” type=”text” emptyok=”true”/><br/>

表单定义成

<go href=”/test.jsp” method=”post”>
<postfield name=”msg” value=”$<%=msgName %>”/>

<postfield name=”emo” value=”test”/>
</go>添加表情</anchor>

经过测试,不提交当前页面的,也有类似问题,三星X708破手机就是这样的。

Tags: wml

Related posts

javascript实现身份证号码的验证

星期三, 6月 4th, 2008

整理了一份javascript对身份证进行验证的程序。

源文件在: http://618119.com/docs/--escaped_anchor:e0dd5e818f3e8b2ef8dfd677654a4540--/shenfenzheng.html

javascript 代码为:
function getName(code){
var name=xzqh[code];
if(name==null){
return name;
}
//如果不是00结尾的,则补上市名称,659000例外 429000,469000
if(code%100 != 0 && (code-code%100)!=659000 && (code-code%100)!=429000 && (code-code%100)!=469000){
var cityName=xzqh[(code-code%100)];
if(cityName.length>1){//过滤掉只有一个字的“县”
name=cityName+name;
}
}
//如果不是0000结尾的,再补上省名称
if(code%10000 != 0){
name=xzqh[(code-code%10000)]+name;
}
return name;
}

function genData(){
var str=”";
for(code in xzqh){
//整理成竖线分隔的每行一条记录
str+=  “”+code  +”|” +getName(code) +”\n”;
}
document.getElementById(”soapres”).value=str;
}

function checkId(){
var code=document.getElementById(”idCode”).value;
if(code==null || ( code.length!=15 && code.length!=18)){
alert(”请输出正确长度的身份证号码!”);
return;
}

var xzqhCode=code.substr(0,6);
var xzqhName=getName(xzqhCode);

//先判断行政区划信息
if(xzqhName==null){
alert(”没有该身份证号码的地区信息,很可能是假身份证号码!”);
return;
}
//再判断是否都是数字和X.
for(var i=0;i<code.length;i++){
if(i<17){
if(code.charAt(i)>”9″ || code.charAt(i)<”0″){
alert(”你输入的身份证号码有误,可能是假身份证号码!”);
return;
}
}

if(i==17){//盘判断第17位
if(! ( (code.charAt(i) >= “0″ && code.charAt(i) <= “9″ )|| code.charAt(i)==’X’ || code.charAt(i)==’x') ){
alert(”你输入的身份证号码有误,可能是假身份证号码!”);
return ;
}
}
}

var year=1900;//出生年
var month=1;//出生月
var day=1;//出生日
var age=30;//年龄
var sex=”男”;//性别
var code15=”";//15位身份证
var code18=”";//18位身份证
var verify=”x”;//校验位
//按15位进行判断
if(code.length==15){
year=1900+parseInt(code.substr(6,1))*10+parseInt(code.substr(7,1));
month=parseInt(code.substr(8,1))*10+parseInt(code.substr(9,1));
if(month>12){
alert(”出生月份有错,可能是假身份证号码!”);
return ;
}
day=parseInt(code.substr(10,1))*10+parseInt(code.substr(11,1));
if(month>31){
alert(”出生日期有错,可能是假身份证号码!”);
return ;
}

var bday=new Date(year,month,day);
if(bday.getFullYear()!=year || bday.getMonth()!=month || bday.getDate()!=day){
alert(”出生年月日有错,可能是假身份证号码!”);
return ;
}

sex=parseInt(code.substr(14,1));
if(sex%2==1){
sex=”男”;
}
else{
sex=”女”;
}
age=parseInt(new Date().getFullYear())-parseInt(year);
code15=code;
code18=xzqhCode+”19″+code.substr(6,9);
verify=getVerify(code18);
code18=code18+verify;
}
//按18位进行判断
if(code.length==18){
year=parseInt(code.substr(6,1))*1000+parseInt(code.substr(7,1))*100+parseInt(code.substr(8,1))*10+parseInt(code.substr(9,1));
month=parseInt(code.substr(10,1))*10+parseInt(code.substr(11,1));
if(month>12){
alert(”出生月份有错,可能是假身份证号码!”);
return ;
}
day=parseInt(code.substr(12,1))*10+parseInt(code.substr(13,1));
if(month>31){
alert(”出生日期有错,可能是假身份证号码!”);
return ;
}
var bday=new Date(year,month,day);
if(bday.getFullYear()!=year || bday.getMonth()!=month || bday.getDate()!=day){
alert(”出生年月日有错,可能是假身份证号码!”);
return ;
}

if(bday.getTime()>=new Date().getTime()){
alert(”日期非法,可能是假身份证号码!”);
return ;
}
sex=parseInt(code.substr(16,1));
if(sex%2==1){
sex=”男”;
}
else{
sex=”女”;
}
verify=getVerify(code);
var tmpv=code.substr(17,1);
if(tmpv==”X”){tmpv=”x”};
if(verify!=tmpv){
alert(”身份证号码无法通过校验,可能是假身份证号码!”);
return ;
}
age=parseInt(new Date().getFullYear())-parseInt(year);
code18=code;
code15=code.substr(0,6)+code.substr(8,9);
}
var msg=”您输入的身份证号码:\t”+code+”\n\n”
+ “对应15位号码为:\t”+code15+”\n\n”
+ “对应18位号码为:\t”+code18+”\n\n”
+ “所在地区:\t”+xzqhName+”\n\n”
+ “出生日期:\t”+year+”年 “+month+” 月 “+day+” 日\n\n”
+ “年龄:\t”+age+” 岁\n\n”
+ “性别:\t”+sex+”\n”;
alert(msg);
}

function getVerify(id){
var result;
var nNum=eval(id.charAt(0)*7+id.charAt(1)*9+id.charAt(2)*10+id.charAt(3)*5+id.charAt(4)*8+id.charAt(5)*4+id.charAt(6)*2+id.charAt(7)*1+id.charAt(8)*6+id.charAt(9)*3+id.charAt(10)*7+id.charAt(11)*9+id.charAt(12)*10+id.charAt(13)*5+id.charAt(14)*8+id.charAt(15)*4+id.charAt(16)*2);
nNum=nNum%11;
switch (nNum) {
case 0 :
result=”1″;
break;
case 1 :
result=”0″;
break;
case 2 :
result=”x”;
break;
case 3 :
result=”9″;
break;
case 4 :
result=”8″;
break;
case 5 :
result=”7″;
break;
case 6 :
result=”6″;
break;
case 7 :
result=”5″;
break;
case 8 :
result=”4″;
break;
case 9 :
result=”3″;
break;
case 10 :
result=”2″;
break;
}
return result;
}
//–>
</SCRIPT>
<FORM id=”idCard” METHOD=POST ACTION=”">

http://618119.com<br/>
身份证号码验证程序,行政区划数据来源为:最新县及县以上行政区划代码(截止2007年12月31日)<br/> http://www.stats.gov.cn/tjbz/xzqhdm/t20080215_402462675.htm<br/>
请输入15位或18位身份证号码:<br/>
<input type=”text” name=”idCode” id=”idCode” value=”" size=”18″ maxlength=”18″  /><br/>
<input type=”button” name=”codeSubmit” value=”提交” id=”codeSubmit” onclick=”checkId();”/> <br/>

Tags: javascript

Related posts

整理行政区划数据的几个操作步骤

星期六, 5月 31st, 2008

1.数据来源:
中华人民共和国统计局官方网站:

最新县及县以上行政区划代码(截止2007年12月31日)
http://www.stats.gov.cn/tjbz/xzqhdm/t20080215_402462675.htm

2.保存为文本文件。
3.使用EditPlus进行排序,再删除冗余信息
4.替换掉星号去掉 (*)和 (**)

5.替换空格,规整成javascript数组的形式.
需要替换的有” 县” ,空格个数从多到少的进行替换.

6.进行名称补全。
xxyyzz的,前面补上 xx0000和xxyy00的名字
然后xxyy00的,前面再补上xx0000的名字
这样每个行政区划代码对应的名称都是完整的了。

7.使用js进行控制,以生成各种想要的数据格式。

JavaScript代码在:

http://618119.com/docs/--escaped_anchor:e0dd5e818f3e8b2ef8dfd677654a4540--/xzqh.html

整理好的数据文本在:

http://618119.com/docs/--escaped_anchor:e0dd5e818f3e8b2ef8dfd677654a4540--/xzqh.txt

代码片段:

[code]

function getName(code){
var name=xzqh[code];
//如果不是00结尾的,则补上市名称,659000例外 429000,469000
if(code%100 != 0 && (code-code%100)!=659000 && (code-code%100)!=429000 && (code-code%100)!=469000){
var cityName=xzqh[(code-code%100)];
if(cityName.length>1){//过滤掉只有一个字的“县”
name=cityName+name;
}
}
//如果不是0000结尾的,再补上省名称
if(code%10000 != 0){
name=xzqh[(code-code%10000)]+name;
}
return name;
}

[/code]

数据节选:

110000|北京市
110100|北京市市辖区
110101|北京市市辖区东城区
110102|北京市市辖区西城区
110103|北京市市辖区崇文区
110104|北京市市辖区宣武区
110105|北京市市辖区朝阳区
110106|北京市市辖区丰台区
110107|北京市市辖区石景山区
110108|北京市市辖区海淀区
110109|北京市市辖区门头沟区
110111|北京市市辖区房山区
110112|北京市市辖区通州区
110113|北京市市辖区顺义区
110114|北京市市辖区昌平区
110115|北京市市辖区大兴区
110116|北京市市辖区怀柔区
110117|北京市市辖区平谷区
110200|北京市县
110228|北京市密云县
110229|北京市延庆县
120000|天津市
120100|天津市市辖区
120101|天津市市辖区和平区
120102|天津市市辖区河东区
120103|天津市市辖区河西区
120104|天津市市辖区南开区
120105|天津市市辖区河北区
120106|天津市市辖区红桥区
120107|天津市市辖区塘沽区
120108|天津市市辖区汉沽区
120109|天津市市辖区大港区
120110|天津市市辖区东丽区
120111|天津市市辖区西青区
120112|天津市市辖区津南区
120113|天津市市辖区北辰区
120114|天津市市辖区武清区
120115|天津市市辖区宝坻区
120200|天津市县
120221|天津市宁河县
120223|天津市静海县
120225|天津市蓟县

Tags: gis, javascript, 行政区划

Related posts