这几天一直在弄 Ucenter 同步登陆的问题,才仔细发现,其实同步登陆就是远程执行了 js脚本。。。
string uc_user_synlogout()
string uc_user_synlogin(integer uid)
返回的类型都是字符串,所以返回的字符串一定要在 网页中输出 才可同步。最好网页在进行延时。 继续阅读
这几天一直在弄 Ucenter 同步登陆的问题,才仔细发现,其实同步登陆就是远程执行了 js脚本。。。
string uc_user_synlogout()
string uc_user_synlogin(integer uid)
返回的类型都是字符串,所以返回的字符串一定要在 网页中输出 才可同步。最好网页在进行延时。 继续阅读
用的是 python2.7的版本,好像对中文支持不是很好。
先来看一个python2编码的例子
# coding: UTF-8 u = u'汉' print repr(u) # u'\u6c49' s = u.encode('UTF-8') print repr(s) # '\xe6\xb1\x89' u2 = s.decode('UTF-8') print repr(u2) # u'\u6c49' # 对unicode进行解码是错误的 # s2 = u.decode('UTF-8') # 同样,对str进行编码也是错误的 # u2 = s.encode('UTF-8')
网上看到一个,直接点用 validId(num) 函数就行。。。代码贴出来分享学习
var powers=new Array("7","9","10","5","8","4","2","1","6","3","7","9","10","5","8","4","2"); var parityBit=new Array("1","0","X","9","8","7","6","5","4","3","2"); //校验18位的身份证号码 function validId18(_id){ _id=_id+""; var _num=_id.substr(0,17); var _parityBit=_id.substr(17); var _power=0; for(var i=0;i< 17;i++){ //校验每一位的合法性 if(_num.charAt(i)<'0'||_num.charAt(i)>'9'){ return false; break; }else{ //加权 _power+=parseInt(_num.charAt(i))*parseInt(powers[i]); //设置性别 if(i==16&&parseInt(_num.charAt(i))%2==0){ sex="female"; }else{ sex="male"; } } } //取模 var mod=parseInt(_power)%11; if(parityBit[mod]==_parityBit){ return true; } return false; } //校验15位的身份证号码 function validId15(_id){ _id=_id+""; for(var i=0;i<_id.length;i++){ //校验每一位的合法性 if(_id.charAt(i)<'0'||_id.charAt(i)>'9'){ return false; break; } } var year=_id.substr(6,2); var month=_id.substr(8,2); var day=_id.substr(10,2); var sexBit=_id.substr(14); //校验年份位 if(year<'01'||year >'90')return false; //校验月份 if(month<'01'||month >'12')return false; //校验日 if(day<'01'||day >'31')return false; return true; } //这个可以验证15位和18位的身份证,并且包含生日和校验位的验证。 //如果有兴趣,还可以加上身份证所在地的验证,就是前6位有些数字合法有些数字不合法。 function validId(num) { num = num.toUpperCase(); //身份证号码为15位或者18位,15位时全为数字,18位前17位为数字,最后一位是校验位,可能为数字或字符X。 if (!(/(^\d{15}$)|(^\d{17}([0-9]|X)$)/.test(num))) { return false; } //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。 //下面分别分析出生日期和校验位 var len, re; len = num.length; if (len == 15) { re = new RegExp(/^(\d{6})(\d{2})(\d{2})(\d{2})(\d{3})$/); var arrSplit = num.match(re); //检查生日日期是否正确 var dtmBirth = new Date('19' + arrSplit[2] + '/' + arrSplit[3] + '/' + arrSplit[4]); var bGoodDay; bGoodDay = (dtmBirth.getYear() == Number(arrSplit[2])) && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3])) && (dtmBirth.getDate() == Number(arrSplit[4])); if (!bGoodDay) { return false; } else { //将15位身份证转成18位 //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。 var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2); var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'); var nTemp = 0, i; num = num.substr(0, 6) + '19' + num.substr(6, num.length - 6); for(i = 0; i < 17; i ++) { nTemp += num.substr(i, 1) * arrInt[i]; } num += arrCh[nTemp % 11]; return num; } } if (len == 18) { re = new RegExp(/^(\d{6})(\d{4})(\d{2})(\d{2})(\d{3})([0-9]|X)$/); var arrSplit = num.match(re); //检查生日日期是否正确 var dtmBirth = new Date(arrSplit[2] + "/" + arrSplit[3] + "/" + arrSplit[4]); var bGoodDay; bGoodDay = (dtmBirth.getFullYear() == Number(arrSplit[2])) && ((dtmBirth.getMonth() + 1) == Number(arrSplit[3])) && (dtmBirth.getDate() == Number(arrSplit[4])); if (!bGoodDay) { return false; } else { //检验18位身份证的校验码是否正确。 //校验位按照ISO 7064:1983.MOD 11-2的规定生成,X可以认为是数字10。 var valnum; var arrInt = new Array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2); var arrCh = new Array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'); var nTemp = 0, i; for(i = 0; i < 17; i ++) { nTemp += num.substr(i, 1) * arrInt[i]; } valnum = arrCh[nTemp % 11]; if (valnum != num.substr(17, 1)) { return false; } return num; } } return false; }
继上一篇 《Linux用crontabs做MySQL本地备份》 之后,这次换做异地备份
本来想用rsync来做备份,但是用rsync需要另外在开一个端口,免得麻烦所以选择scp,scp用来做 mysql异地备份还是够用了。。。
首先让本地的服务器登陆线上ssh免密码
用root登陆本地服务器,输入
ssh-keygen -t rsa 继续阅读
和两天数据库服务器出了点问题,突然打不开,还担心是硬盘坏了。结果问机房的半天才给答复,说是机房停电。。。坑爹
不过这次停电也敲了下警钟,要有备份的意识啊。。。
线上mysql服务器是Linux的,就记录下 linux下的mysql备份,Let’s go!!!
线上服务器是最小化安装的 CentOS6,没有自带crontab,所以要自己装个,并设置好自启动。 继续阅读
cd /etc/apt/
sudo wget http://mirrors.163.com/.help/sources.list.hardy #Ubuntu 8.04
sudo wget http://mirrors.163.com/.help/sources.list.lucid #Ubuntu 10.04
sudo wget http://mirrors.163.com/.help/sources.list.maverick #Ubuntu 10.10
sudo wget http://mirrors.163.com/.help/sources.list.natty #Ubuntu 11.04
sudo wget http://mirrors.163.com/.help/sources.list.oneiric #Ubuntu 11.10
sudo wget http://mirrors.163.com/.help/sources.list.precise #Ubuntu 12.04
#备份
sudo mv sources.list sources.list.bak
#xxxxx为对应的版本
sudo mv sources.list.xxxxx sources.list
jQuery操作cookie的插件,大概的使用方法如下
$.cookie(‘the_cookie’); //读取Cookie值
$.cookie(’the_cookie’, ‘the_value’); //设置cookie的值
$.cookie(’the_cookie’, ‘the_value’, {expires: 7, path: ‘/’, domain: ‘jquery.com’, secure: true});//新建一个cookie 包括有效期 路径 域名等
$.cookie(’the_cookie’, ‘the_value’); //新建cookie
$.cookie(’the_cookie’, null); //删除一个cookie
最近在尝试使用Python进行采集,感觉还不错。。。但是采集多了想进行一下延时,发现只有sleep函数,php里面有个 usleep 函数进行毫秒级的休眠,然后百度了一下,原来在Python中的sleep函数可以传小数进去,就可以进行毫秒级的延时了
# 例1:循环输出休眠1秒 import time i = 1 while i <= 3: print i # 输出i i += 1 time.sleep(1) # 休眠1秒 # 例1:循环输出休眠100毫秒 import time i = 1 while i <= 3: print i # 输出i i += 1 time.sleep(0.1) # 休眠0.1秒
在很多场合为了显示出信息的及时性,一般会将时间显示成“刚刚”,“5分钟前”,“3小时前”等,而不是直接将时间打印出来。比如微博,SNS类应用就最长用到这个功能。而一般存储在数据库中的时间格式为 Unix时间戳,所以这里记录一个将 Unix时间戳 转化为时间轴显示的PHP函数。 继续阅读
linux下ping包的默认大小为64Byte,次数不限。但有时我们需要尝试ping大数据包,来测试网络的状况,这时,就要指定ping包的大小了。
Linux下ping大数据包的格式;
语 法:ping [-dfnqrRv][-c<完成次数>][-i<间隔秒数>][-I<网络界面>][-l<前置载入>][-p<范本样式>][-s<数据包大小>][-t<存活数值>][主机名称或IP地址]
例如:
1. 指定数据包大小为1500Byte:ping -s 1500 ip
2. 指定次数为4次,数据包大小为32767Byte:ping -c 4 -s 32767 ip 继续阅读