| 
 UID2033152 威望1 点 金钱3090 金币 点卡0 点 
 | 
1#
 发表于 2004-6-6 19:34 
 | 只看该作者 
 [转帖]Php部分常见问题总结(强烈推荐)(二)
| 11:为什么我升级PHP后,原来的程序出现满屏的 Notice: Undefined variable: 
 
 这是警告的意思,由于变量未定义引起的.
 打开php.ini,找到最下面的error_reporting,修改为error_reporting = E_ALL & ~E_NOTICE
 
 对于Parse error错误
 error_reporting(0)无法关闭.
 如果你想关闭任何错误提示,打开php.ini,找到display_errors,设置为display_errors = Off.以后任何错误都不会提示.
 
 那什么是error_reporting?
 12:我想在每个文件最前,最后面都加上一文件.但一个一个添加很麻烦
 
 1:打开php.ini文件
 设置 include_path= "c:"
 
 2:写两个文件
 auto_prepend_file.php 和 auto_append_file.php 保存在c盘,他们将自动依附在每个php文件的头部和尾部.
 
 3:在php.ini中找到:
 Automatically add files before or after any PHP document.
 auto_prepend_file = auto_prepend_file.php;依附在头部
 auto_append_file = auto_append_file.php;依附在尾部
 
 以后你每个php文件就相当于
 13:如何利用PHP上传文件复制代码<?php Include "auto_prepend_file.php" ;.......//这里是你的程序Include "auto_append_file.php";?>
