ZendOptimizer发布了新版本3.3.9 for Linux,于是乎及时跟进。
症状:成功安装后,phpinfo()显示正常,但是网站页面却打不开,显示“访问的页面不存在或输入网址有误,请确认” 。
解决方案:与已安装APC缓存模块有冲突,设置apc.enabled = 0,问题解决。
参考资料:http://kb.zend.com/index.php?View=entry&EntryID=150
ZendOptimizer发布了新版本3.3.9 for Linux,于是乎及时跟进。
症状:成功安装后,phpinfo()显示正常,但是网站页面却打不开,显示“访问的页面不存在或输入网址有误,请确认” 。
解决方案:与已安装APC缓存模块有冲突,设置apc.enabled = 0,问题解决。
参考资料:http://kb.zend.com/index.php?View=entry&EntryID=150
ini_set(‘max_execution_time’,’10′);
ini_set(‘memory_limit’,’1024M’);
echo ‘max_execution_time = ‘ . ini_get(‘max_execution_time’) ;
echo ‘memory_limit = ‘ . ini_get(‘memory_limit’) ;
echo ‘post_max_size = ‘ . ini_get(‘post_max_size’);
echo ‘upload_max_filesize = ‘ . ini_get(‘upload_max_filesize’);
ini_set(‘max_execution_time’,’10′);
ini_set(‘memory_limit’,’1024M’);
注意: post_max_size,upload_max_filesize用下面的方法是修改不了的.
ini_set(‘post_max_size’,’1024M’);
ini_set(‘upload_max_filesize’,’1024M’);
正确做法是用.htaccess文件:
php_value upload_max_filesize 50M
php_value post_max_size 100M
前提是该站点在httpd.conf中配置了:
AllowOverride All
补充:
其实在php文档里有说明upload_max_filesize的可修改范围是PHP_INI_PERDIR。PHP_INI_PERDIR的意思是域内指令可以在php.ini、httpd.conf或.htaccess文件中修改。PHP_INI_SYSTEM 域内指令可以在php.ini和httpd.conf文件中修改所以upload_max_filesize用int_set是无法修改的。只有可修改范围是PHP_INI_ALL的才可以用int_set修改。
原文参见:http://www.cnblogs.com/kingthy/archive/2008/10/08/flex_file_uploader.html
我这里所做的修改:同一页面中可多次调用FLASH,解决IE,FIREFOX,CHROME,OPERA浏览器传值兼容问题,另外提供可跨域上传的解决办法。
————————————————-
2010-5-21 更新:默认语言为英文,将错误提示工作交给JS,根据错误类型自定义错误信息。
/*
*当Flash出现错误时(如上传文件)将触发此事件。
*error拥有两个属性
*error.type 错误类型
*error.value 错误信息
*/
__SWFUpload_OnError = function(objID, error){
switch(error.type){
case ‘size’:
alert(‘文件大小超出限制:’+error.value);
break;
default:
alert(error.value);
break;
}
__SWFUpload_GetMovie(objID).__SWFUpload_ResetUpload();
}
示例文件下载(Ver 1.1):Flex.FileUploader.1.1
header() 函数会传送一个标题讯息给浏览器。因为这些讯息都遵循 HTTP 的规范, 因此浏览器会依据这些讯息做适当之响应。
header()格式:��int header ( string 标头宣告文字 [, bool 置换 [, int http回应码]])
–[标头宣告文字] 的内容就是传给浏览器的标题文字内容。
–[置换] 是布尔型态的参数。 设定为 True 时, 当有二的相同型态的标题讯息宣告时, 后面的讯息将会覆盖前一个讯息。
–第三个参数会让 HTTP 回应码给指定的值。
Location
Refresh
Content-type
Expires(意思为终止)
Last-Modified等。
Location – 浏览器显示指定的网页。
格式: header(“Location: http://绝对地址”);
Location 的地址必须是一个绝对地址。
Refresh
Refresh – 更新网页。
格式如下:��header(“Refresh : N ; URL=网址”)
–N 代表更新时间, 时间单位为秒。 URL 为更新后连结的网址。 如果省略 URL 就表示更新网页本身。
Content-type
Content-type – 定义网页内容的类型。
格式: Content-Type��= “Content-Type:” media-type
举例如下:
Header(“Content-type: text/html; charset=big5″) 设定网页内容为big5
Header(“Content-type: image/gif”) 设定网页内容为gif格式的图片
Header(“Content-type: application/pdf”) 设定网页内容为pdf档
Cache Control – Cache 的控制。
Cache Control 大致可以分成几种类型
设定过期时间。 当时间超过指定时间就表示网页内容已经失效。 其格式如下
Expires = “Expires:” HTTP-date
例 如: header(“Expires: Fri, 31 Oct 2003 18:00:00 GMT”); 表示2003年10月31日星期五 18时。
header(“Expires: Wed, 30 Jun 2004 09:00:00 GMT”); 表示2004年6月30日星期三 9时。
Last-Modified = “Last-Modified” “:” HTTP-date
例如 header(“Last-Modified: Wed, 01 Jan 2003 12:00:00 GMT”); 上次修改时间2003年1月1日12时
Cache Control
no-cache 使得服务器的数据可以传送到远程的使用者, 而不会被暂存 (cache) 起来。
no-store 是预防不良的版本或者是敏感的信息被保留下来。
must-revalidate 是指必须要再评估信息, 如果暂存 (cached) 的数据是无效的则让服务器与使用者端联机
Date 是说明数据内容的建立日期及时间。 其格式如下: Date = “Date:” HTTP-date
范例: header(“Date: Sun, 15 Feb 2004 08:00:00 GMT”); 建立日期是2004年2月15日8时。
使用 header() 函数认证
基本的认证就是使用账号密码窗体输入HTTP 认证。
窗体认 证:
<?php
if (($_POST['name'] != “john”) or ($_POST['passwd'] != “1234″)):
?>
<html>
<title>登入画面</title>
<body>
<B>未输入账号或密码, 或账号,密码不正确 </B><p>
<form action=<?php echo $_SERVER['PHP_SELF'] ?> method=post>
账号 <input type=text name=name value=”请输入账号” size=10><p>
密码 <input type=password name=passwd size=10><p>
<input type=submit value=” 登入 “>
<input type=reset value=” 清除 “>
</form>
</body>
</html>
<?php
else:
echo “登入成功 …..<p>”;
echo “您登入的账号是 “.$_POST['name'].”<br>”;
echo “您使用的密码是 “.$_POST['passwd'];
endif
?>
HTTP认证
<?php
if (empty($_SERVER['PHP_AUTH_USER'])) {
header(“Content-type: text/html; charset=big5″);
header(‘WWW-Authenticate: Basic realm=”认证范围”‘);
header(‘HTTP/1.0 401 Unauthorized’);
echo ‘请输入正确的账号及密码, 不可以取消!’;
exit;
} else {
echo “您登入的账号是 “.$_SERVER['PHP_AUTH_USER'].”<br>”;
echo “您使用的密码是 “.$_SERVER['PHP_AUTH_PW'].”<p>”;
$correctName=”john”;
$correctpwd=”1234″ ;
if (($_SERVER['PHP_AUTH_USER'] != $correctName) or
($_SERVER['PHP_AUTH_PW'] !=$correctpwd)){
echo “登入失败, 请开启新的浏览器重新登入”;
}else{
echo “登入成功…..”;
}
}
?>
DIV弹出之前,禁止页面滚动:
if(Prototype.Browser.IE){
$($$(‘html’)[0]).setStyle({overflow : ‘hidden’});
}else{
$($$(‘body’)[0]).setStyle({overflow : ‘hidden’});
}
DIV关闭之后,恢复页面滚动:
if(Prototype.Browser.IE){
$($$(‘html’)[0]).setStyle({overflow : ‘auto’});
}else{
$($$(‘body’)[0]).setStyle({overflow : ‘auto’});
}
所谓高内存占用,在我的机器环境下,是指120M左右:一个主题,一个扩展。
下面是手术记录:
在地址栏输入 about:config,进入配置模式:
1. 新建一个布尔值,名为 config.trim_on_minimize,并设定值为 true,这样当 Firefox 最小化时就会释放内存占用;
2. 修改browser.sessionhistory.max_total_viewers修改值为5(页面快进/快退 功能中保存的页面总数,默认是-1(无限));
3. 新建一个整数值,名为 browser.cache.memory.capacity,设定其值16384 (>=1G 内存, 此步配置指定内存)。
丢了半年多的东西,好心疼!
先用函数base64_encode() — 使用 MIME base64 对数据进行编码
标题字符串前加编码类型例如: =?UTF-8?B?
标题字符串后加:?=
邮件header指明Content-type: text/html; charset=utf-8,这样就能防止邮件正文乱码
IE里需要在 a 标签中加入 hidefocus=”true” 属性:<a href=”” hidefocus=”true” title=””>siteface</a>
而在Firefox等浏览器中定义CSS:a { outline:none; }或者a { outline:0; } 就可以了。
在IE里 hideFocus即隐藏聚焦,具有使对象聚焦失效的功能,其功能相当于:
onFocus=”this.blur()”
它的值是一个布尔值,如hideFocus=true。也可省略赋值直接写hideFocus。
当看到错误提示
syntax error, unexpected T_ENCAPSED_AND_WHITESPACE, expecting T_STRING or T_VARIABLE or T_NUM_STRING
这个提示,是提示变量使用的问题。
而我出现的是,语句中使用了数组,导致失败。下面看看失败的代码;
<?php
echo “我是数组,$n['x']“;
?>
这样即时双引号是可以解析变量的,但是素组这样的,写法是没办法解析。修改成下面就可以了!
<?php
echo “我是数组,{$n['x']}”;
?>
加上花括号{}可以让语句识别这里面是动态的。