存档

2012年11月 的存档

PHP分多步骤填写发布信息的简单方法实例代码

2012年11月30日 评论已被关闭

有的时候,在做发布信息提交页面时,需要把很多复杂信息提交页面分成多个步骤来提交。下现就是实现的这种功能的基本方法

1.php

复制代码 代码如下:

<form name=form1 id=form1 method=post action=2.php>
基本信息1:<input type=text name=base1 />
基本信息2:<input type=text name=base2 />
<input type=submit value=”下一步”>
</form>


2.php

复制代码 代码如下:

<form name=form2 id=form2 method=post action=3.php>
产品名称:<input type=text name=prcname />
产品价格:<input type=text name=price />
产品型号:<input type=text name=prcXH />
<input type=hidden name=base1 value=”<?php echo $_REQUEST[‘base1’] ?>” />
<input type=hidden name=base2 value=”<?php echo $_REQUEST[‘base2’] ?>” />
<input type=submit value=下一步 />
</form>


3.php

复制代码 代码如下:

<form name=form3 id=form3 method=post action=4.php>
其他信息1:<input type=text name=other1 />
其他信息2:<input type=text name=other2 />
<input type=hidden name=base1 value=<?php echo $_REQUEST[‘base1’] ?> />
<input type=hidden name=base2 value=<?php echo $_REQUEST[‘base2’] ?> />
<input type=hidden name=prcname value=<?php echo $_REQUEST[‘prcname’] ?> />
<input type=hidden name=price value=<?php echo $_REQUEST[‘price’] ?> />
<input type=hidden name=prcXH value=<?php echo $_REQUEST[‘prcXH’] ?> />
<input type=submit value=确定 />
</form>


4.php

复制代码 代码如下:

<?php
$base1=$_REQUEST[‘base1’];
$base2=$_REQUEST[‘base2’];
$prcname=$_REQUEST[‘prcname’];
$price=$_REQUEST[‘price’];
$prcXH=$_REQUEST[‘prcXH’];
$other1=$_REQUEST[‘other1’];
$other2=$_REQUEST[‘other2’];