14:如何配置GD库复制代码<html><head><title>上载文件表单</title></head> <body> <form enctype="multipart/form-data" action="" method="post"> 请选择文件: <br><input name="upload_file" type="file"><br><input type="submit" value="上传文件"> </form> </body></html> <?$upload_file=$_FILES['upload_file']['tmp_name'];$upload_file_name=$_FILES['upload_file']['name'];if($upload_file){$file_size_max = 1000*1000;// 1M限制文件上传最大容量(bytes)$store_dir = "d:/";// 上传文件的储存位置$accept_overwrite = 1;//是否允许覆盖相同文件// 检查文件大小if ($upload_file_size > $file_size_max) {echo "对不起,你的文件容量大于规定";exit;}// 检查读写文件if (file_exists($store_dir . $upload_file_name) && !$accept_overwrite) {Echo   "存在相同文件名的文件";exit;}//复制文件到指定目录if (!move_uploaded_file($upload_file,$store_dir.$upload_file_name)) {echo "复制文件失败";exit;}}Echo   "<p>你上传了文件:";echo  $_FILES['upload_file']['name'];echo "<br>";//客户端机器文件的原名称。 Echo   "文件的 MIME 类型为:";echo $_FILES['upload_file']['type'];//文件的 MIME 类型,需要浏览器提供该信息的支持,例如“image/gif”。 echo "<br>";Echo   "上传文件大小:";echo $_FILES['upload_file']['size'];//已上传文件的大小,单位为字节。 echo "<br>";Echo   "文件上传后被临时储存为:";echo $_FILES['upload_file']['tmp_name'];//文件被上传后在服务端储存的临时文件名。 echo "<br>";$Erroe=$_FILES['upload_file']['error'];switch($Erroe){        case 0:            Echo   "上传成功"; break;        case 1:            Echo   "上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值."; break;        case 2:            Echo   "上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。";    break;        case 3:            Echo   "文件只有部分被上传";break;        case 4:            Echo   "没有文件被上传";break;}?>
 
 下面是我的配置过程
 1:用dos命令(也可以手动操作,拷贝dlls文件夹里所有dll文件到system32目录下) copy c:\php\dlls\*.dll c:\windows\system32\
 2:打开php.ini
 设置extension_dir = "c:/php/extensions/";
 3:
 extension=php_gd2.dll;把extension前面的逗号去掉,如果没有php_gd2.dll,php_gd.dll也一样,保证确实存在这一文件c:/php/extensions/php_gd2.dll
 4:运行下面程序进行测试
 15:什么是UBB代码复制代码<?phpOb_end_flush();//注意,在此之前不能向浏览器输出任何信息,要注意是否设置了 auto_prepend_file.header ("Content-type: image/png");$im = @imagecreate (200, 100)    or die ("无法创建图像");$background_color = imagecolorallocate ($im, 0,0, 0);$text_color = imagecolorallocate ($im, 230, 140, 150);imagestring ($im, 3, 30, 50,  "A Simple Text String", $text_color);imagepng ($im);?>
UBB代码是HTML的一个变种,是Ultimate Bulletin Board (国外一个BBS程序,国内也有不少地方使用这个程序)采用的一种特殊的TAG.
 即使禁止使用 HTML,你也可以用 UBBCode? 来实现.也许你更希望使用 UBBCode? 而不是 HTML, 即使论坛允许使用 HTML, 因为使用起来代码较少也更安全.
 
 Q3boy的UBB里面付有例子,可以直接运行测试
 
 16:我想修改MySQL的用户,密码
 
 首先要声明一点,大部分情况下,修改MySQL是需要有mysql里的root权限的,
 所以一般用户无法更改密码,除非请求管理员.
 
 方法一
 使用phpmyadmin,这是最简单的了,修改mysql库的user表,
 不过别忘了使用PASSWORD函数。
 
 方法二
 使用mysqladmin,这是前面声明的一个特例。
 mysqladmin -u root -p password mypasswd
 输入这个命令后,需要输入root的原密码,然后root的密码将改为mypasswd。
 把命令里的root改为你的用户名,你就可以改你自己的密码了。
 当然如果你的mysqladmin连接不上mysql server,或者你没有办法执行mysqladmin,
 那么这种方法就是无效的。
 而且mysqladmin无法把密码清空。
 
 下面的方法都在mysql提示符下使用,且必须有mysql的root权限:
 方法三
 mysql> INSERT INTO mysql.user (Host,User,Password)
 VALUES('%','jeffrey',PASSWORD('biscuit'));
 mysql> FLUSH PRIVILEGES
 确切地说这是在增加一个用户,用户名为jeffrey,密码为biscuit。
 在《mysql中文参考手册》里有这个例子,所以我也就写出来了。
 注意要使用PASSWORD函数,然后还要使用FLUSH PRIVILEGES。
 
 方法四
 和方法三一样,只是使用了REPLACE语句
 mysql> REPLACE INTO mysql.user (Host,User,Password)
 VALUES('%','jeffrey',PASSWORD('biscuit'));
 mysql> FLUSH PRIVILEGES
 
 方法五
 使用SET PASSWORD语句,
 mysql> SET PASSWORD FOR jeffrey@"%" = PASSWORD('biscuit');
 你也必须使用PASSWORD()函数,
 但是不需要使用FLUSH PRIVILEGES。
 
 方法六
 使用GRANT ... IDENTIFIED BY语句
 mysql> GRANT USAGE ON *.* TO jeffrey@"%" IDENTIFIED BY 'biscuit';
 这里PASSWORD()函数是不必要的,也不需要使用FLUSH PRIVILEGES。
 
 注意: PASSWORD() [不是]以在Unix口令加密的同样方法施行口令加密。
 
 17:我想知道他是通过哪个网站连接到本页
 18:数据放入数据库和取出来显示在页面需要注意什么复制代码<?php//必须通过超级连接进入才有输出Echo $_SERVER['HTTP_REFERER'];?>
 入库时
 $str=addslashes($str);
 $sql="insert into `tab` (`content`) values('$str')";
 出库时
 $str=stripslashes($str);
 显示时
 $str=htmlspecialchars(nl2br($str)) ;
 
 19:如何读取当前地址栏信息
 20:我点击后退按钮,为什么之前填写的东西不见复制代码<?php $s="http://{$_SERVER['HTTP_HOST']}:{$_SERVER["SERVER_PORT"]}{$_SERVER['SCRIPT_NAME']}"; $se=''; foreach ($_GET as $key => $value) {     $se.=$key."=".$value."&";     }   $se=Preg_Replace("/(.*)&$/","$1",$se); $se?$se="?".$se:"";echo   $s."?$se"; ?> 
 这是因为你使用了session.
 解决办法:
 21:怎么在图片里显示IP地址复制代码<?php session_cache_limiter('private, must-revalidate');session_start(); .....................?>
22:如何取得用户的真实IP复制代码<?  Header("Content-type: image/png");  $img = ImageCreate(180,50);  $ip = $_SERVER['REMOTE_ADDR'];  ImageColorTransparent($img,$bgcolor);  $bgColor = ImageColorAllocate($img, 0x2c,0x6D,0xAF); // 背景颜色  $shadow = ImageColorAllocate($img, 250,0,0);    // 阴影颜色  $textColor = ImageColorAllocate($img, oxff,oxff,oxff);       // 字体颜色  ImageTTFText($img,10,0,78,30,$shadow,"d:/windows/fonts/Tahoma.ttf",$ip); //显示背景  ImageTTFText($img,10,0,25,28,$textColor,"d:/windows/fonts/Tahoma.ttf","your ip is".$ip); // 显示IP  ImagePng($img);  imagecreatefrompng($img);  ImageDestroy($img);?>
23:如何从数据库读取三天内的所有记录复制代码<? function iptype1 () { if (getenv("HTTP_CLIENT_IP")) {    return getenv("HTTP_CLIENT_IP"); } else {    return "none"; } } function iptype2 () { if (getenv("HTTP_X_FORWARDED_FOR")) {    return getenv("HTTP_X_FORWARDED_FOR"); } else {    return "none"; } } function iptype3 () { if (getenv("REMOTE_ADDR")) {    return getenv("REMOTE_ADDR"); } else {    return "none"; } } function ip() { $ip1 = iptype1();   $ip2 = iptype2(); $ip3 = iptype3(); if (isset($ip1) && $ip1 != "none" && $ip1 != "unknown") {    return $ip1; } elseif (isset($ip2) && $ip2 != "none" && $ip2 != "unknown") {    return $ip2; } elseif (isset($ip3) && $ip3 != "none" && $ip3 != "unknown") {    return $ip3; }     else {   return "none"; } } Echo ip(); ?> 
 首先表格里要有一个DATETIME字段记录时间,
 格式为'2003-7-15 16:50:00'
 
 SELECT * FROM `xltxlm` WHERE TO_DAYS(NOW()) - TO_DAYS(`date`) <= 3;
 
 
 24:如何远程链接Mysql数据库
 
 
 在增加用户的mysql表里有一个host字段,修改为"%",或者指定允许连接的ip地址,这样,你就可以远程调用了。
 
 $link=mysql_connect("192.168.1.80:3306","root","");
 
 
 25:正则到底怎么用
 
 点击这里
 正则表达式中的特殊字符
 
 
 26:用Apache后,主页出现乱码
 
 
 方法一:
 AddDefaultCharset ISO-8859-1 改为 AddDefaultCharset off
 
 方法二:
 AddDefaultCharset GB2312
 ========================================================
 tip:
 大家贴代码时GB2312会被解释成??????
 
 改成这样就不会
 GB2312
 
 ========================================================
 
 
 
 | 
 |