使用ECshop做二次开发,自己写的模板调用商品列表时,有时会出现空商品的情况,即明明没有这个商品,却多出一个商品位置来,而该商品的链接,名字,图片等都是空的。
出现这种情况的原因是调用foreach或section时没有判断数组是否为空,数组中的元素是否为空。
所以规范的做法是,调用foreach前判断数组是否为空,调用其元素时判断字段是否为空。
写其它程序时也应该养成这种习惯。
使用ECshop做二次开发,自己写的模板调用商品列表时,有时会出现空商品的情况,即明明没有这个商品,却多出一个商品位置来,而该商品的链接,名字,图片等都是空的。
出现这种情况的原因是调用foreach或section时没有判断数组是否为空,数组中的元素是否为空。
所以规范的做法是,调用foreach前判断数组是否为空,调用其元素时判断字段是否为空。
写其它程序时也应该养成这种习惯。
近期对我的下载站做了个改进,针对手机平板等移动设备取消了每25秒只能下载一个文件的限制,通过PHP判断user-agent实现的。
代码:
其实用的是穷举法,列出所有的移动平台并加以判断。
function isMobile(){ $agent = $_SERVER['HTTP_USER_AGENT']; if(strpos($agent,"NetFront") || strpos($agent,"iPhone") || strpos($agent,"MIDP-2.0") || strpos($agent,"Opera Mini") || strpos($agent,"UCWEB") || strpos($agent,"Android") || strpos($agent, "Windows CE") || strpos($agent,"SymbianOS")) { return true; } else{ return false; }
收集了些PHP常用正则表达式,不会时可以查查看看。
1。[size=12px]1。^d+$ //匹配非负整数(正整数 + 0)
2。^[0-9]*[1-9][0-9]*$ //匹配正整数
3。^((-d+)|(0+))$ //匹配非正整数(负整数 + 0)
4。^-[0-9]*[1-9][0-9]*$ //匹配负整数
5。^-?d+$ //匹配整数
6。^d+(.d+)?$ //匹配非负浮点数(正浮点数 + 0)
7。^(([0-9]+.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*.[0-9]+)|([0-9]*[1-9][0-9]*))$ //匹配正浮点数
8。^((-d+(.d+)?)|(0+(.0+)?))$ //匹配非正浮点数(负浮点数 + 0)
9。^(-(([0-9]+.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*.[0-9]+)|([0-9]*[1-9][0-9]*)))$ //匹配负浮点数
10。^(-?d+)(.d+)?$ //匹配浮点数
11。^[A-Za-z]+$ //匹配由26个英文字母组成的字符串
12。^[A-Z]+$ //匹配由26个英文字母的大写组成的字符串
13。^[a-z]+$ //匹配由26个英文字母的小写组成的字符串
14。^[A-Za-z0-9]+$ //匹配由数字和26个英文字母组成的字符串
15。^w+$ //匹配由数字、26个英文字母或者下划线组成的字符串
16。^[w-]+(.[w-]+)*@[w-]+(.[w-]+)+$ //匹配email地址
17。^[a-zA-z]+://匹配(w+(-w+)*)(.(w+(-w+)*))*(?S*)?$ //匹配url
18。匹配中文字符的正则表达式: [u4e00-u9fa5]
19。匹配双字节字符(包括汉字在内):[^x00-xff]
20。应用:计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
String.prototype.len=function(){return this.replace([^x00-xff]/g,”aa”).length;}
21。匹配空行的正则表达式:n[s| ]*r
22。匹配HTML标记的正则表达式:/<(.*)>.*</1>|<(.*) />/
23。匹配首尾空格的正则表达式:(^s*)|(s*$)
* 正则表达式用例
* 1、 ^S+[a-z A-Z]$ 不能为空 不能有空格 只能是英文字母
* 2、 S{6,} 不能为空 六位以上
* 3、 ^d+$ 不能有空格 不能非数字
* 4、 (.*)(.jpg|.bmp)$ 只能是jpg和bmp格式
* 5、 ^d{4}-d{1,2}-d{1,2}$ 只能是2004-10-22格式
* 6、 ^0$ 至少选一项
* 7、 ^0{2,}$ 至少选两项
* 8、 ^[s|S]{20,}$ 不能为空 二十字以上
* 9、 ^+?[a-z0-9](([-+.]|[_]+)?[a-z0-9]+)*@([a-z0-9]+(.|-))+[a-z]{2,6}$邮件
* 10、 w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*([,;]s*w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*)* 输入多个地址用逗号或空格分隔邮件
* 11、 ^(([0-9]+))?[0-9]{7,8}$电话号码7位或8位或前面有区号例如(022)87341628
* 12、 ^[a-z A-Z 0-9 _]+@[a-z A-Z 0-9 _]+(.[a-z A-Z 0-9 _]+)+(,[a-z A-Z 0-9 _]+@[a-z A-Z
0-9 _]+(.[a-z A-Z 0-9 _]+)+)*$
* 只能是字母、数字、下划线;必须有@和.同时格式要规范 邮件
* 13 ^w+@w+(.w+)+(,w+@w+(.w+)+)*$上面表达式也可以写成这样子,更精练。
14 ^w+((-w+)|(.w+))*@w+((.|-)w+)*.w+$ [/size]
匹配中文字符的正则表达式: [u4e00-u9fa5]
评注:匹配中文还真是个头疼的事,有了这个表达式就好办了
匹配双字节字符(包括汉字在内):[^x00-xff]
评注:可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
匹配空白行的正则表达式:ns*r
评注:可以用来删除空白行
匹配HTML标记的正则表达式: <(S*?)[^>]*>.*? | <.*? />
评注:网上流传的版本太糟糕,上面这个也仅仅能匹配部分,对于复杂的嵌套标记依旧无能为力
匹配首尾空白字符的正则表达式:^s* |s*$
评注:可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式
匹配Email地址的正则表达式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*
评注:表单验证时很实用
匹配网址URL的正则表达式:[a-zA-z]+://[^s]*
评注:网上流传的版本功能很有限,上面这个基本可以满足需求
匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
评注:表单验证时很实用
匹配国内电话号码:d{3}-d{8} |d{4}-d{7}
评注:匹配形式如 0511-4405222 或 021-87888822
匹配腾讯QQ号:[1-9][0-9]{4,}
评注:腾讯QQ号从10000开始
匹配中国邮政编码:[1-9]d{5}(?!d)
评注:中国邮政编码为6位数字
匹配身份证:d{15} |d{18}
评注:中国的身份证为15位或18位
匹配ip地址:d+.d+.d+.d+
评注:提取ip地址时有用
匹配特定数字:
^[1-9]d*$ //匹配正整数
^-[1-9]d*$ //匹配负整数
^-?[1-9]d*$ //匹配整数
^[1-9]d* |0$ //匹配非负整数(正整数 + 0)
^-[1-9]d* |0$ //匹配非正整数(负整数 + 0)
^[1-9]d*.d* |0.d*[1-9]d*$ //匹配正浮点数
^-([1-9]d*.d* |0.d*[1-9]d*)$ //匹配负浮点数
^-?([1-9]d*.d* |0.d*[1-9]d* |0?.0+ |0)$ //匹配浮点数
^[1-9]d*.d* |0.d*[1-9]d* |0?.0+ |0$ //匹配非负浮点数(正浮点数 + 0)
^(-([1-9]d*.d* |0.d*[1-9]d*)) |0?.0+ |0$ //匹配非正浮点数(负浮点数 + 0)
评注:处理大量数据时有用,具体应用时注意修正
匹配特定字符串:
^[A-Za-z]+$ //匹配由26个英文字母组成的字符串
^[A-Z]+$ //匹配由26个英文字母的大写组成的字符串
^[a-z]+$ //匹配由26个英文字母的小写组成的字符串
^[A-Za-z0-9]+$ //匹配由数字和26个英文字母组成的字符串
^w+$ //匹配由数字、26个英文字母或者下划线组成的字符串
“^[\w-]+([url=file://\.[\w-]+)*@[\w-]+(\.[\w-]+)+___FCKpd___0quot]\.[\w-]+)*@[\w-]+(\.[\w-]+)+___FCKpd___0quot[/url]; //email地址
“^[a-zA-z]+://([url=file://\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?___FCKpd___0quot]\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?___FCKpd___0quot[/url]; //url
匹配中文字符的正则表达式: [u4e00-u9fa5]
评注:匹配中文还真是个头疼的事,有了这个表达式就好办了
匹配双字节字符(包括汉字在内):[^x00-xff]
评注:可以用来计算字符串的长度(一个双字节字符长度计2,ASCII字符计1)
匹配空白行的正则表达式:ns*r
评注:可以用来删除空白行
匹配HTML标记的正则表达式: <(S*?)[^>]*>.*? | <.*? />
评注:网上流传的版本太糟糕,上面这个也仅仅能匹配部分,对于复杂的嵌套标记依旧无能为力
匹配首尾空白字符的正则表达式:^s* |s*$
评注:可以用来删除行首行尾的空白字符(包括空格、制表符、换页符等等),非常有用的表达式
!!!匹配Email地址的正则表达式:w+([-+.]w+)*@w+([-.]w+)*.w+([-.]w+)*
评注:表单验证时很实用
匹配网址URL的正则表达式:[a-zA-z]+://[^s]*
评注:网上流传的版本功能很有限,上面这个基本可以满足需求
匹配帐号是否合法(字母开头,允许5-16字节,允许字母数字下划线):^[a-zA-Z][a-zA-Z0-9_]{4,15}$
评注:表单验证时很实用
匹配国内电话号码:d{3}-d{8} |d{4}-d{7}
评注:匹配形式如 0511-4405222 或 021-87888822
匹配腾讯QQ号:[1-9][0-9]{4,}
评注:腾讯QQ号从10000开始
!!!匹配中国邮政编码:[1-9]d{5}(?!d)
评注:中国邮政编码为6位数字
匹配身份证:d{15} |d{18}
评注:中国的身份证为15位或18位
匹配ip地址:d+.d+.d+.d+
评注:提取ip地址时有用
匹配特定数字:
^[1-9]d*$ //匹配正整数
^-[1-9]d*$ //匹配负整数
^-?[1-9]d*$ //匹配整数
^[1-9]d* |0$ //匹配非负整数(正整数 + 0)
^-[1-9]d* |0$ //匹配非正整数(负整数 + 0)
^[1-9]d*.d* |0.d*[1-9]d*$ //匹配正浮点数
^-([1-9]d*.d* |0.d*[1-9]d*)$ //匹配负浮点数
^-?([1-9]d*.d* |0.d*[1-9]d* |0?.0+ |0)$ //匹配浮点数
^[1-9]d*.d* |0.d*[1-9]d* |0?.0+ |0$ //匹配非负浮点数(正浮点数 + 0)
^(-([1-9]d*.d* |0.d*[1-9]d*)) |0?.0+ |0$ //匹配非正浮点数(负浮点数 + 0)
评注:处理大量数据时有用,具体应用时注意修正
匹配特定字符串:
^[A-Za-z]+$ //匹配由26个英文字母组成的字符串
^[A-Z]+$ //匹配由26个英文字母的大写组成的字符串
^[a-z]+$ //匹配由26个英文字母的小写组成的字符串
^[A-Za-z0-9]+$ //匹配由数字和26个英文字母组成的字符串
^w+$ //匹配由数字、26个英文字母或者下划线组成的字符串
“^[\w-]+([url=file://\.[\w-]+)*@[\w-]+(\.[\w-]+)+___FCKpd___0quot]\.[\w-]+)*@[\w-]+(\.[\w-]+)+___FCKpd___0quot[/url]; //email地址
“^[a-zA-z]+://([url=file://\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?___FCKpd___0quot]\w+(-\w+)*)(\.(\w+(-\w+)*))*(\?\S*)?___FCKpd___0quot[/url]; //urlview
plaincopy to clipboardprint?
正则几个基本概念:
1.贪婪:+,*,?,{m,n}等默认是贪婪匹配,即尽可能多匹配,也叫最大匹配
2.获取:默认用(x |y)是获取匹配,很多时候只是测试,不一定要求得到所匹配的数据,尤其在嵌套匹配
或大数据中就要用非获取匹配(?:x |y),这样提高了效率,优化了程序。
3.消耗:默认是消耗匹配,一般在预查中是非消耗匹配。
举个例子,2003-2-8要变为2003-02-08
如果用/-(d)-/第二次匹配将从8开始,从而只替换第一个2,错误
如果用/-(d)(?=-)/则第二次匹配从第二个-开始,即不消耗字符
4.预查:js中分为正向预查和负向预查
如上面的(?=pattern)是正向预查,在任何匹配 pattern 的字符串开始处匹配查找字符串。还有(?!
pattern)是负向预查,在任何不匹配 pattern 的字符串开始处匹配查找字符串。负向预查有时会用在对
[^]的扩充,[^]只是一些字符,而?!可以使整个字符串。
5.回调:一般用在替换上,即根据不用的匹配内容返回不用的替换值,从而简化了程序,需要高版本支持
6.引用:num 对所获取的第num个匹配的引用。
例如,’(.)11′ 匹配AAA型。’(.)(.)21′ 匹配ABBA型。
正则表达式保留字
^ (carat)
. (period)
[ (left bracket}
$ (dollar sign)
( (left parenthesis)
) (right parenthesis)
| (pipe)
* (asterisk)
+ (plus symbol)
? (question mark)
{ (left curly bracket, or left brace)
构造 匹配于
字符
x 字符 x
\ 反斜线字符
n 八进制值的字符0n (0 <= n <= 7)
nn 八进制值的字符 0nn (0 <= n <= 7)
mnn 八进制值的字符0mnn 0mnn (0 <= m <= 3, 0 <= n <= 7)
xhh 十六进制值的字符0xhh
uhhhh 十六进制值的字符0xhhhh
t 制表符(‘u0009’)
n 换行符 (‘u000A’)
r 回车符 (‘u000D’)
f 换页符 (‘u000C’)
a 响铃符 (‘u0007’)
e 转义符 (‘u001B’)
cx T对应于x的控制字符 x
字符类
[abc] a, b, or c (简单类)
[^abc] 除了a、b或c之外的任意 字符(求反)
[a-zA-Z] a到z或A到Z ,包含(范围)
[a-z-[bc]] a到z,除了b和c : [ad-z](减去)
[a-z-[m-p]] a到z,除了m到 p: [a-lq-z]
[a-z-[^def]] d, e, 或 f
预定义的字符类
. 任意字符(也许能与行终止符匹配,也许不能)
d 数字: [0-9]
D 非数字: [^0-9]
s 空格符: [ tnx0Bfr]
S 非空格符: [^s]
w 单词字符: [a-zA-Z_0-9]
W 非单词字符: [^w]
之前曾经写过一遍关于PHP读取EXCEL时出现中文乱码的解决办法的文章,里面给出一个函数,可以进行编码转换,不过
那个方法不是太好,每次都得对单元格使用那个函数,而且偶尔还是会有乱码。
原理就不分析了,直接给出解决办法。
其实我用的EXCEL读取类类名是Spreadsheet_Excel_Reader,它本身支持设置输出的编码,以前一直没发现。
设置方法:
$myReader = new Spreadsheet_Excel_Reader(); $myReader->setOutputEncoding('GBK'); //GBK或者GB2312 $myReader->read("1.xls");
相比原来只添加了第二行代码,而且一劳永逸。
也有人说这样设置
$myReader = new Spreadsheet_Excel_Reader("1.xls",true,"GBK");
经测试,不管用,可能这个类的版本问题吧。
另外附上PHP excelreader类的下载链接
location / { root /usr/share/nginx/html/blog.kiccp.com; index index.php index.html index.htm; try_files $uri $uri/ /index.php?$args; } location ~* .(js|css|png|jpg|jpeg|gif|ico)$ { root /usr/share/nginx/html/blog.kiccp.com; expires 24h; log_not_found off; }
php等比缩放图片并计算其margin,适用于处理宽高比例不一致但要求显示一致的图片场合。
/* * 等比缩放图片并计算其margin * @param $picpath 图片路径 * @param $pwidth 要显示的宽度 * @param $pheight 要显示的高度 * @return array 宽高,margin的top和left(bottom=top,right=left) */ function resizeImageWHM($picpath,$pwidth,$pheight){ $imginfo=getimagesize($picpath); $owidth=$imginfo[0]; $oheight=$imginfo[1]; $ra=number_format(($owidth/$pwidth),3);//宽比 $ra2=number_format(($oheight/$pheight),3);//高比 if($owidth>$pwidth && $oheight>$pheight){ if($ra>=$ra2){ $width=round($owidth/$ra);; $height=round($oheight/$ra); }else{ $width=round($owidth/$ra2); $height=round($oheight/$ra2); } }else{ $width=$owidth; $height=$oheight; } $margin_top=0; if($height<$pheight){ $margin_top=round(($pheight-$height)/2); } $margin_left=0; if($width<$pwidth){ $margin_left=round(($pwidth-$width)/2); } $newsize['width']=$width; $newsize['height']=$height; $newsize['margin_top']=$margin_top; $newsize['margin_left']=$margin_left; return $newsize; }
在PHP官网上找到的一个获取MySQL数据表的结构信息的函数,稍微改进了下,替换掉过时的ereg函数。现在
这个函数比mysql_list_fields要强大,它能获取到集合结构(set)字段的所有值,这在生成HTML时是非常
有用的。
上代码:
function GetFieldInfo($table) { global $cfg_dbname,$cfg_dbhost,$cfg_dbuser,$cfg_dbpwd; $con = mysql_connect($cfg_dbhost, $cfg_dbuser, $cfg_dbpwd); if (!$con) { die('Could not connect: ' . mysql_error()); } $db_selected = mysql_select_db($cfg_dbname,$con); mysql_query("set names utf8"); if($table == '') return false; $fields = mysql_list_fields($cfg_dbname, $table); if($fields){ $columns = mysql_query('show columns from ' . $table); if($columns){ $num = mysql_num_fields($fields); for($i=0; $i < $num; ++$i){ $column = mysql_fetch_array($columns); $field = mysql_fetch_field($fields, $i); $flags = mysql_field_flags($fields, $i); if($flags == '') $flags=array(); else $flags = explode(' ',$flags); if (preg_match('/enum.(.*)./',$column['Type'],$match)) $field->values = explode(',',$match[1]); if (preg_match('/set.(.*)./',$column['Type'],$match)) $field->values = explode(',',$match[1]); if(!$field->values) $field->values = array(); $field->flags = $flags; $field->len = mysql_field_len($fields, $i); $result_fields[$field->name] = $field; $result_fields[$i] = $field; } mysql_free_result($columns); } mysql_free_result($fields); return $result_fields; } return false; }
分享ThinkPHP的几个小知识点:
1. URL中隐藏模块Home名称
define(‘BIND_MODULE’,’Home’);
2. 自定义函数库置于 /Common/Common目录下,需要在项目的配置文件中配置加载该函数库
/Conf/config.php, 添加 “LOAD_EXT_FILE”=>”common” ,则会自动加载 common.php
3. 模型新增数据使用 add ,更新时使用 save
刚才花了一个半小时的时间在三台CentOS 6系统下使用Nginx作了一次负载均衡的实战。入口是Nginx,后台可以是apache也可以是Nginx,端口可以自定义。
实验环境 :
Server1 192.168.0.100 :
用途: 入口服务器,负载均衡服务器
环境: CentOS 6 + Nginx + PHP(php-fpm)
端口: 80
Server2 192.168.0.101 :
用途:一般的后台服务器
环境:CentOS 6 + Apache + PHP
端口:80
Server3 192.168.0.102 :
用途:一般的后台服务器
环境:CentOS 6 + Apache + PHP
端口:8080
Server2和Server3用的是 Apache ,配置了虚拟主机,分别在端口80和8080接收test.kiccp.com .
Server1用的是 Nginx ,配置如下:
/etc/nginx/nginx.conf :
# For more information on configuration, see: # * Official English Documentation: http://nginx.org/en/docs/ # * Official Russian Documentation: http://nginx.org/ru/docs/ user nginx nginx; worker_processes 1; error_log /var/log/nginx/error.log; #error_log /var/log/nginx/error.log notice; #error_log /var/log/nginx/error.log info; pid /var/run/nginx.pid; events { worker_connections 1024; } http { include /etc/nginx/mime.types; default_type application/octet-stream; log_format main '$server_name $remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" "$http_x_forwarded_for"'; access_log /var/log/nginx/access.log main; sendfile on; #tcp_nopush on; #keepalive_timeout 0; keepalive_timeout 65; gzip on; upstream myserver { ####两个后台服务器,分别监听80和8080端口。 server 192.168.0.101:80 weight=5; server 192.168.0.102:8080 weight=5; } # Load modular configuration files from the /etc/nginx/conf.d directory. # See http://nginx.org/en/docs/ngx_core_module.html#include # for more information. ##包含etc/nginx/conf.d/下的所有conf文件,虚拟主机配置就在这个目录里。 include /etc/nginx/conf.d/*.conf; }
接下来是 /etc/nginx/conf.d/ 下的loadbalance.conf文件,被nginx.conf 包含进来。
server { listen 80; server_name test.kiccp.com; ##绑定域名 location / { proxy_pass http://myserver; ##使用nginx.conf中定义的upstream proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; client_max_body_size 10m; client_body_buffer_size 128k; proxy_connect_timeout 90; proxy_send_timeout 90; proxy_read_timeout 90; proxy_buffer_size 4k; proxy_buffers 4 32k; proxy_busy_buffers_size 64k; proxy_temp_file_write_size 64k; } }
在这种配置下, Server1上的Nginx监听80端口上的test.kiccp.com,并随机路由到Server2和Server3,
这样就达到了负载均衡的目的。虽然Server3上的apache用的是8080端口,但访客察觉不到,url显示的依然
是test.kiccp.com且端口没有变化。Server1的log会把所有这些请求都记录下来,而Server2和Server3的
log中记录的来源ip则是Server1的IP,毕竟是从Server1路由过去的。Server1上的Nginx不用关心Server2
和Server3上使用的是apache还是nginx,或者tomcat,只需要知道它的ip和端口即可。
实战总结:
1.Nginx做负载均衡是很强大的,而且配置过程简单
2.Nginx所负载的服务器不一定要用Nginx,用Apache和Tomcat也可以,而且端口完全可以自定义。
3.Nginx的负载均衡对于访客来说是不透明的,他们也无需知道当前由哪个服务器在处理他的请求。
此前关于公积金的观点,多诟病其劫贫济富、提取困难、管理混乱、投资水平低下、政府挪用、贪腐风险等,这些批评虽然可能促使公积金制度的小修小补,但核心问题是,公积金还有没有存在的必要。
如果你有兴趣,有足够的耐心,不妨看看我们从财务角度、投资角度上分析,告诉你可能不知道的真相。
一、公积金贷款、商业贷款相差多少钱?
没有几个人能全款买房,那些富二代、土豪劣绅、或者啃老啃三代筹钱买房的,我们暂且都不讨论,一般人买房,要么通过公积金贷款,要么通过商业银行贷款。
北上广深四大城市,个人公积金贷款最多50万(两人合贷,最高可以达到80万),为了方便计算,我们拿50万贷款额度作为样本,贷款30年,不提前还贷。
公积金贷款利率4.5%,贷款50万30年,利息41万。
商业贷款利率6.55%,贷款50万30年,利息64万。
两者相差23万!
天啊,原来公积金贷款可以省这么多利息!完全符合公积金设立的宗旨,互惠互助、互存互贷,公积金真是伟大,人们在欢呼,但,这只是表象。
二、废除公积金制度,月薪上涨20%吗?
如果废除公积金制度,此时我们讨论的前提是,必须承认公积金是个人劳动报酬,事实上是的:
依据现行的《住房公积金管理条例》规定,住房公积金是单位和在职员工缴纳的一种长期住房储金,并且所有权属于职工个人。
同时,职工以及单位为职工缴纳住房公积金,是依据上年度员工工资水平的一定比例来确定,可见公积金是从职工工资而来,因此公积金实际本质就是工资,或者说是员工劳动报酬所得。
只不过这部分劳动报酬之前是强制留存在公积金账户里。废除公积金后,你的月薪将会立即上涨20%(一般来说,抠门的公司一般只付8%,个人为了合法避税则选用12%)。
看到这里,人们开始眉开眼笑了,没错,月薪一下上涨20%。
但你现在只能用商业贷款买房了,你只能默默承受6.55%的高额利息了,怕了吗?
三、问题是,你能不能跑赢这23万?
刚才说到,贷款50万30年,商业贷款比公积金贷款利息多付23万,问题是,废除公积金后,你能不能用每个月“多”发的钱,在30年间挣到23万?
别怕,你能的!再给点耐心看看怎么算计:
为了方便计算,我们需要忽略你的工资涨幅、 CPI涨幅、未来利率市场化等因素。
如果你的工资是5000元。(备注一下,2013年北京人均工资是5793元,上海5036元,广州6647元,深圳7220元,全国4289元,我们取个整数5000元。)
你每月公积金是5000×(公司缴纳8%+个人缴纳12%)=1000元。
你每年的公积金是1000元×12个月=1.2万元。
你30年的公积金总额是1.2万×30=36 万元。
如果废除公积金,你每年都提取这笔钱去投资,比如就放在“宝宝”之类的货币基金里,按照最近年化收益约4%计算。
F=1.2×(1+4%)^29+1.2×(1+4%)^28+……+1.2×(1+4%)^1=66.1018万元
复利投资收益为66.1018万元-36万元=30.1018万元。
30万纯收益,顿时秒杀23万的利差。
4%的收益率一般能达到,只要你不炒股,炒股就难说了,姚明进去潘长江出来。
当然了,考虑利率市场化,今后存款和“宝宝”们的收益率会呈递减趋势,那么要达到多少收益率才能跑赢23万呢?
1.2×(1+i)^29+1.2×(1+i)^28+……+1.2×(1+i)^1-本金36万元=利差23万元
计算i约等于3.5%,比一年期定存3%略高而已,这时你是不是信心百倍?
四、真相是什么?
真相就是,如果你工资超过5000元,废除公积金,把钱交给你打理,你比那帮公积金管理中心的大老爷们会做得更好!
看到这里,你是支持废除公积金,还是支持保留公积金?
五、还有真相:公积金存款不是还有利息吗?
有人会说,公积金存款也有利息啊,那是你想多了。
按照现行制度,当年的公积金按活期存款利率(0.35%)计算,上年结余的公积金按三月整存整取利率(2.6%)计算,且今后也持续按照此利率水平计息。
公积金的会计年度为当年的7月1日——次年的6月30日,每年6月30日进行结息。
如果你的每月公积金1000元,你一年下来能拿到多少利息?
1000元×0.35%×(12/12+11/12+10/12+9/12+……+2/12+1/12)=22.75元
22.75元,一斤瘦肉的价钱,所以,网上有教程,循循善诱地教导大家不要把公积金当存款了。
六、还有真相:拿私产去投资,收益去哪了?
有人会说,公积金投资也有收益啊,你又想多了,这些收益到不了你手上。
按照《住房公积金财务管理办法》规定,公积金增值收益主要有三个用途:首先是划作公积金管理中心的运营成本,其次是按增值收益60%的比例,提取贷款风险准备金(近几年楼市处于上升期,没有出现烂账,这笔风险金暂时还没有动用过)。此外,增值收益扣除上述两项后,剩余的将要全部上缴财政,用于城市廉租住房建设资金,公积金管理中心不能截留。
个人公积金账户的缴存金额,实际上属于个人财产,但现实情况是,公积金和其增值部分属于缴纳者的私人产权这一本质,未被充分确认,而且将增值收益用于廉租住房建设公共事业,或者进行增值投资,你也没有“话事权” 。
目前全国有各级公积金管理机构600多个,各地公积金管理中心共开发出几百套公积金管理系统,每个系统花费数百万元到上千万元,每年还有几十万的升级维护费,这些人力成本和软件成本都出在你的身上呢,你知道吗?