$sql1=”insert into [base_table](base1,base2) values(‘{$base1}’,'{$base2}’)”;
$sql2=”insert into [prc_table](prcname,price,prcXH) values(‘{$prcname}’,'{$price}’,'{$prcXH}’)”;
$sql3=”insert into [other_table](other1,other2) values(‘{$other1}’,'{$other2}’)”;
query($sql1);
query($sql2);
query($sql3);

echo “写入完成”;
?>

分类: php 标签:

PHP获取搜索引擎关键字来源的函数(支持百度和谷歌等搜索引擎)

2012年11月30日 评论已被关闭

通过网站功能来增加一字段,获取来源关键字,如何获取来源关键字,代码发在下面,里面包含(百度、谷歌、雅虎、搜狗、搜搜、必应、有道)几大搜索引擎的获取方法,代码中均注明,希望对你有帮助,分享一下

最近遇到一个项目,客户需要一个功能,一个商品销售下单需要知道用户下单是从哪个途径来的,认为客服软件(53客服)和站长统计只能满足工作时间,及晚上下班和周六日休息,客服不在线,用户下单会不知道该订单的具体来源,所以嘛,又只能通过网站功能来增加一字段,获取来源关键字,如何获取来源关键字,代码发在下面,里面包含(百度、谷歌、雅虎、搜狗、搜搜、必应、有道)几大搜索引擎的获取方法,代码中均注明,希望对你有帮助,分享一下

代码如下:

复制代码 代码如下:

<?php
//获取来自搜索引擎入站时的关键词
function get_keyword($url,$kw_start)
{
$start=stripos($url,$kw_start);
$url=substr($url,$start+strlen($kw_start));
$start=stripos($url,’&’);
if ($start>0)
{
$start=stripos($url,’&’);
$s_s_keyword=substr($url,0,$start);
}
else
{
$s_s_keyword=substr($url,0);
}
return $s_s_keyword;
}

$url=isset($_SERVER[‘HTTP_REFERER’])?$_SERVER[‘HTTP_REFERER’]:”;//获取入站url。
$search_1=”google.com”; //q= utf8
$search_2=”baidu.com”; //wd= gbk
$search_3=”yahoo.cn”; //q= utf8
$search_4=”sogou.com”; //query= gbk
$search_5=”soso.com”; //w= gbk
$search_6=”bing.com”; //q= utf8
$search_7=”youdao.com”; //q= utf8

$google=preg_match(“/b{$search_1}b/”,$url);//记录匹配情况,用于入站判断。
$baidu=preg_match(“/b{$search_2}b/”,$url);
$yahoo=preg_match(“/b{$search_3}b/”,$url);
$sogou=preg_match(“/b{$search_4}b/”,$url);
$soso=preg_match(“/b{$search_5}b/”,$url);
$bing=preg_match(“/b{$search_6}b/”,$url);
$youdao=preg_match(“/b{$search_7}b/”,$url);
$s_s_keyword=””;
$bul=$_SERVER[‘HTTP_REFERER’];
//获取没参数域名
preg_match(‘@^(?:http://)?([^/]+)@i’,$bul,$matches);
$burl=$matches[1];
//匹配域名设置
$curl=”www.netxu.com”;
if($burl!=$curl){
if ($google)
{//来自google
$s_s_keyword=get_keyword($url,’q=’);//关键词前的字符为”q=”。
$s_s_keyword=urldecode($s_s_keyword);
$urlname=”谷歌:”;
$_SESSION[“urlname”]=$urlname;
$_SESSION[“s_s_keyword”]=$s_s_keyword;
//$s_s_keyword=iconv(“GBK”,”UTF-8″,$s_s_keyword);//引擎为gbk
}
else if($baidu)
{//来自百度
$s_s_keyword=get_keyword($url,’wd=’);//关键词前的字符为”wd=”。
$s_s_keyword=urldecode($s_s_keyword);
$s_s_keyword=iconv(“GBK”,”UTF-8″,$s_s_keyword);//引擎为gbk
$urlname=”百度:”;
$_SESSION[“urlname”]=$urlname;
$_SESSION[“s_s_keyword”]=$s_s_keyword;
}
else if($yahoo)
{//来自雅虎
$s_s_keyword=get_keyword($url,’q=’);//关键词前的字符为”q=”。
$s_s_keyword=urldecode($s_s_keyword);
//$s_s_keyword=iconv(“GBK”,”UTF-8″,$s_s_keyword);//引擎为gbk
$urlname=”雅虎:”;
$_SESSION[“urlname”]=$urlname;
$_SESSION[“s_s_keyword”]=$s_s_keyword;
}
else if($sogou)
{//来自搜狗
$s_s_keyword=get_keyword($url,’query=’);//关键词前的字符为”query=”。
$s_s_keyword=urldecode($s_s_keyword);
$s_s_keyword=iconv(“GBK”,”UTF-8″,$s_s_keyword);//引擎为gbk
$urlname=”搜狗:”;
$_SESSION[“urlname”]=$urlname;
$_SESSION[“s_s_keyword”]=$s_s_keyword;
}
else if($soso)
{//来自搜搜
$s_s_keyword=get_keyword($url,’w=’);//关键词前的字符为”w=”。
$s_s_keyword=urldecode($s_s_keyword);
$s_s_keyword=iconv(“GBK”,”UTF-8″,$s_s_keyword);//引擎为gbk
$urlname=”搜搜:”;
$_SESSION[“urlname”]=$urlname;
$_SESSION[“s_s_keyword”]=$s_s_keyword;
}
else if($bing)
{//来自必应
$s_s_keyword=get_keyword($url,’q=’);//关键词前的字符为”q=”。
$s_s_keyword=urldecode($s_s_keyword);
//$s_s_keyword=iconv(“GBK”,”UTF-8″,$s_s_keyword);//引擎为gbk
$urlname=”必应:”;
$_SESSION[“urlname”]=$urlname;
$_SESSION[“s_s_keyword”]=$s_s_keyword;
}
else if($youdao)
{//来自有道
$s_s_keyword=get_keyword($url,’q=’);//关键词前的字符为”q=”。
$s_s_keyword=urldecode($s_s_keyword);
//$s_s_keyword=iconv(“GBK”,”UTF-8″,$s_s_keyword);//引擎为gbk
$urlname=”有道:”;
$_SESSION[“urlname”]=$urlname;
$_SESSION[“s_s_keyword”]=$s_s_keyword;
}
else{
$urlname=$burl;
$s_s_keyword=””;
$_SESSION[“urlname”]=$urlname;
$_SESSION[“s_s_keyword”]=$s_s_keyword;
}
$s_urlname=$urlname;
$s_urlkey=$s_s_keyword;
}
else{
$s_urlname=$_SESSION[“urlname”];
$s_urlkey=$_SESSION[“s_s_keyword”];
}
?>


有一点要记住,由于各搜索引擎的页面编码不一样,有的是GBK,有的是UTF8,所以在获取时会有不同对字符编码的转换
转载请注明:http://www.netxu.com/program/12.html

下面是另外一个函数,也可以参考下

复制代码 代码如下:

<?php
$_SERVER[‘HTTP_REFERER’]=’http://www.baidu.com/s?wd=http://www.jb51.net’;
echo save_www_iiwnet_com_keyword(‘http://www.baidu.com/s?wd=http://www.jb51.net’,’http://www.baidu.com/s?wd=http://www.jb51.net’);
function save_www_iiwnet_com_keyword($domain,$path){
if(strpos($domain, ‘google.com.tw’)!==false && preg_match(‘/q=([^&]*)/i’,$path,$regs)){
$searchengine = ‘GOOGLE TAIWAN’;
$keywords = urldecode($regs[1]); // google taiwan
}
if(strpos($domain,’google.cn’)!==false && preg_match(‘/q=([^&]*)/i’,$path,$regs)){
$searchengine = ‘GOOGLE CHINA’;
$keywords = urldecode($regs[1]); // google china
}
if(strpos($domain,’google.com’)!==false && preg_match(‘/q=([^&]*)/i’,$path,$regs)){
$searchengine = ‘GOOGLE’;
$keywords = urldecode($regs[1]); // google
}elseif(strpos($domain,’baidu.’)!==false && preg_match(‘/wd=([^&]*)/i’,$path,$regs)){
$searchengine = ‘BAIDU’;
$keywords = urldecode($regs[1]); // baidu
}elseif(strpos($domain,’baidu.’)!==false && preg_match(‘/word=([^&]*)/i’,$path,$regs)){
$searchengine = ‘BAIDU’;
$keywords = urldecode($regs[1]); // baidu
}elseif(strpos($domain,’114.vnet.cn’)!== false && preg_match(‘/kw=([^&]*)/i’,$path,$regs)){
$searchengine = ‘CT114’;
$keywords = urldecode($regs[1]); // ct114
}elseif(strpos($domain,’iask.com’)!==false && preg_match(‘/k=([^&]*)/i’,$path,$regs)){
$searchengine = ‘IASK’;
$keywords = urldecode($regs[1]); // iask
}elseif(strpos($domain,’soso.com’)!==false && preg_match(‘/w=([^&]*)/i’,$path,$regs)){
$searchengine = ‘SOSO’;
$keywords = urldecode($regs[1]); // soso
}elseif(strpos($domain, ‘sogou.com’)!==false && preg_match(‘/query=([^&]*)/i’,$path,$regs)){
$searchengine = ‘SOGOU’;
$keywords = urldecode($regs[1]); // sogou
}elseif(strpos($domain,’so.163.com’)!==false && preg_match(‘/q=([^&]*)/i’,$path,$regs)){
$searchengine = ‘NETEASE’;
$keywords = urldecode($regs[1]); // netease
}elseif(strpos($domain,’yodao.com’)!== false && preg_match(‘/q=([^&]*)/i’,$path,$regs)){
$searchengine = ‘YODAO’;
$keywords = urldecode($regs[1]); // yodao
}elseif(strpos($domain,’zhongsou.com’)!==false && preg_match(‘/word=([^&]*)/i’,$path,$regs)){
$searchengine = ‘ZHONGSOU’;
$keywords = urldecode($regs[1]); // zhongsou
}elseif(strpos($domain,’search.tom.com’)!==false && preg_match(‘/w=([^&]*)/i’,$path,$regs)){
$searchengine = ‘TOM’;
$keywords = urldecode($regs[1]); // tom
}elseif(strpos($domain,’live.com’)!==false && preg_match(‘/q=([^&]*)/i’,$path,$regs)){
$searchengine = ‘MSLIVE’;
$keywords = urldecode($regs[1]); // MSLIVE
}elseif(strpos($domain, ‘tw.search.yahoo.com’)!==false && preg_match(‘/p=([^&]*)/i’,$path,$regs)){
$searchengine = ‘YAHOO TAIWAN’;
$keywords = urldecode($regs[1]); // yahoo taiwan
}elseif(strpos($domain,’cn.yahoo.’)!==false && preg_match(‘/p=([^&]*)/i’,$path,$regs)){
$searchengine = ‘YAHOO CHINA’;
$keywords = urldecode($regs[1]); // yahoo china
}elseif(strpos($domain,’yahoo.’)!==false && preg_match(‘/p=([^&]*)/i’,$path,$regs)){
$searchengine = ‘YAHOO’;
$keywords = urldecode($regs[1]); // yahoo
}elseif(strpos($domain,’msn.com.tw’)!==false && preg_match(‘/q=([^&]*)/i’,$path,$regs)){
$searchengine = ‘MSN TAIWAN’;
$keywords = urldecode($regs[1]); // msn taiwan
}elseif(strpos($domain,’msn.com.cn’)!==false && preg_match(‘/q=([^&]*)/i’,$path,$regs)){
$searchengine = ‘MSN CHINA’;
$keywords = urldecode($regs[1]); // msn china
}elseif(strpos($domain,’msn.com’)!==false && preg_match(‘/q=([^&]*)/i’,$path,$regs)){
$searchengine = ‘MSN’;
$keywords = urldecode($regs[1]); // msn
}
return $keywords;
}
分类: php 标签:

自己在做项目过程中学到的PHP知识收集

2012年11月30日 评论已被关闭

以前没学过PHP,最近刚好一个项目需要用到,我就决定一边学一边做PHP

1 在SQL语句中可通过添加限制条件:left(text,20)只取text文本的前20个字;

2 可以用limit fromRecord, RecordNum 来作为分页使用,比如limit 0,30表示从第一个记录开始遍历30个纪录;

3 两个表的连接可以是:table1 join table2 using x(x为两个表的公共字段),或者是table1 join table2 on table1.x = table2.x

4 php获取querystring可以用$page = $_GET[‘page’];

  或者

  $page = $_REQUEST[‘page’];

  其中Request可取得post,get,QueryString等字符;

  在这之前 我看到了一个较笨的办法:

  parse_str($_SERVER[‘QUERY_STRING’],$output); // 先将查询字符串存到一个数组$output中

  $page = $output[‘page’]; //然后根据变量名索引

5 php中日期函数的比较实际上就是字符串的比较;

6 mysql中date类型的数据可以是:2000-02-03,2002.02.03,2002.2.3,02.02.03,02.2.3,就是说必须有月和日,而且必须以’-‘或’.’分隔开来。

7 data()来获取时间会有时区的问题,我发现时间都少了8个小时,是因为php.ini里面默认配置是GTM美国时区;

  解决办法:可以修改php.ini:

  [Date]

  ; Defines the default timezone used by the date functions

  date.timezone = “Asia/Shanghai”

  或者在使用date()函数是加上date_Default_TimeZone_set(“PRC”);

8 一段时间,调试时在body处总是说我缺少”)”,费了半天是intval($_POST[‘consumeType’])的问题,在数据库中该字段是varchar(50),在zengsong表中我没用intval函数,是因为它的ID就是1,2…整数跟char型的可以互相转换,但在另外两个表中是A5A,SP07-01之类的,但它怎么转换成int型了呢?

  让我们来看看intval函数的声明:

  intval函数用来获取变量的整数值:int intval ( mixed var [, int base] )

  通过使用特定的进制转换(默认是十进制),返回变量 var 的 integer 数值。

  var 可以是任何标量类型。intval() 不能用于 array 或 object。

9 另外一个莫名的问题,以用户名1登陆就可以,换个’bo’登陆,系统就在处出错:说我运行时间错误:缺少”)”,nnd。检查了一下,原来是sql语句中的变量类型跟数据库中的不一致,

10 php中当从浮点数转换成整数时,数字将被取整(丢弃小数位)。

11 在mysql插入语句中,如果是自增字段要用(NULL)来代替。

12 php的中文乱码???问题解决:

  在mysql_connect后加入mysql_query(“set names ‘gb2312′”);

  或者全用utf8编码,就不用加入上述语句了。

  还有函数iconv(“GBK”,”UTF8″,”字符串”);可实现各种字符编码的转换。

分类: php 标签:


标签

ajax apache array array_slice CentOS checkbox composer cookie csv curl date DATE_FORMAT excel FCKEditor file_get_contents laravel Magento Certified Developer mb_substr memcache Memcached MySQL String Functions Netbeans openssl php面试题 preg_match_all preg_replace QQ登录 rewrite SaeStorage serialize session setTimeout Sphinx spl Storage strtotime ueditor vsftp vsftpd Zend zip 分割字符串 图片处理 新浪云 正则表达式

存档