首页 > 编程技术 > php

php 总结数值计算的注意事项

发布时间:2016-11-25 17:17

php数值计算有一些结果可能并不是我们想的那样但它这样计算有自己的理论基础了,下面我们来看一篇php 总结数值计算的注意事项吧。


一:四舍五入

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接口即可生成自己要的地址了,下面来看一些小编总结的例子。

新浪短网址接口的稳定性和跳转速度还是很给力的,现给出其API说明。
该接口支持两种返回格式:xml和json

对应的URL请求地址为:

 代码如下 复制代码

xml:http://api.t.sina.com.cn/short_url/shorten.xml
json:http://api.t.sina.com.cn/short_url/shorten.json

使用说明

请求方式: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>
     <url>
          <url_short>http://t.cn/123456789</url_short>
          <url_long>=https://www.111cn.net</url_long>
          <type>0</type>
     </url>
</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
session_start();
$allow_sep = '2';
if (isset($_SESSION['post_sep'])) {
    if (time() - $_SESSION['post_sep'] < $allow_sep) {
        die('请不要频繁刷新,休息2秒再刷新吧');
    } else {
        $_SESSION['post_sep'] = time();
    }
} else {
    $_SESSION['post_sep'] = time();
}
?>

php原始做法

 代码如下 复制代码

#短连接生成算法
  
    class Short_Url {
        #字符表
        public static $charset = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";

        public static function short($url) {
            $key = "alexis";
            $urlhash = md5($key . $url);
            $len = strlen($urlhash);

            #将加密后的串分成4段,每段4字节,对每段进行计算,一共可以生成四组短连接
            for ($i = 0; $i < 4; $i++) {
                $urlhash_piece = substr($urlhash, $i * $len / 4, $len / 4);
                #将分段的位与0x3fffffff做位与,0x3fffffff表示二进制数的30个1,即30位以后的加密串都归零
                $hex = hexdec($urlhash_piece) & 0x3fffffff; #此处需要用到hexdec()将16进制字符串转为10进制数值型,否则运算会不正常

                $short_url = "http://t.cn/";
                #生成6位短连接
                for ($j = 0; $j < 6; $j++) {
                    #将得到的值与0x0000003d,3d为61,即charset的坐标最大值
                    $short_url .= self::$charset[$hex & 0x0000003d];
                    #循环完以后将hex右移5位
                    $hex = $hex >> 5;
                }

                $short_url_list[] = $short_url;
            }

            return $short_url_list;
        }
    }

    $url = http://www.111cn.net;
    $short = Short_Url::short($url);
    print_r($short);

********************************

调用方法:

 代码如下 复制代码

    $short = Short_Url::short('www.baidu.com');
    var_dump($short);
    //省略链接memcache
    $memcache->set($cacheKey.$short[0],“原始地址”);

magento在服务器中配置域名是可以正常的访问了,但是有朋友发现magento在本地配置如192.168.1.1这种无法登录了,下面一起来看看如何处理此问题。

在本地安装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();
// }

标签:[!--infotagslink--]

您可能感兴趣的文章: