本文来自lukin的博客。。。
Lukin,lazyCMS的作者,如果你用过,或许会知道。。。
以下是原文
我是从asp转向php的,asp里面提供了下面的方法
代码1:
ASP/Visual Basic代码
- on error remuse next
-
- on error goto 0
----------------------------------------------------华丽的分割线-------------------------------------------------
转向php之后,查了一些资料貌似php没有提供类似这样的语法
直接使用error_reporting(0);关闭所有错误是很不明智的。所以,考虑使用@来抑制错误的发生,但是往往不如意。
我使用的set_error_handler('myerror')监听了一个函数,直接写@抑制错误的发生那是办不到的,照样会跳到myerror函数里面进行处理,后来看WordPress的源码,发现她屏蔽错误的方法:
代码2:
PHP代码
- $error_reporting = error_reporting(0);
-
- error_reporting($error_reporting);
应用到我系统里面,发现此方法也不好用,照样会进入myerror函数进行错误处理。
继续狂翻php手册,仔细查看set_error_handler这个函数的说明,然后查看评论(一般看手册上的评论还是很有收获的),评论上的一段代码引起了我的注意:
代码3:
PHP代码
-
- if (error_reporting() == 0) {
- return;
- }
细想了一下,把这段代码加入到myerror里面,果然ok了!原来使用@的时候,error_reporting()会返回0
这样可以利用@屏蔽某个函数里面发生的错误了,也可以使用【代码2】的方法来进行分段屏蔽错误了。
--EOF--
我一般是用Set_error_handler的。。还有我记得Error_reporting是可以返回当前设置的等级的。先取回当前的等级,然后设置为0,解决完后再设置回去。其实也是就第二种了。。不过我觉得lukin应该是用这种的,即:
PHP代码
- <?php
- $old = error_reporting();
- error_reporting(0);
-
- error_reporting($old);
找来找去,这个应该是最全的解决方案列表了。。突然间想找这个是因为,网易评论的“分页列表”用的是链接,但没有虚框,很好看,所以想找找这样的资料。。。
以下就属于原文了。。
如何隐藏掉点击链接时周围出现的虚线框呢?
在常规情况下,该虚线框是作为一种提示让用户明确当前关注的东西,然而如果我们把链接的4种状态样式设置比较完整的话,就不是特别需要虚线框的存 在,因为它很有可能影响页面的美观。尤其是在做应用系统界面的时候,总给人一种浏览网页的感觉,显得不够专业。我就遇到过这种情况,有次做一个WEB应用 项目,那用户以前使用桌面软件的,突然转到B/S软件下操作,老是觉得点击链接或按钮出现的虚线框让他很不爽。后来我们挨个把所有会出现虚线框的链接都改 过一遍,这客户高兴坏了,后来还说这系统功能性这么一改好用多了。可见,这么一个小小的东西,对用户体验是多么的重要。
当然,如果全盘否定掉链接虚线框,对使用键盘的用户体验可能又是个大弊端。但这就是另外一个话题了,这里就不说了,不然就扯出UI设计和用户体验这个大话题了,我这小小的地方可说不清楚呢。
以下是解决方案:
方法一:
在IE下是使用html属性:hideFoucs,在HTML标签中加上hidefocus=”true” 属性即可,但这个属性是IE私有的,Firefox是不认的。
XML/HTML代码
- <a href="#" hidefocus="true" title="加了hidefocus" >欢迎来到博客园(加了hidefocus属性)</a>
Firefox的处理方法比较符合标准,只需要在样式里设置a:focus{outline:none}皆可:
CSS代码
- .xzw_test a.setFocus:focus{outline:none}
方法二:
通过javascript方法让其点击后失去焦点从而达到没有虚线框,也不失为一种曲线救国的方案:
JavaScript代码
-
- if(j(this).attr("id")=="jsControl")
- j(this).blur();
--EOF--
作者最后说:Opera也是很WEB标准的浏览器哦,大伙不妨多用用。
不过我现在已经不用了。中文版的opera太难看了。不知道UI是怎么设计的。又或者是我的字体有问题?还是我看惯FF或者safari?唉。。人被养刁了也不好。
由于我的页面不能提供测试样例,所以,想看测试样例的朋友还请移步到:http://www.cnblogs.com/miqi2214/archive/2008/12/25/1361996.html,里面有关于图片和链接的样例
果然是福无双至,祸不单行。古人诚不欺我。
我一直以为这种话是那些人自我安慰,阿Q精神等等还有就是嫉妒别人的时候发出来的感慨,但我最近却是发现了。
虽然只是小小的问题,但却是接蹱而至。
小家伙前两天因为高烧去医院检查,从凌晨两点折腾到5点多,回家两天刚刚有点恢复,昨天发现身上发红点了,【上海话说叫:风疹块】,去医院检查时,才发现医院那就象庙会一样,人山人海,上午10点去,下午4点多才轮上,阿门,本来身上只发了5、6个红点点,结果到下午几乎是全身了。
最后医生还检查出有痰,可能会有肺炎,让挂水。同时配上皮肤止痒的药,并怀疑上次发烧时配的药对小孩有过敏反应,让停用。
回家一看,很多药以前都吃过,只有一个止咳药水没有吃过,难道是那个?仔细一想,去年好象也是因为吃了这个,然后小孩就开始发类似的东西了。唉。。。。
再说,傍晚挂水的时候,平时看到白大褂就害怕的他居然对扎针的护士一直拍马屁叫阿姨,老婆说,叫了还是会扎的啦。听说小家伙在扎的时候没哭,扎完了哭了几下,拔针的时候又对着护士叫阿姨。。【据说旁边还有个三岁左右的小孩在挂完第一瓶的时候还在哭 。。。】
晚上回家,问小家伙,怎么了,小家伙指指手,告诉被扎针了。不过还好,精神还挺好。
晚上吃药的时候,并不拒绝,好象不象我,我很反感吃药,情愿打针。。。
最后,希望小东西能够快点好起来。。
早上,老婆在MSN上和我说她的同事在准备为婚房装修,好象习惯性的就打开了篱笆论坛,说是在论坛上有很多装修的案例还有别人写的心得。心里不由的一阵郁闷,论坛果然还是一个聚集人气的地方,普通的网站确实有点难做,象搜房、百思家之类的,以纯资讯的网站就难以超过这些以论坛为主的网站。
不过仔细看看,这些网站还是有自己的特色的,搜房还是以房型为主,看网站名称也能看得出。而百思家看名字,也是和百思买之类差不多的网站。所不同的是,搜房上更多的新闻,而百思家则以案例介绍居多,而篱笆网则全是论坛主题贴。可能就是因为这个,才导致别人喜欢看论坛,因为,看起来觉得真实?
再看上述网站,篱笆的设计施工频道则显得有点凌乱,搜房网仍然是更多的偏向资讯以及一些建材等的测评,百思家则相对比较好一点,以案例为载体来介绍装修公司和设计师。这些都算是各有特色,篱笆是主要靠论坛,所以施工频道很乱也觉得无所谓;搜房是偏向做门户,对于资讯就相对比较重视,毕竟这样才能拉广告;百思家则以案例为主,为装修公司和设计师提供一片空间。
虽然介绍了上面三家公司,但这只是从用户体验来介绍的,再加上我身处上海,所以也是以上海的网站来介绍。如果在其他地方就不能以此为标准了。
打开google【哦,他已经阵亡了】和百度,搜索一下:装修公司,你会发现在百度上面,第一屏几乎全是推广,这些当然不能点或者少点击,然后往下看再继续搜索一下本地的一些装修公司才是正途。当然,你也可以直接搜索“上海 装修公司”,这样的结果会比较精确一点。【“上海 装修公司”中的上海请换成你所在地区的名称】
只是不知道,google的离去,对我们影响有多大,百度的竞价排名是不是又该涨价了。又或者,可以有人告垄断性经营了?乱讲讲
虽然转载,但并未成功,只是为了防止以后再也找不到类似资料做个备份。
其实作者写的挺详细了,只是我明明设置了RemoteIP,但却无法正确的获取。不知道是否因为是VPS的关系。当然也或许我太笨吧。先转了再说
原文如下,如看原文点击这里:
自从实验室放了台 Linux 服务器后,可玩的东西就越来越多了。虽然这台服务器主要的工作是 Web Server,但鉴于我们那小站压力非常之小,服务器资源绝大多数还是浪费着,所以让它多干些活是个不错的选择。实验室的内部网络中有不少非常有用的资 源,例如科研用的文献资料,个人的实验数据等等,这些内容一旦离开实验室就不那么容易访问到了。解决这个问题最好的办法就是 VPN。在 Ubuntu 上搭建 VPN 服务器的方法非常多,比较著名的有 PPTP, L2TP/IPSec 和 OpenVPN。这三种方式中后两者的安全性比较好,但配置较麻烦。其中 OpenVPN 在 Windows/Mac 平台上还需要额外的客户端。而 L2TP/IPSec 方式虽然比较好,但我配置后,虽然 Windows 和 Linux 用户没有问题,但 Mac/iPhone 却始终无法连上,所以暂时删掉了,日后搞清楚是什么问题再换到这种方式。
只剩下 PPTP 了。事实上 PPTP 是这三者中配置最容易的方式,而且由于 Windows/Mac 系统中都内建相应的客户端,使用起来非常方便。下面我就简单写写我的安装过程,希望对需要的朋友有用。当然如果您有什么高见,也欢迎您提出。
首先,我所有的操作都是在之前文章中介绍的 Ubuntu 8.04 Server 系统中操作的,如果您的系统和我的不一样,请参考之前的两篇文章。我的服务器环境是单网卡 eth0。
在 Ubuntu 中建立 pptp server 需要的软件包为 pptpd,用 apt-get 即可安装:
sudo apt-get install pptpd
系统会自动解决依赖关系,安装好后,需要进行一番设置。首先编辑 /etc/pptpd.conf
sudo nano /etc/pptpd.conf
去掉文件最末端的 localip 和 remoteip 两个参数的注释,并进行相应修改。这里,localip 是 VPN 连通后服务器的 ip 地址,而 remoteip 则是客户端的可分配 ip 地址。下面是我的配置:
localip 10.100.0.1
remoteip 10.100.0.2-10
编辑好这个文件后,我们需要编辑 /etc/ppp/pptpd-options 文件,还是用 nano 编辑,命令这里就不写了。这里绝大多数参数只需维持原来的默认值即可,我们只需要改变其中的 ms-dns 选项,为 VPN 客户端指派 DNS 服务器地址:
ms-dns 202.113.16.10
ms-dns 208.67.222.222
修改 /etc/ppp/chap-secrets 文件,这里面存放着 VPN 的用户名和密码,根据你的实际情况填写即可。如文件中注释所示,第一列是用户名,第二列是服务器名(默认写 pptpd 即可,如果在 pptpd-options 文件中更改过的话,注意这里保持一致),第三列是密码,第四列是 IP 限制(不做限制写 * 即可)。这里我就不贴我的配置了
全部搞定后,我们需要重启 pptpd 服务使新配置生效:
sudo /etc/init.d/pptpd restart
找一台 Windows 电脑,新建个 VPN 链接,地址填服务器的 IP(或域名),用户名密码填刚才设置好的,域那项空着(如果你在 pptpd-options 中设置了,这里就保持一致),点连接就可以了。正常情况下您应该能够建立与服务器的 VPN 链接了。
建立连接之后,您会发现除了可以访问服务器的资源,其余内外和互联网的内容均无法访问。如果需要访问这些内容的话,我们还需要进一步设置:
首先,开启 ipv4 forward。方法是,修改 /etc/sysctl.conf,找到类似下面的行并取消它们的注释:
net.ipv4.ip_forward=1
然后使新配置生效:
sudo sysctl -p
有些时候,经过这样设置,客户端机器就可以上网了(我在虚拟机上这样操作后就可以了)。但我在实验室的服务器上这样操作后仍然无法访问网络,这样我们就需要建立一个 NAT。这里我们使用强大的 iptables 来建立 NAT。首先,先安装 iptables:
sudo apt-get intall iptables
装好后,我们向 nat 表中加入一条规则:
sudo iptables -t nat -A POSTROUTING -s 10.100.0.0/24 -o eth0 -j MASQUERADE
这样操作后,客户端机器应该就可以上网了。
但是,只是这样,iptables 的规则会在下次重启时被清除,所以我们还需要把它保存下来,方法是使用 iptables-save 命令:
sudo iptables-save > /etc/iptables-rules
然后修改 /etc/network/interfaces 文件,找到 eth0 那一节,在对 eth0 的设置最末尾加上下面这句:
pre-up iptables-restore < /etc/iptables-rules
这样当网卡 eth0 被加载的时候就会自动载入我们预先用 iptables-save 保存下的配置。
到此,一个 VPN Server/Gateway 基本就算架设完毕。当然,也许你按照我的方法做了,还是无法成功,那么下面总结一些我碰到的问题和解决方案:
无法建立 VPN 连接
安装好 pptpd 并设置后,客户端还是无法建立到服务器的连接。造成的原因可能有以下几种:
- 服务器端的防火墙设置:PPTP 服务需要使用 1723(tcp) 端口和 gre 协议,因此请确保您的防火墙设置允许这两者通行。
- 如果服务器在路由器后面,请确保路由器上做好相应的设置和端口转发。
- 如果服务器在路由器后面,那么请确保你的服务器支持 VPN Passthrough。
- 如果客户端在路由器后面,那么客户端所使用的路由器也必须支持 VPN Passthrough。其实市面上稍微好点的路由器都是支持 VPN Passthrough 的,当然也不排除那些最最最便宜的便宜货确实不支持。当然,如果你的路由器可以刷 DD-Wrt 的话就刷上吧,DD-Wrt 是支持的。
能建立链接,但“几乎”无法访问互联网
这里我使用“几乎”这个词,是因为并不是完全不能访问互联网。 症状为,打开 Google 搜索没问题,但其它网站均无法打开;SSH 可用,但 scp 不行;ftp 能握手,但传不了文件。我就遇到了这种情况,仔细 Google 后发现原来是 MTU 的问题,用 ping 探测了一下果然是包过大了。知道问题就好办了,我们可以通过 iptables 来修正这一问题。具体原理就不讲了,需要的自己 Google。这里只说解决方案,在 filter 表中添加下面的规则:
sudo iptables -A FORWARD -s 10.100.0.0/24 -p tcp -m tcp --tcp-flags SYN,RST SYN
-j TCPMSS --set-mss 1200
上面规则中的 1200 可以根据你的实际情况修改,为了保证最好的网络性能,这个值应该不断修改,直至能保证网络正常使用情况下的最大值。
好了,至此,一台单网卡 pptp-server 就算完成了。
----EOF---
后记:好象有很多类似的文章,前面几段都差不多的。
比如这里:
1、http://blog.sina.com.cn/s/blog_49cd61e70100cbph.html
2、http://hi.baidu.com/wangshuxun25/blog/item/b37779f04deae4a7a50f5231.html ,这个是用的shorewall防火墙,上面两篇都是用iptables的
继续后记:
已经可以了。哈哈。还是我没有配置好的原因。oh yeah ...