分析实施总结报告:
我的测试报告如下:(注意是我的)数据十几万条
采用zouql的索引优化后,每单条网站搜索的CPU负担至少上升一半,如果并发五六条搜索,那等着服务器挂好了
经过彻夜的分析与研究(本人不是程序员,没有理论基础,花的时间也久些)得出:
老柏默认的索引为多列索引,zouql的为单列索引.
看了N多资料后,发现多列肯定是优于单列索引,想想老柏默认的索引是有道理的,否则他不会这样设计的,因为程序的SQL表字段的调用,他最清楚^^
还原老柏默认索引后,性能马上提高一半多.忘了默认索引的朋友我帮大家贴一下:
首先删除所有的索引,除了ID那个,再运行下面:
ALTER TABLE `dede_archives` ADD INDEX `typeid` (sortrank,click,pubdate,senddate,lastpost,postnum);
ALTER TABLE `dede_archives` ADD INDEX `typeid_2` (typeid,typeid2);
ALTER TABLE `dede_archives` ADD INDEX `senddate` (memberID,mtype);
ALTER TABLE `dede_archives` ADD INDEX `title` (title,keywords);
在使用这个默认索引前,我自已也测试了几个多列组合,性能也有所下降,我搞着玩的^^阅读全文
我的测试报告如下:(注意是我的)数据十几万条
采用zouql的索引优化后,每单条网站搜索的CPU负担至少上升一半,如果并发五六条搜索,那等着服务器挂好了
经过彻夜的分析与研究(本人不是程序员,没有理论基础,花的时间也久些)得出:
老柏默认的索引为多列索引,zouql的为单列索引.
看了N多资料后,发现多列肯定是优于单列索引,想想老柏默认的索引是有道理的,否则他不会这样设计的,因为程序的SQL表字段的调用,他最清楚^^
还原老柏默认索引后,性能马上提高一半多.忘了默认索引的朋友我帮大家贴一下:
首先删除所有的索引,除了ID那个,再运行下面:
ALTER TABLE `dede_archives` ADD INDEX `typeid` (sortrank,click,pubdate,senddate,lastpost,postnum);
ALTER TABLE `dede_archives` ADD INDEX `typeid_2` (typeid,typeid2);
ALTER TABLE `dede_archives` ADD INDEX `senddate` (memberID,mtype);
ALTER TABLE `dede_archives` ADD INDEX `title` (title,keywords);
在使用这个默认索引前,我自已也测试了几个多列组合,性能也有所下降,我搞着玩的^^阅读全文
写了一个简单的队列任务处理。多进程任务,异步任务可能会用到这个(主要是命令行应用)
比如,任务的某个一个环节速度十分不稳定,可能执行几秒,也可能执行几分钟,
我就可以把那个环节包括前面的部分扔进队列,多跑几个进程,同时往队列里面写。
然后后面比较快的环节只跑一个处理任务就OK了。让整体速度达到更好的效果。
write.php: 将任务写入队列
<?php
/*
产生队列
*/
//用微秒生成队列文件名。因为会有多个队列,所以加了一个identifier来区分各个队列
function mt($identifier='default')
{
return sprintf("%.6f.%s",strtok(microtime(),' ')+strtok(''),$identifier);
}
while(1) //实际中尽量不要while(1) 非要while(1)记得任务完成要break
{
if(count(glob('./queue/*.identifier'))>=10) //队列最大长度,不限制的话硬盘可能会受不了哦。
{
sleep(1);//记住这里要sleep,否则队列满了cpu占用很高
continue;
}
$url = 'www.'.time().'.com'; //随便举个例子,我用时间戳生成了一个网址
echo "$url\r\n";
$fp = fopen('./queue/'.mt('identifier'),'w');
fwrite($fp,$url);
fclose($fp);
sleep(1);//这里不需要sleep,我sleep是因为我的任务太简单。
}
?>
read.php:
<?php
/*
处理队列
*/
while(1) //实际程序最好不要while(1)如果while(1),记得处理完任务要break
{
if($queue = glob('./queue/*.identifier'))
{
$q = array_shift($queue);
$url = file_get_contents($q);
echo $url."\r\n";
unlink($q);
}
sleep(1);//这里要不要sleep或sleep多久自己凭感觉来。
}
?>
比如,任务的某个一个环节速度十分不稳定,可能执行几秒,也可能执行几分钟,
我就可以把那个环节包括前面的部分扔进队列,多跑几个进程,同时往队列里面写。
然后后面比较快的环节只跑一个处理任务就OK了。让整体速度达到更好的效果。
write.php: 将任务写入队列
<?php
/*
产生队列
*/
//用微秒生成队列文件名。因为会有多个队列,所以加了一个identifier来区分各个队列
function mt($identifier='default')
{
return sprintf("%.6f.%s",strtok(microtime(),' ')+strtok(''),$identifier);
}
while(1) //实际中尽量不要while(1) 非要while(1)记得任务完成要break
{
if(count(glob('./queue/*.identifier'))>=10) //队列最大长度,不限制的话硬盘可能会受不了哦。
{
sleep(1);//记住这里要sleep,否则队列满了cpu占用很高
continue;
}
$url = 'www.'.time().'.com'; //随便举个例子,我用时间戳生成了一个网址
echo "$url\r\n";
$fp = fopen('./queue/'.mt('identifier'),'w');
fwrite($fp,$url);
fclose($fp);
sleep(1);//这里不需要sleep,我sleep是因为我的任务太简单。
}
?>
read.php:
<?php
/*
处理队列
*/
while(1) //实际程序最好不要while(1)如果while(1),记得处理完任务要break
{
if($queue = glob('./queue/*.identifier'))
{
$q = array_shift($queue);
$url = file_get_contents($q);
echo $url."\r\n";
unlink($q);
}
sleep(1);//这里要不要sleep或sleep多久自己凭感觉来。
}
?>
yum install openldap openldap-devel nss_ldap openldap-clients openldap-servers
cd php-5.2.8/
./configure 省略参数 --with-ldap --with-ldap-sasl
make ZEND_EXTRA_LIBS='-liconv'
make install
substr()函数可以分割文字,但要分割的文字如果包括中文字符往往会遇到问题,这时可以用mb_substr()/mb_strcut这个函数,mb_substr()/mb_strcut的用法与substr()相似,只是在mb_substr()/mb_strcut最后要加入多一个参数,以设定字符串的编码,但是一般的服务器都没打开php_mbstring.dll,需要在php.ini在把php_mbstring.dll打开。
举个例子:
echo mb_substr('这样一来我的字符串就不会有乱码^_^', 0, 7, 'utf-8');
?>
输出:这样一来我的字
echo mb_strcut('这样一来我的字符串就不会有乱码^_^', 0, 7, 'utf-8');
?>
输出:这样一
从上面的例子可以看出,mb_substr是按字来切分字符,而mb_strcut是按字节来切分字符,但是都不会产生半个字符的现象
举个例子:
echo mb_substr('这样一来我的字符串就不会有乱码^_^', 0, 7, 'utf-8');
?>
输出:这样一来我的字
echo mb_strcut('这样一来我的字符串就不会有乱码^_^', 0, 7, 'utf-8');
?>
输出:这样一
从上面的例子可以看出,mb_substr是按字来切分字符,而mb_strcut是按字节来切分字符,但是都不会产生半个字符的现象
在下找到了一个超详细配置教程,大家可以看看去 http://eidiot.net/lessons/fdt/
另外fdt的破解这里也有 , http://my.opera.com/smile_bug/blog/show.dml/192412
这里还有个eclipse的入门,可惜是英文的,偶看了一部分,还没坚持看完- -b
http://www.actionscript.com/Article/tabid/54/ArticleID/Optimizing-Your-Workflow-with-Eclipse-and-FDT/Default.aspx
这还有个针对上篇文章的快捷键总结
http://www.betriebsraum.de/blog/2006/03/12/eclipsefdt-shortcut-sheet/
偶发现这些资源或教程都会在 本站首页 http://www.nshen.net 更新,以后就不会发到blog里了恩。。
eclipse真是强大啊,好多方便的东西。得备忘一下
快捷键:
ctrl shift r 寻找类,很方便不用知道类的路径了
ctrl f 在本文件中查找,替换。当close查找窗口后,ctrl k 继续查找下一个,ctrl shift k 查找前一个
最常用的查找ctrl + J ,可以不用打开新窗口,查找下一个ctrl +J ,查找上一个ctrl shift j
ctrl h 在很多文件中都寻找某字符串,这都是flash灭有的。。
方法属性查找 ctrl+ o
在某变量或方法上按f3可以查找声明该变量或方法的地方
f4可以打开该属性的class类型
f5会打开该class的super class //好象没打开- -b
下边这个厉害了 (Type Hierarchy view),找个类,ctrl+T ,整个类库结构1清2楚了
另外fdt的破解这里也有 , http://my.opera.com/smile_bug/blog/show.dml/192412
这里还有个eclipse的入门,可惜是英文的,偶看了一部分,还没坚持看完- -b
http://www.actionscript.com/Article/tabid/54/ArticleID/Optimizing-Your-Workflow-with-Eclipse-and-FDT/Default.aspx
这还有个针对上篇文章的快捷键总结
http://www.betriebsraum.de/blog/2006/03/12/eclipsefdt-shortcut-sheet/
偶发现这些资源或教程都会在 本站首页 http://www.nshen.net 更新,以后就不会发到blog里了恩。。
eclipse真是强大啊,好多方便的东西。得备忘一下
快捷键:
ctrl shift r 寻找类,很方便不用知道类的路径了
ctrl f 在本文件中查找,替换。当close查找窗口后,ctrl k 继续查找下一个,ctrl shift k 查找前一个
最常用的查找ctrl + J ,可以不用打开新窗口,查找下一个ctrl +J ,查找上一个ctrl shift j
ctrl h 在很多文件中都寻找某字符串,这都是flash灭有的。。
方法属性查找 ctrl+ o
在某变量或方法上按f3可以查找声明该变量或方法的地方
f4可以打开该属性的class类型
f5会打开该class的super class //好象没打开- -b
下边这个厉害了 (Type Hierarchy view),找个类,ctrl+T ,整个类库结构1清2楚了
翻开扉页,购书日期:2003.2.10。实在汗颜,且此类书,我的案头还有许多。
在两周中抽出时间,翻看完了这本传说中的经典。阅读全文
在两周中抽出时间,翻看完了这本传说中的经典。阅读全文
今天在做GSM模块收发短信中,遇到了一个问题,0X0D和0X0A会自动只收到0X0A,在网上查了下,果真有这个问题。
现在把原因及解决方法写出来:
在我们发送字符0x0d的时候,往往接受端得到的字符是0x0a 这是怎么回事,原因是在串口配置中c_iflag和c_oflag中存在从NL-CR 和CR-NL的映射,也就是说,串口能够把回车和换行看成一个字符,所以,此时我们应该屏蔽掉这些,用options.c_oflag &=~(INLCR|IGNCR|ICRNL|);和options.c_oflag &=~(ONLCR|OCRNL); 进行配置。
还有一个例子:
struct termios Opt;
int m_fd = open("/dev/ttyAM1", O_RDWR | O_NOCTTY | O_NDELAY);
if(m_fd==-1) perror("lcd_drawlib: Cannot open ttyAM1! \n" ) ;
//设置 串口的NL-CR 和CR-NL 的映射
tcgetattr(m_fd,&Opt); //首先读取系统默认设置options
Opt.c_iflag &=~(INLCR|IGNCR|ICRNL);
Opt.c_oflag &=~(ONLCR|OCRNL);
tcflush(m_fd,TCIFLUSH); /* Update the options and do it NOW */ //刷新和立刻写进去
//设置波特率
cfsetispeed(&Opt,B9600);
cfsetospeed(&Opt,B9600);
tcsetattr(m_fd,TCSANOW,&Opt);
write(m_fd, "\x0a", 1);
close(m_fd);
参考资料:http://www.oldlinux.org/oldlinux/viewthread.php?tid=7903,http://www.idcnews.net/html/edu/20070101/285934.html注意:参考中Opt.c_iflag写错,我已进行了修改
现在把原因及解决方法写出来:
在我们发送字符0x0d的时候,往往接受端得到的字符是0x0a 这是怎么回事,原因是在串口配置中c_iflag和c_oflag中存在从NL-CR 和CR-NL的映射,也就是说,串口能够把回车和换行看成一个字符,所以,此时我们应该屏蔽掉这些,用options.c_oflag &=~(INLCR|IGNCR|ICRNL|);和options.c_oflag &=~(ONLCR|OCRNL); 进行配置。
还有一个例子:
struct termios Opt;
int m_fd = open("/dev/ttyAM1", O_RDWR | O_NOCTTY | O_NDELAY);
if(m_fd==-1) perror("lcd_drawlib: Cannot open ttyAM1! \n" ) ;
//设置 串口的NL-CR 和CR-NL 的映射
tcgetattr(m_fd,&Opt); //首先读取系统默认设置options
Opt.c_iflag &=~(INLCR|IGNCR|ICRNL);
Opt.c_oflag &=~(ONLCR|OCRNL);
tcflush(m_fd,TCIFLUSH); /* Update the options and do it NOW */ //刷新和立刻写进去
//设置波特率
cfsetispeed(&Opt,B9600);
cfsetospeed(&Opt,B9600);
tcsetattr(m_fd,TCSANOW,&Opt);
write(m_fd, "\x0a", 1);
close(m_fd);
参考资料:http://www.oldlinux.org/oldlinux/viewthread.php?tid=7903,http://www.idcnews.net/html/edu/20070101/285934.html注意:参考中Opt.c_iflag写错,我已进行了修改
<?php
class EchoParam
{
function EchoValue($a,$b)
{
echo "value = ".$a*$b."\n";
}
function EchoValues($a,$b)
{
echo "jjjj";
}
}
class ClsFactory
{
public static function CreateNoCheckModel($classname)
{
return new $classname;
}
}
class Vmware
{
public function doProx($method, $args)
{
$model = ClsFactory::CreateNoCheckModel("EchoParam");
echo call_user_func_array ( array ($model, $method), $args);
}
public function __call($method, $args)
{ var_dump($method);
return $this->doProx($method, $args);
}
}
$a = 1;
$b = 88;
$mwallobj = new Vmware();
$mwallobj->EchoValue($a, $b);
$mwallobj->EchoValues($a, $b);
?>
class EchoParam
{
function EchoValue($a,$b)
{
echo "value = ".$a*$b."\n";
}
function EchoValues($a,$b)
{
echo "jjjj";
}
}
class ClsFactory
{
public static function CreateNoCheckModel($classname)
{
return new $classname;
}
}
class Vmware
{
public function doProx($method, $args)
{
$model = ClsFactory::CreateNoCheckModel("EchoParam");
echo call_user_func_array ( array ($model, $method), $args);
}
public function __call($method, $args)
{ var_dump($method);
return $this->doProx($method, $args);
}
}
$a = 1;
$b = 88;
$mwallobj = new Vmware();
$mwallobj->EchoValue($a, $b);
$mwallobj->EchoValues($a, $b);
?>
这个$method 就是调用的函数名,这就给代理前作判断,而可以代理后就调用modle层的方法,正是因为类Vmware没有这个方法名,而modle层有这个方法名,达到了代理认证的目的。
结果:
[root@vm0000055 ~]# php call_user_func_array.php
string(9) "EchoValue"
value = 88
string(10) "EchoValues"
jjjj
string(9) "EchoValue"
value = 88
string(10) "EchoValues"
jjjj
==========================================
call_user_func_array函数也可以调用类内部的方法的:
Class ClassA
{
function bc($b, $c) {
$bc = $b + $c;
echo $bc;
}
}
call_user_func_array(array('ClassA','bc'), array("111", "222"));
//显示 333
?>
注意POST:
$this->para['uid'] = $_POST['uid'];
$this->para['content'] =$_POST['content'];
GET接收:
$this->para['uid'] = $_GET['uid'];
$this->para['content'] =$_GET['content'];
中文问题:
var url="a.jsp?name=小李";
url=encodeURI(url);
url=encodeURI(url); //两次,很关键[具体为什么,我也不清楚]
/********************************************/
也有人写成var url="a.jsp?name=escape("小李")";
功能和encodeURI方法类似。
/********************************************/
xmlHTTP.setrequestheader("cache-control","no-cache");
xmlHTTP.setrequestheader("Content-Type","application/x-www-form-urlencoded");
xmlHTTP.setrequestheader("contentType","text/html;charset=uft-8")//指定发送数据的编码格式
xmlHTTP.open ("post",url,true);
PHP得做:urldecode()的操作。
用httpfox抓包,用httpwatcher调试js错误。
以下是Ajax POST提交方式提交:
阅读全文
$this->para['uid'] = $_POST['uid'];
$this->para['content'] =$_POST['content'];
GET接收:
$this->para['uid'] = $_GET['uid'];
$this->para['content'] =$_GET['content'];
中文问题:
var url="a.jsp?name=小李";
url=encodeURI(url);
url=encodeURI(url); //两次,很关键[具体为什么,我也不清楚]
/********************************************/
也有人写成var url="a.jsp?name=escape("小李")";
功能和encodeURI方法类似。
/********************************************/
xmlHTTP.setrequestheader("cache-control","no-cache");
xmlHTTP.setrequestheader("Content-Type","application/x-www-form-urlencoded");
xmlHTTP.setrequestheader("contentType","text/html;charset=uft-8")//指定发送数据的编码格式
xmlHTTP.open ("post",url,true);
PHP得做:urldecode()的操作。
用httpfox抓包,用httpwatcher调试js错误。
以下是Ajax POST提交方式提交:
阅读全文
$HTTP["host"] == "xd.sina.com.cn" {
server.document-root = "/opt/www/pengyou/framework2/"
accesslog.filename = space_logdir + "xd.sina.com.cn-access.log"
server.errorlog = space_logdir + "xd.sina.com.cn-error.log"
url.rewrite-once = (
"^/?$" => "/control/index.php",
"^/view/(.*)" => "/view/$1",
"^/(.*)" => "/control/$1",
)
}
PHP开发,个人觉得还是要轻量级去做框架,分为3个层次:data 层 modle层 control 层,而我们在data层里面可能会用到设计模式的单一模式,而在modle层里面可能采用简单工厂模式,而在control层里面有order模式,和代理(proxy层,让框架去自动调用),而这里面往往这些都在一个依赖倒转原则下(也就是会修电脑但你不会修收音机),其实就是一个里氏代换原则,让data modle control彻底的分开,就像电脑插槽一样,随时随地可以替换,而且很容易查到问题 的所在。
工厂类调用方式:
$smarty = ClsFactory::Create ( "libs::MySmarty" );
$this->template = 'myrecord.html';
工厂类实现方法:
class ClsFactory
{
function Create($classname)
{
$c = explode("::",$classname);
if(count($c) == 2)
{
$package = $c[0];
$classname = $c[1];
}
if(!class_exists($classname))
{
$classpath = SERVER_ROOT."/libs/";
//if($package) $classpath .= $package."/";
$classfile = $classpath.strtolower($classname).".class.php";
if(!file_exists($classfile)) return 0;
include($classfile);
}
if(!class_exists($classname)) {
return 0;
}
return new $classname;
}
}
路径定义:
./stdafx.php:define ( "SERVER_ROOT", dirname ( __FILE__ ) );
全局变量:
function init_www()
{
$need_include = array (
SERVER_ROOT,
SERVER_ROOT . DIRECTORY_SEPARATOR . "libs" . DIRECTORY_SEPARATOR,
SERVER_ROOT . DIRECTORY_SEPARATOR . "program" . DIRECTORY_SEPARATOR,
dirname ( SERVER_ROOT ) . DIRECTORY_SEPARATOR . "libs" . DIRECTORY_SEPARATOR );
$include_path = explode ( PATH_SEPARATOR, ini_get ( 'include_path' ) );
foreach ( $need_include as $path )
{
if (! in_array ( $path, $include_path ))
{
$include_path [] = $path;
}
}
ini_set ( 'include_path', join ( PATH_SEPARATOR, $include_path ) );
}
init_www ();
工厂类调用方式:
$smarty = ClsFactory::Create ( "libs::MySmarty" );
$this->template = 'myrecord.html';
工厂类实现方法:
class ClsFactory
{
function Create($classname)
{
$c = explode("::",$classname);
if(count($c) == 2)
{
$package = $c[0];
$classname = $c[1];
}
if(!class_exists($classname))
{
$classpath = SERVER_ROOT."/libs/";
//if($package) $classpath .= $package."/";
$classfile = $classpath.strtolower($classname).".class.php";
if(!file_exists($classfile)) return 0;
include($classfile);
}
if(!class_exists($classname)) {
return 0;
}
return new $classname;
}
}
路径定义:
./stdafx.php:define ( "SERVER_ROOT", dirname ( __FILE__ ) );
全局变量:
function init_www()
{
$need_include = array (
SERVER_ROOT,
SERVER_ROOT . DIRECTORY_SEPARATOR . "libs" . DIRECTORY_SEPARATOR,
SERVER_ROOT . DIRECTORY_SEPARATOR . "program" . DIRECTORY_SEPARATOR,
dirname ( SERVER_ROOT ) . DIRECTORY_SEPARATOR . "libs" . DIRECTORY_SEPARATOR );
$include_path = explode ( PATH_SEPARATOR, ini_get ( 'include_path' ) );
foreach ( $need_include as $path )
{
if (! in_array ( $path, $include_path ))
{
$include_path [] = $path;
}
}
ini_set ( 'include_path', join ( PATH_SEPARATOR, $include_path ) );
}
init_www ();
背景:在Flash里直接在浏览器关闭时实现上报数据(Get;/Post;),发现有些浏览器不支持,调用Js实现也有这样的一个问题,记录在:
http://jackxiang.com/post/6084/
chrome浏览器支持onbeforeunload事件吗?
Chrome Safari 在调用 document.write、document.open、document.close 方法以及 "javascipt:" 伪协议时,不会触发 onbeforeunload 事件。
http://w3help.org/zh-cn/causes/BX2047
于是我就自己也试了一把这个Js调用Flash,Flash再调用Js的一个过程,记录如下:
这一篇文章是最好的实践方法,尤其是对Js调用Flash里的函数不同浏览器的不同方法:
http://www.imququ.com/post/39.html
再就是在使用FlashDevelop时新建时默认要用ActionScript AS3 Project,默认的AS3才行。
核心:http://www.imququ.com/post/39.html
结果,除了IE之外,其他浏览器都不会工作,会提示找不到hello这个方法。这个问题困扰了我比较久。最后发现:在非IE浏览器里,flash提供的方法是加在embed上的,我们要得到object下的embed对象,调用embed上的方法才会成功!
1)Html代码如下,index.html:
2)Flash的代码如下,Main.as:
阅读全文
http://jackxiang.com/post/6084/
chrome浏览器支持onbeforeunload事件吗?
Chrome Safari 在调用 document.write、document.open、document.close 方法以及 "javascipt:" 伪协议时,不会触发 onbeforeunload 事件。
http://w3help.org/zh-cn/causes/BX2047
于是我就自己也试了一把这个Js调用Flash,Flash再调用Js的一个过程,记录如下:
这一篇文章是最好的实践方法,尤其是对Js调用Flash里的函数不同浏览器的不同方法:
http://www.imququ.com/post/39.html
再就是在使用FlashDevelop时新建时默认要用ActionScript AS3 Project,默认的AS3才行。
核心:http://www.imququ.com/post/39.html
结果,除了IE之外,其他浏览器都不会工作,会提示找不到hello这个方法。这个问题困扰了我比较久。最后发现:在非IE浏览器里,flash提供的方法是加在embed上的,我们要得到object下的embed对象,调用embed上的方法才会成功!
1)Html代码如下,index.html:
2)Flash的代码如下,Main.as:
阅读全文
多选select 的name必须是一个name_value[],后面有这个中括号,为哈?
如果不是中括号的话,你用httpfox抓下包,
select 1
select 2
select 3
php他会得到一个值,也就是多选最下面的那个值,而在加上中括号后呢,就会出现如下:
select[] 1
select[] 2
select[] 3
select.html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>提交多选的静态页</title>
</head>
<body>
<form id="post_form" name="post_form" method="post" action="./select.php">
<select name="select[]" size="10" multiple="multiple" id="select">
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
<option value="4">4</option>
</select>
<label> <br />
<input type="submit" name="button" id="button" value="提交" />
</label>
</form>
</body>
</html>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>PHP接收多选是一个数组</title>
</head>
select.php
<body>
<?php
print_r($_POST['select']);
?>
</body>
</html>
这样PHP得到:
Array
(
[0] => 1
[1] => 2
[2] => 3
)
如果不是中括号的话,你用httpfox抓下包,
select 1
select 2
select 3
php他会得到一个值,也就是多选最下面的那个值,而在加上中括号后呢,就会出现如下:
select[] 1
select[] 2
select[] 3
select.html
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>提交多选的静态页</title>
</head>
<body>
<form id="post_form" name="post_form" method="post" action="./select.php">
<select name="select[]" size="10" multiple="multiple" id="select">
<option value="1">1</option>
<option value="2">2</option>
<option value="3">3</option>
<option value="4">4</option>
</select>
<label> <br />
<input type="submit" name="button" id="button" value="提交" />
</label>
</form>
</body>
</html>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>PHP接收多选是一个数组</title>
</head>
select.php
<body>
<?php
print_r($_POST['select']);
?>
</body>
</html>
这样PHP得到:
Array
(
[0] => 1
[1] => 2
[2] => 3
)
1. 自己技术很强很全面.
作为leader, 不一定要写很多代码, 但是下面人有了问题你要能解决. 这既是项目需要, 也是leader建立威信所必须的. 从lz的描述来看, 自己只参与了数据库相关的开发, 以至于小到搭环境出现问题大到改架构都需要X来处理, 而对于X没处理好的lz似乎很不满
2. 底下有个技术和关系都很过硬的人.
这个不用多说了, 只要这个技术牛人很服你, 你们沟通肯定没问题, 出现技术问题他自然可以帮你顶着. 有技术没关系, 别人没这个义务(如果只有你是leader的话). 没技术, 那啥也不用说了.
3. 团队技术过硬,关系融洽.
技术过硬问题就少, 关系融洽, 有问题就可以内部消化, 基本不会暴露到你跟前.
好的业务模式(产品) + 很好的技术 = 大赚钱
好的业务模式(产品) + 能用的技术 = 也赚钱
差的业务模式(产品) + 好的技术 = 赚吆喝(现在的SNS就差不多这样了)
差的业务模式(产品) + 差的技术 = 自己浪费资源
好的业务模式(产品) + 能用的技术 = 也赚钱
差的业务模式(产品) + 好的技术 = 赚吆喝(现在的SNS就差不多这样了)
差的业务模式(产品) + 差的技术 = 自己浪费资源
对我过去感兴趣的朋友们,请看十年总结系列文章
---
在经过RUP和XP两种思想的冲撞之后,我发现想要借助一个什么理论来获得工作绩效的提升,基本上是不可能的,
RUP也好,XP也罢,都不是看看书,照猫画虎就可以解决软件开发过程中的问题的。阅读全文
---
在经过RUP和XP两种思想的冲撞之后,我发现想要借助一个什么理论来获得工作绩效的提升,基本上是不可能的,
RUP也好,XP也罢,都不是看看书,照猫画虎就可以解决软件开发过程中的问题的。阅读全文