文章关键字 ‘javascript’

将google托管的ajax js文件同步到本地服务器

2010年04月14日,星期三
google提供了供全世界访问的公共javascript库托管,
参考:http://code.google.com/intl/zh-CN/apis/ajaxlibs/
只要使用 <script src=”http://www.google.com/jsapi”></script> 引用google的js,
然后使用 google.load() 方法,就可以指定载入对应库的对应版本。 例如:google.load(“jquery”, “1″);
就可以载入当前最新的jquery库。
虽然google承诺无限期地托管各版本的js文件,但是由于大部分人知道的原因,在国内使用这种方式共享js资源存在一定风险。
因此,我参考google对这些js的部署结构,将js下载回来放到了本地服务器。
目前托管的js库有以下组件:
jQuery
jQuery UI
Prototype
script.aculo.us
MooTools
Dojo
SWFObject
Yahoo! 用户界面库 (YUI)
Ext Core
全部都同步下来,操作步骤如下:
先在Firefox里打开:
http://www.google.com/jsapi
然后将js保存到成本地文件,然后用Aptana打开,并格式化,然后找到
google.loader.rpl,然后把括号里一段json对象复制出来,定义成  var jslibs;
然后通过js生成对应js的url。然后使用java下载到本地保存到对应目录。
代码参考:
<SCRIPT LANGUAGE=”JavaScript”>
<!–
var jslibs={
“:jquery” : {
“versions” : {
“:1.2.3″ : {
“uncompressed” : “jquery.js”,
“compressed” : “jquery.min.js”
},
“:1.3.1″ : {
“uncompressed” : “jquery.js”,
“compressed” : “jquery.min.js”
},
“:1.3.0″ : {
“uncompressed” : “jquery.js”,
“compressed” : “jquery.min.js”
},
“:1.3.2″ : {
“uncompressed” : “jquery.js”,
“compressed” : “jquery.min.js”
},
“:1.2.6″ : {
“uncompressed” : “jquery.js”,
“compressed” : “jquery.min.js”
},
“:1.4.0″ : {
“uncompressed” : “jquery.js”,
“compressed” : “jquery.min.js”
},
“:1.4.1″ : {
“uncompressed” : “jquery.js”,
“compressed” : “jquery.min.js”
},
“:1.4.2″ : {
“uncompressed” : “jquery.js”,
“compressed” : “jquery.min.js”
}
},
“aliases” : {
“:1″ : “1.4.2″,
“:1.4″ : “1.4.2″,
“:1.3″ : “1.3.2″,
“:1.2″ : “1.2.6″
}
}
}
//–>
</SCRIPT>
<TEXTAREA id=”urls” NAME=”urls” ROWS=”40″ COLS=”80″></TEXTAREA>
<SCRIPT LANGUAGE=”JavaScript”>
<!–
var urls=”";
for(var jslibName in jslibs){
var jslibList=jslibs[jslibName];
for(var jslibver in jslibList["versions"]){
var url1=”http://ajax.googleapis.com/ajax/libs/”+jslibName.replace(“:”,”")+”/”+jslibver.replace(“:”,”")+”/”+jslibList["versions"][jslibver]["uncompressed"];
var url2=”http://ajax.googleapis.com/ajax/libs/”+jslibName.replace(“:”,”")+”/”+jslibver.replace(“:”,”")+”/”+jslibList["versions"][jslibver]["compressed"];
urls=urls+”\n”+url1+”\n”+url2;
}
}
document.getElementById(“urls”).value=”String[] urlsStrings={”
+urls
+”};”
+”  for (int i = 0; i < urlsStrings.length; i++) {”
+”   try {”
+”    URL url = new URL(urlsStrings[i]);”
+”    File file = new File(\”E:/js\”, url.getPath());”
+”    file.getParentFile().mkdirs();”
+”    PrintWriter pw = new PrintWriter(file);”
+”    URLConnection urlc = url.openConnection();”
+”    urlc.setConnectTimeout(5000);”
+”    urlc.connect();”
+”    BufferedReader in = new BufferedReader(new InputStreamReader(”
+”      urlc.getInputStream(), \”UTF-8\”));”
+”    String line;”
+”    while ((line = in.readLine()) != null) {”
+”     pw.write(line);”
+”     // sb.append(line).append(‘\n’);”
+”    }”
+”    pw.close();”
+”    in.close();”
+”   } catch (Exception e) {”
+”    e.printStackTrace();”
+”   }”;
//–>
</SCRIPT>
Tags: ajax, google, javascript

Related posts

javascript实现身份证号码的验证

2008年06月4日,星期三

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

源文件在: http://618119.com/docs/gis/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

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

2008年05月31日,星期六

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/gis/xzqh.html

整理好的数据文本在:

http://618119.com/docs/gis/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