文件上传
你可以利用PHP实现文件的上传功能,注意客户端的浏览器应该是Netscape3以上或者IE3以上的版本。同时,因为本程序与你的PHP配置文件(PHP3为php3.ini,PHP4为php.in)设置有关。在执行该程序之前请先检查您的PHP配置文件有没有做好如下的设置:
将;upload_tmp_dir该行的注释符,即前面的分号“;”去掉,使该行在php.ini文档中起作用。upload_tmp_dir是用来定义上传文件存放的临时路径,在这里你还可以给其定义一个绝对路径,例如:upload_tmp_dir = d:\upload 当然,此时你的d:\upload目录必须有读写权限。
如果你在你的.php3程序里已经定义了上传的路径,此时上传文件的路径以.php3程序里定义的路径为基准。在下例中,receiver.php3文件就指定了用于存放上传文件的目录是:d:\upload。
upload_max_filesize 是用来限制PHP处理的上载文件大小的最大值,以字节计算,缺省值为2097152= 2*1024*1024字节(2兆),你可以通过修改该缺省值来定义最大的上载文件大小。
修改后不要忘了重启Apache,IIS或PWS服务哦。
同时在PHP中,文件上载还有几点是值得注意的:
1. 在form表单中要将method属性设为post,enctype属性设为multipart/form-data;
2. 在form表单中可以加一个hidden类型的input框,其中名字为 MAX_FILE_SIZE的隐藏值域,通过设置其VALUE可以限制上载文件的大小。当然,这个值不可能超过PHP的配置文件(PHP3为php3.ini,PHP4为php.ini)中的upload_max_filesize,注意这个input框一定要放在所有file类型的input框前面,否则也是无效的哦;
3. 在PHP程序运行完后,上传文件被放在了临时目录下。如果上传文件没有被改名或移动,那么在请求的最后该文件将自动被从临时文件夹中删除,所以我们最好立即将新的上传文件上传移到一个永久目录下或更改其文件名。
首先我们需要一个上载文件的表单网页(upload.htm):
| 代码: |
<HTML> <HEAD> <TITLE>Upload Your File</TITLE> </HEAD> <BODY> <FORM ACTION="receiver.php3" ENCTYPE="multipart/form-data" METHOD=POST> <INPUT TYPE="HIDDEN" NAME="MAX_FILE_SIZE" VALUE="2000000"> <INPUT TYPE="FILE" N ="uploadfile" SIZE="24" MAXLENGTH="80"> <BR><BR> <INPUT TYPE="SUBMIT" VALUE="Upload File!" NAME="sendit"> <INPUT TYPE="SUBMIT" VALUE="Cancel" NAME="cancelit"><BR> </FORM> </BODY> </HTML> |
处理上载文件的PHP文件(receiver.php3)
| 代码: |
<? function do_upload () { global $uploadfile, $uploadfile_size; global $local_file, $error_msg; if ( $uploadfile == "none" ) { $error_msg = "对不起,你没有选定任何文件上传!"; return; } if ( $uploadfile_size > 2000000 ) { $error_msg = "对不起,你要上传的文件太大了!"; return; } $the_time = time ();
// 在这里指定你用来存放上传文件的目录,你需要对以下目录有写权限 // 同时,我们也可以给上传文件指定另外的目录,如:$upload_dir = "/local/uploads";
$upload_dir = "d:/upload"; $local_file = "$upload_dir/$the_time"; if ( file_exists ( $local_file ) ) { $seq = 1; while ( file_exists ( "$upload_dir/$the_time$seq" ) ) { $seq++; } $local_file = "$upload_dir/$the_time$seq"; }; rename ( $uploadfile, $local_file ); display_page (); } function display_page () { // 这里是你的页面内容 } ?> <HTML> <HEAD> <TITLE>php3 Receiving Script</TITLE> </HEAD> <BODY> <? if ( $error_msg ) { echo "<B>$error_msg</B><BR><BR>"; } if ( $sendit ) { do_upload (); echo "文件上载成功!"; } elseif ( $cancelit ) { header ( "Location: $some_other_script" ); echo "文件上载失败!"; exit; } else { some_other_func (); } ?> </BODY> </HTML> |
最近在解析一个天气预报的xml文件时,发现它里面所有的汉字都转化为了html实体(十进制表示的Unicode编码),这样做的好处就是不管网页的编码是什么,都可以正常的显示汉字,而不会出现乱码,当然也适用于其他字符集。
在php中我们可以用
mbstring的mb_convert_encoding函数实现这个正向及反向的转化。
如:
mb_convert_encoding ("你好", "HTML-ENTITIES", "gb2312"); //输出:你好
mb_convert_encoding ("你好", "gb2312", "HTML-ENTITIES"); //输出:你好
可以查看这个页面:htmlentities.html, 不管选择什么网页编码,网页都能正常显示。
如果需要对整个页面转化,则只需要在php文件的头部加上这三行代码:
mb_internal_encoding("gb2312"); // 这里的gb2312是你网站原来的编码
mb_http_output("HTML-ENTITIES");
ob_start('mb_output_handler');
PS:要打开mbstring扩展在asp中我们可以用下面这个函数来实现这个转化:
Function htmlentities(str)
For i = 1 to Len(str)
char = mid(str, i, 1)
If AscW(char) > 0 then
htmlentities = htmlentities & "&#" & Ascw(char) & ";"
Else
htmlentities = htmlentities & "&#" & (65536 + ascW(char)) & ";"
End if
Next
End Function
出自:
http://www.ugia.cn/?p=72#m...
模板制作技巧系列:让你的ECMS模板更“自动化”
这里只是说到我做模板的一些经验,不涉及程序,对HTML有所了解的话,更容易理解。我所列的都是以我制作的大观园网站为例子,希望能起个抛砖引玉的作用。。具体要做什么样的效果,大家可以多动手试下
以中华大观园为例
http://www.5000sky.com/
一、使用公共模板变量定义通用部分
一般可建立[!--temp.header--] ,[!--temp.footer--],[!--temp.sitename--],[!-- temp.search--]之类的常用部分。然后在页面需要插入的地方直接插入。好处是修改时只需要修改这个变量,不必每个模板页去都去改。
注意:动态页面,如搜索,评论等不支持公共模板变量
二、网站通用导航(所有一级栏目)
在3.7版本以前,只能手工设定,3.7新增的带模板的导航标签可以实现
页面模板内容:
[!--empirenews.listtemp--]<!--list.var1-->[!--empirenews.listtemp--]
列表内容模板
(list.var)
<a href="[!--classurl--]" title="[!--classname--]">[!--classname--]</a> |
标签调用 [showclasstemp]0,标签模板ID,0[/showclasstemp]
注意:如果在栏目页显示的是当前栏目的导航,可以加上单引号"0"——我是这样做的。如果ID号填的是为某个栏目的ID,则为特定栏目的导航
数据库连接
<?
$hostname="localhost"; //数据库地址可以用IP
$username="username"; //用户名称
$userpassword="14589abc"; //用户密码
$database="e-boy"; //数据库名称
$c_id=mysql_connect($hostname,$username,$userpassword);
mysql_select_db($database,$c_id);
///////////////////////////////////////////////////////////// 数据库连
?>
系例数据段显示方法一
<?
$showdata=mysql_query("select * from pw_smiles",$c_id);
while ($row=mysql_fetch_array($showdata))
{
echo $row["字段名"];
//......//
}
?>
系例数据段显示方法二
$result=mysql_db_query($database,"select * from book");
while ($row=mysql_fetch_array($result))
{
echo $row[book_name]."<br>";
//......其它数据显示....//
}
单数条记录数据显示方法
<?
require("conn.php");
$c_db=mysql_select_db($dbase,$c_id);
$s_book=mysql_query("select * from book",$c_id);
$row=mysql_fetch_row($s_book);
echo $row[2];
?>
显示记录当中的几条记录
<?
$s_db=mysql_db_query($dbase,"select * from book order by book_id desc");
$record_total=mysql_num_rows($s_db); ///记录的总数
$book=mysql_fetch_assoc($s_db);
//while($book=mysql_fetch_assoc($s_db)) ////
for($i=1;$i<=5;$i++)
{
echo $book["book_name"]."<br>";
$book=mysql_fetch_assoc($s_db);
}
?>
/////////////////////////////////////////////////////////////////////
判断一个变量是否存在的方法:
<?
if(isset($name)) echo $name;
?>
/////////////////////////////////////////////////////////////////////
自动转向代码
<?php
header("Location:
http://biz.260v.com/biz");
?>
//////////////////////////////////////////////////////////////////////
sql语句
查询
select * form 表单 where 条件 order by 字段 desc/asc;
增加
insert into 表单 values ('字段0','字段1','字段2', ...... ,'字段n');
更新
update book set book_name='$book_name',book_age='$book_age',book_address='$book_address',book_content='$book_content' where book_id=$book_id
删除表单
delete from 表单 where 条件;
前10条记录:select * from table limit 0,10
第11至20条记录:select * from table limit 10,10
第21至30条记录:select * from table limit 20,10
//////////////////////////////////////////////////////////////////////
分页显示代码
2、原理
所谓分页显示,也就是将数据库中的结果集人为的分成一段一段的来显示,这里需要两个初始的参数:
每页多少条记录($PageSize)?
当前是第几页($CurrentPageID)?
现在只要再给我一个结果集,我就可以显示某段特定的结果出来。
至于其他的参数,比如:上一页($PreviousPageID)、下一页($NextPageID)、总页数($numPages)等等,都可以根据前边这几个东西得到。
以mysql数据库为例,如果要从表内截取某段内容,sql语句可以用:select * from table limit offset, rows。看看下面一组sql语句,尝试一下发现其中的规率。
前10条记录:select * from table limit 0,10
第11至20条记录:select * from table limit 10,10
第21至30条记录:select * from table limit 20,10
……
这一组sql语句其实就是当$PageSize=10的时候取表内每一页数据的sql语句,我们可以总结出这样一个模板:
select * from table limit ($CurrentPageID - 1) * $PageSize, $PageSize
拿这个模板代入对应的值和上边那一组sql语句对照一下看看是不是那么回事。搞定了最重要的如何获取数据的问题以后,剩下的就仅仅是传递参数,构造合适的sql语句然后使用php从数据库内获取数据并显示了。以下我将用具体代码加以说明。
$link = mysql_connect("localhost", "mysql_user", "mysql_password")
or die("Could not connect: " . mysql_error());
// 获取当前页数
if( isset($_GET['page']) ){
$page = intval( $_GET['page'] );
}
else{
$page = 1;
}
// 每页数量
$PageSize = 10;
// 获取总数据量
$sql = "select count(*) as amount from table";
$result = mysql_query($sql);
$row = mysql_fetch_row($result);
$amount = $row['amount'];
// 记算总共有多少页
if( $amount ){
if( $amount < $page_size ){ $page_count = 1; } //如果总数据量小于$PageSize,那么只有一页
if( $amount % $page_size ){//取总数据量除以每页数的余数
$page_count = (int)($amount / $page_size) + 1; //如果有余数,则页数等于总数据量除以每页数的结果取整再加一
}else{
$page_count = $amount / $page_size;//如果没有余数,则页数等于总数据量除以每页数的结果
}
}
else{
$page_count = 0;
}
// 翻页链接
$page_string = ';
if( $page == 1 ){
$page_string .= '第一页|上一页|';
}
else{
$page_string .= '第一页|上一页|';
}
if( ($page == $page_count) || ($page_count == 0) ){
$page_string .= '下一页|尾页';
}
else{
$page_string .= '下一页|尾页';
}
// 获取数据,以二维数组格式返回结果
if( $amount ){
$sql = "select * from table order by id desc limit ". ($page-1)*$page_size .", $page_size";
$result = mysql_query($sql);
while ( $row = mysql_fetch_row($result) ){
$rowset[] = $row;
}
}else{
$rowset = array();
}
基本输出 echo
如
<?php
echo ("Hello world!");
?>
=====================================================
调用包含文件 require("****.php") include("****.php")
区别
require("****.php"); //require 被调用的文件的内容成为调用文件的一部分.
include("****.php"); //include php解释过程中,才读入相关的部分.
=====================================================
常量
数值常量
如: 7854 02333 //八进制 0x1232 //十六进制
字符常量
如: 'a' 'b' 'c'
字符串常量
如: "I am chinese!"
常量的定义
<?
define("copyright","Copyright ? 2000,netleader.126.com");
echo copyright
?>
=====================================================
变量
变量的类型:
string //字符串
integer //整形
double //为浮点数
array //数组
object //对像变量
变量的声明
$names
只有在给赋值的时候才知道变的类型
动态变量
$ch=words;
$$ch=china;
echo "$ch";
=====================================================
PHPr的运算符
+ - * / %(取余) ++ 累加 -- 递减
. 可以将字符串连接起来如
$char1="I am a Chinese";
acho $char1."Are you shur!";
逻辑运算符
< > <= >= == != && //而且(and) AND //而且(and) || // 或者(or) OR 或者(or) Xor 异或 ! // 不(Not)