一:四舍五入
1.round — 对浮点数进行四舍五入
float round ( float $val [, int $precision ] )
2:floor — 舍去法取整(向下取整)
float floor ( float $value )
3.ceil — 进一法取整(向上取整)
float ceil ( float $value )
坑点: 当数值为整数的时候 例如 11 那么floor(11) = 10 , ceil (11) = 12; 问题显而易见,所以计算的时候要格外注意这一点,解决方法 floor(11 + 0.01);
二:整数和小数相乘除
坑点:3.5 * 100 = 300 ,就算你数学再好也没用,在php世界里这就是真理。
解决方法就是将整型变成浮点型 3.5 * (float)100 = 350
三:浮点数的怪异
坑点:8.50 – 8 = 0.500000001 其实原因和2差不多, 解决方法:将结果进行round(),提高精度即可
身份证号码中的校验码是身份证号码的最后一位,是根据中华人民共和国国家标准GB 11643-1999中有关公民身份号码的规定,根据精密的计算公式计算出来的,我们下面来看利用PHP计算身份证校验码示例,具体的细节如下介绍。中国(大陆)公民身份证号码每一位所代表的意义,网上很多文章都有介绍,在此就不多说。其中身份证号码的最后一位是校验码,跟据前17位计算得到。算法大 概是这样:把前17位的每一个数字和一串加权因子相乘,再计算这些乘积的和;把这些乘积的和模11得到的数字作为序号,最后在一个校验码串中提取出与序号 相对应的字符。当然,网上也有不少的文章教大家计算这个校验码,下面我们将尝试用PHP语言来完成这一工作,也许可以用于PHP开发中,如校验用户的身份 证号码是否正确。
假设某中国(大陆)公民的身份证号码前17位是这个:44010221990101001(注:此人出生于2199年),那么我们跟据上面的算法尝试写几行PHP代码来完成校验码的计算。为了能让大家更容易理解,我使用了较简单的语句,请看代码:
代码如下 | 复制代码 |
<?php //身份证号码前17位,可以从各种数据源中获得(如数据库、用户提交的表单等) $body = '44010221990101001'; //加权因子 $wi = array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2); //校验码串 $ai = array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'); //按顺序循环处理前17位 for ($i = 0;$i < 17;$i++) { //提取前17位的其中一位,并将变量类型转为实数 $b = (int) $body{$i}; //提取相应的加权因子 $w = $wi[$i]; //把从身份证号码中提取的一位数字和加权因子相乘,并累加 $sigma += $b * $w; } //计算序号 $number = $sigma % 11; //按照序号从校验码串中提取相应的字符。 $check_number = $ai[$number]; //输出 echo $body.$check_number; ?> |
运行以上代码之后,可以算出该身份证的校验码为9。大家可以用自己身份证的前17位试试。
如果你明白上面的例子的话,就可以把这段代码的一些语句合并,去除没必要的变量,优化得到如下代码:
代码如下 | 复制代码 |
<?php $body = '44010221990101001'; $wi = array(7, 9, 10, 5, 8, 4, 2, 1, 6, 3, 7, 9, 10, 5, 8, 4, 2); $ai = array('1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'); for ($i = 0;$i < 17;$i++) { $sigma += ((int) $body{$i}) * $wi[$i]; } echo $body.$ai[($sigma % 11)]; ?> |
新浪短网址接口的稳定性和跳转速度还是很给力的,现给出其API说明。
该接口支持两种返回格式:xml和json
对应的URL请求地址为:
代码如下 | 复制代码 |
xml:http://api.t.sina.com.cn/short_url/shorten.xml |
使用说明
请求方式:GET
请求参数:
source:应用的appkey
url_long:需要转换的长链接
举个例子:
代码如下 | 复制代码 |
xml:http://api.t.sina.com.cn/short_url/shorten.xml?source=123456789&url_long==https://www.111cn.net 返回内容为: <urls> json:http://api.t.sina.com.cn/short_url/shorten.json?source=123456789&url_long=https://www.111cn.net |
返回内容为:
[{"url_short":"http://t.cn/123456789","url_long":https://www.111cn.net","type":0}]
代码如下 | 复制代码 |
<?php |
php原始做法
代码如下 | 复制代码 |
#短连接生成算法 public static function short($url) { #将加密后的串分成4段,每段4字节,对每段进行计算,一共可以生成四组短连接 $short_url = "http://t.cn/"; $short_url_list[] = $short_url; return $short_url_list; $url = http://www.111cn.net; ******************************** |
调用方法:
代码如下 | 复制代码 |
$short = Short_Url::short('www.baidu.com'); |
在本地安装magento后,账号密码登录的时候发现出现空白,无法跳转到后台。
如何解决?
解决方法一:
这是一个cookie问题,使用firefox等非IE核心浏览器可以解决这个问题,虽然浏览器处理cookie的方式很相似但并不是100%相同, Magento其它的版本也有这个问题。
详细的修正这个问题的方法是定位到: app/code/core/Mage/Core/Model/Session/Abstract/Varien.php 。
大约在70行左右你可以看到类似的:
// set session cookie params
session_set_cookie_params(
$this->getCookie()->getLifetime(),
$this->getCookie()->getPath() // 注释掉后面或删除
解决方法二:
不用localhost登陆,
改为你的IP地址登陆:例如http://192.168.1.100/加后台地址,
也可以到apache里指向其它地址,
在服务器上一般不会出现这问题,不用修改。
magento1.9 后台无法登陆问题
打开 magento/app/code/core/Mage/Core/Model/Session/Abstract/varien.php
找到下面的代码,注释掉$cookieParams['domain'] = $cookie->getDomain();这行,就行了。
if (isset($cookieParams['domain'])) {
$cookieParams['domain'] = $cookie->getDomain();
}
结果如下
if (isset($cookieParams['domain'])) {
//$cookieParams['domain'] = $cookie->getDomain();
}
但是按照这个去做之后,还是出现错误,于是我把下面这段全部注释掉
//if (isset($cookieParams['domain'])) {
//$cookieParams['domain'] = $cookie->getDomain();
// }