找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 774|回复: 0
打印 上一主题 下一主题

Php部分常见问题总结第1/2页

[复制链接]

2560

主题

2560

帖子

7622

积分

论坛元老

Rank: 8Rank: 8

积分
7622
跳转到指定楼层
楼主
发表于 2018-2-14 09:48:02 | 只看该作者 回帖奖励 |正序浏览 |阅读模式

            
若有出错地方或者你有更好的想法,欢迎跟贴.
[B]
在提问题前请先仔细查阅
PHP手册
,
MYSQL手册
  以及PHPINFO里面的设置
另外希望你读一下
PHP编程标准

[/B]
[I]PHP手册下载地址[/I]
[B]
1:为什么我得不到变量
[/B]
我在一网页向另一网页POST数据name,为什么输出$name时却得不到任何值?
在PHP4.2以后的版本中register_global默认为off
若想取得从另一页面提交的变量:
方法一:在PHP.ini中找到register_global,并把它设置为on.
方法二:在接收网页最前面放上这个extract($_POST);extract($_GET);(注意extract($_SESSION)前必须要有Session_Start()).
方法三:一个一个读取变量$a=$_GET["a"];$b=$_POST["b"]等,这种方法虽然麻烦,但比较安全.
[B]
2:调试你的程序
[/B]
在运行时必须知道某个变量为何值。我是这样做的,建立一文件debug.php,其内容如下:
CODE:
[Copy to clipboard]
();
[color=]Session_Start
();
Echo "";
Echo
[color=]"本页得到的_GET变量有:"
;
[color=]Print_R
(
[color=]$_GET
);
Echo
[color=]"本页得到的_POST变量有:"
;
[color=]Print_R
(
[color=]$_POST
);
Echo
[color=]"本页得到的_COOKIE变量有:"
;
[color=]Print_R
(
[color=]$_COOKIE
);
Echo
[color=]"本页得到的_SESSION变量有:"
;
[color=]Print_R
(
[color=]$_SESSION
);
Echo "";
[color=]?>
然后在php.ini中设置:include_path = "c:/php",并将debug.php放在此文件夹,
以后就可以在每个网页里包含此文件,查看得到的变量名和值.
[B]
3:如何使用session
[/B]
凡是与session有关的,之前必须调用函数session_start();
为session付值很简单,如:
CODE:
[Copy to clipboard]
();
[color=]$Name
=
[color=]"这是一个Session例子"
;
[color=]Session_Register
(
[color=]"Name"
);
//注意,不要写成:Session_Register("$Name");
Echo
[color=]$_SESSION
[
[color=]"Name"
];
//之后$_SESSION["Name"]为"这是一个Session例子"
[color=]?>
在php4.2之后,可以为session直接付值:
CODE:
[Copy to clipboard]
();
[color=]$_SESSION
[
[color=]"name"
]=
[color=]"value"
;
[color=]?>
取消session可以这样:
CODE:
[Copy to clipboard]
();
[color=]session_unset
();
[color=]session_destroy
();
[color=]?>
取消某个session变量在php4.2以上还有BUG.
注意:
[I]
1:在调用Session_Start()之前不能有任何输出.例如下面是错误的.[/I]
==========================================
1行
2行
==========================================
提示1:
凡是出现"........
headers already sent
..........",就是Session_Start()之前向浏览器输出信息.
去掉输出就正常,(COOKIE也会出现这种错误,错误原因一样)
提示2:
如果你的Session_Start()放在循环语句里,并且很难确定之前哪里向浏览器输出信息,可以用下面这种方法:
1行
........这里是你的程序......
[I]
2:这是什么错误[/I]
Warning: session_start(): open(/tmp\sess_7d190aa36b4c5ec13a5c1649cc2da23f, O_RDWR) failed:....
因为你没有指定session文件的存放路径.
解决方法:
(1)在c盘建立文件夹tmp
(2)打开php.ini,找到session.save_path,修改为session.save_path= "c:/tmp"
[B]
4:为什么我向另一网页传送变量时,只得到前半部分,以空格开头的则全部丢失[/B]
CODE:
[Copy to clipboard]
=
[color=]"hello php"
;
//修改为$Var="     hello php";试试得到什么结果
[color=]$post
=
[color=]"receive.php?Name="
.
[color=]$Var
;
[color=]header
(
[color=]"locationpost"
);
[color=]?>
receive.php的内容:
CODE:
[Copy to clipboard]
Echo
"";
Echo   
[color=]$_GET
[
[color=]"Name"
];
Echo "";
[color=]?>
正确的方法是:
CODE:
[Copy to clipboard]
=
[color=]"hello php"
;
[color=]$post
=
[color=]"receive.php?Name="
.
[color=]urlencode
(
[color=]$Var
);
[color=]header
(
[color=]"locationpost"
);
[color=]?>
在接收页面你不需要使用Urldecode(),变量会自动编码.
[B]
5:如何截取指定长度汉字而不会出现以"?>"结尾,超出部分以"..."代替
[/B]
一般来说,要截取的变量来自Mysql,首先要保证那个字段长度要足够长,一般为char(200),可以保持100个汉字,包括标点.
CODE:
[Copy to clipboard]
PHP
$str
=
[color=]"这个字符好长呀,^_^"
;
[color=]$Short_Str
=
[color=]showShort
(
[color=]$str
,
[color=]4
);
//截取前面4个汉字,结果为:这个字符...
Echo   
[color=]"$Short_Str"
;
Function
[color=]csubstr
(
[color=]$str
,
[color=]$start
,
[color=]$len
)
{
[color=]$strlen
=
[color=]strlen
(
[color=]$str
);
[color=]$clen
=
[color=]0
;
for(
[color=]$i
=
[color=]0
;
[color=]$i
[color=]$strlen
;
[color=]$i
++,
[color=]$clen
++)
{
if (
[color=]$clen
>=
[color=]$start
+
[color=]$len
)
break;
if(
[color=]ord
(
[color=]substr
(
[color=]$str
,
[color=]$i
,
[color=]1
))>
[color=]0xa0
)
{
if (
[color=]$clen
>=
[color=]$start
)
[color=]$tmpstr
.=
[color=]substr
(
[color=]$str
,
[color=]$i
,
[color=]2
);
[color=]$i
++;
}
else
{
if (
[color=]$clen
>=
[color=]$start
)
[color=]$tmpstr
.=
[color=]substr
(
[color=]$str
,
[color=]$i
,
[color=]1
);
}
}
return
[color=]$tmpstr
;
}
Function
[color=]showShort
(
[color=]$str
,
[color=]$len
)
{
[color=]$tempstr
=
[color=]csubstr
(
[color=]$str
,
[color=]0
,
[color=]$len
);
if (
[color=]$str
[color=]$tempstr
)
[color=]$tempstr
.=
[color=]"..."
;
//要以什么结尾,修改这里就可以.
return
[color=]$tempstr
;
}
[color=]?>
[B]
6:规范你的SQL语句
[/B]
在表格,字段前面加上"
`
",这样就不会因为误用
关键字
而出现错误,
当然我并不推荐你使用
关键字
.
例如
$Sql="INSERT INTO
`
xltxlm
`
(
`
author
`
,
`
title
`
,
`
id
`
,
`
content
`
,
`
date
`
) VALUES ('xltxlm', 'use`', 1, 'criterion your sql string ', '2003-07-11 00:00:00')"
"
`
"怎么输入? 在TAB键上面.
[B]
7:如何使Html/PHP格式的字符串不被解释,而是照原样显示
[/B]
CODE:
[Copy to clipboard]
=
"HP";
Echo
[color=]"被解释过的: "
.
[color=]$str
.
"
经过处理的:";
Echo   
[color=]htmlentities
(
[color=]nl2br
(
[color=]$str
));
[color=]?>
[B]
8:怎么在函数里取得函数外的变量值
[/B]
CODE:
[Copy to clipboard]
=
[color=]"HP"
;
[color=]foo
();
Function
[color=]foo
()
{
  global
[color=]$a
;
//删除这里看看是什么结果
  
Echo
[color=]"$a"
;
}
[color=]?>
[B]
9:我怎么知道系统默认支持什么函数
[/B]
CODE:
[Copy to clipboard]
=
[color=]get_defined_functions
();
Function
[color=]php
() {
}
echo   "";
Echo   
[color=]"这里显示系统所支持的所有函数,和自定以函数phpn"
;
[color=]print_r
(
[color=]$arr
);
echo   "";
[color=]?>
[B]
10:如何比较两个日期相差几天
[/B]
CODE:
[Copy to clipboard]
=
[color=]"2003-7-15"
;
//也可以是Date_1="2003-6-25 23:29:14";
[color=]$Date_2
=
[color=]"1982-10-1"
;
[color=]$Date_List_1
=
[color=]explode
(
[color=]"-"
,
[color=]$Date_1
);
[color=]$Date_List_2
=
[color=]explode
(
[color=]"-"
,
[color=]$Date_2
);
[color=]$d1
=
[color=]mktime
(
[color=]0
,
[color=]0
,
[color=]0
,
[color=]$Date_List_1
[
[color=]1
],
[color=]$Date_List_1
[
[color=]2
],
[color=]$Date_List_1
[
[color=]0
]);
[color=]$d2
=
[color=]mktime
(
[color=]0
,
[color=]0
,
[color=]0
,
[color=]$Date_List_2
[
[color=]1
],
[color=]$Date_List_2
[
[color=]2
],
[color=]$Date_List_2
[
[color=]0
]);
[color=]$Days
=
[color=]round
((
[color=]$d1
-
[color=]$d2
)/
[color=]3600
/
[color=]24
);
Echo   
[color=]"偶已经奋斗了 $Days 天^_^"
;
[color=]?>
[B]
11:为什么我升级PHP后,原来的程序出现满屏的 Notice: Undefined variable:
[/B]
这是警告的意思,由于变量未定义引起的.
打开php.ini,找到
最下面
的error_reporting,修改为error_reporting = E_ALL & ~E_NOTICE
对于Parse error错误
error_reporting(0)无法关闭.
如果你想关闭任何错误提示,打开php.ini,找到display_errors,设置为display_errors = Off.以后任何错误都不会提示.
那什么是
error_reporting
?
[B]
12:我想在每个文件最前,最后面都加上一文件.但一个一个添加很麻烦
[/B]
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;依附在尾部
[I]以后你每个php文件就相当于[/I]
CODE:
[Copy to clipboard]
Include
[color=]"auto_prepend_file.php"
;
.......//这里是你的程序
Include
[color=]"auto_append_file.php"
;
[color=]?>
[B]
13:如何利用PHP上传文件
[/B]
CODE:
[Copy to clipboard]
上载文件表单


请选择文件:





=
[color=]$_FILES
[
[color=]'upload_file'
][
[color=]'tmp_name'
];
[color=]$upload_file_name
=
[color=]$_FILES
[
[color=]'upload_file'
][
[color=]'name'
];
if(
[color=]$upload_file
){
[color=]$file_size_max
=
[color=]1000
*
[color=]1000
;
// 1M限制文件上传最大容量(bytes)
[color=]$store_dir
=
[color=]"d:/"
;
// 上传文件的储存位置
[color=]$accept_overwrite
=
[color=]1
;
//是否允许覆盖相同文件
// 检查文件大小
if (
[color=]$upload_file_size
>
[color=]$file_size_max
) {
echo
[color=]"对不起,你的文件容量大于规定"
;
exit;
}
// 检查读写文件
if (
[color=]file_exists
(
[color=]$store_dir
.
[color=]$upload_file_name
) && !
[color=]$accept_overwrite
) {
Echo   
[color=]"存在相同文件名的文件"
;
exit;
}
//复制文件到指定目录
if (!
[color=]move_uploaded_file
(
[color=]$upload_file
,
[color=]$store_dir
.
[color=]$upload_file_name
)) {
echo
[color=]"复制文件失败"
;
exit;
}
}
Echo   "你上传了文件:";
echo  
[color=]$_FILES
[
[color=]'upload_file'
][
[color=]'name'
];
echo "
";
//客户端机器文件的原名称。
Echo   
[color=]"文件的 MIME 类型为:"
;
echo
[color=]$_FILES
[
[color=]'upload_file'
][
[color=]'type'
];
//文件的 MIME 类型,需要浏览器提供该信息的支持,例如“image/gif”。
echo
"
";
Echo   
[color=]"上传文件大小:"
;
echo
[color=]$_FILES
[
[color=]'upload_file'
][
[color=]'size'
];
//已上传文件的大小,单位为字节。
echo
"
";
Echo   
[color=]"文件上传后被临时储存为:"
;
echo
[color=]$_FILES
[
[color=]'upload_file'
][
[color=]'tmp_name'
];
//文件被上传后在服务端储存的临时文件名。
echo
"
";
[color=]$Erroe
=
[color=]$_FILES
[
[color=]'upload_file'
][
[color=]'error'
];
switch(
[color=]$Erroe
){
        case
[color=]0
:
            Echo   
[color=]"上传成功"
; break;
        case
[color=]1
:
            Echo   
[color=]"上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值."
; break;
        case
[color=]2
:
            Echo   
[color=]"上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。"
;    break;
        case
[color=]3
:
            Echo   
[color=]"文件只有部分被上传"
;break;
        case
[color=]4
:
            Echo   
[color=]"没有文件被上传"
;break;
}
[color=]?>
[B]
14:如何配置GD库
[/B]
下面是我的配置过程
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:运行下面程序进行测试
CODE:
[Copy to clipboard]
();
//注意,在此之前不能向浏览器输出任何信息,要注意是否设置了 auto_prepend_file.
[color=]header
(
[color=]"Content-type: image/png"
);
[color=]$im
= @
[color=]imagecreate
(
[color=]200
,
[color=]100
)
    or die (
[color=]"无法创建图像"
);
[color=]$background_color
=
[color=]imagecolorallocate
(
[color=]$im
,
[color=]0
,
[color=]0
,
[color=]0
);
[color=]$text_color
=
[color=]imagecolorallocate
(
[color=]$im
,
[color=]230
,
[color=]140
,
[color=]150
);
[color=]imagestring
(
[color=]$im
,
[color=]3
,
[color=]30
,
[color=]50
,  
[color=]"A Simple Text String"
,
[color=]$text_color
);
[color=]imagepng
(
[color=]$im
);
[color=]?>

点击这里查看结果


[B]
15:什么是UBB代码
[/B]

UBB代码是HTML的一个变种,是Ultimate Bulletin Board (国外一个BBS程序,国内也有不少地方使用这个程序)采用的一种特殊的TAG.
即使禁止使用 HTML,你也可以用 UBBCode? 来实现.也许你更希望使用 UBBCode? 而不是 HTML, 即使论坛允许使用 HTML, 因为使用起来代码较少也更安全.

Q3boy的UBB
里面付有例子,可以直接运行测试
[B]
16:我想修改MySQL的用户,密码
[/B]
首先要声明一点,大部分情况下,修改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口令加密的同样方法施行口令加密。
[B]
17:我想知道他是通过哪个网站连接到本页
[/B]
CODE:
[Copy to clipboard]
//必须通过超级连接进入才有输出
Echo
[color=]$_SERVER
[
[color=]'HTTP_REFERER'
];
[color=]?>
[B]
18:数据放入数据库和取出来显示在页面需要注意什么
[/B]
入库时
$str=addslashes($str);
$sql="insert into `tab` (`content`) values('$str')";
出库时
$str=stripslashes($str);
显示时
$str=htmlspecialchars(nl2br($str)) ;
[B]
19:如何读取当前地址栏信息
[/B]
CODE:
[Copy to clipboard]
=
[color=]"http://{$_SERVER['HTTP_HOST']}:{$_SERVER["SERVER_PORT"]}{$_SERVER['SCRIPT_NAME']}"
;
[color=]$se
=
[color=]''
;
foreach (
[color=]$_GET
as
[color=]$key
=>
[color=]$value
) {     
[color=]$se
.=
[color=]$key
.
[color=]"="
.
[color=]$value
.
[color=]"&"
;     
}   
[color=]$se
=
[color=]Preg_Replace
(
[color=]"/(.*)&$/"
,
[color=]"$1"
,
[color=]$se
);
[color=]$se
?
[color=]$se
=
[color=]"?"
.
[color=]$se
:
[color=]""
;
echo   
[color=]$s
.
[color=]"?$se"
;
[color=]?>
[B]
20:我点击后退按钮,为什么之前填写的东西不见
[/B]
这是因为你使用了session.
解决办法:
CODE:
[Copy to clipboard]
(
[color=]'private, must-revalidate'
);
[color=]session_start
();
...........
..........
[color=]?>
[B]
21:怎么在图片里显示IP地址
[/B]
CODE:
[Copy to clipboard]
(
[color=]"Content-type: image/png"
);
  
[color=]$
=
[color=]ImageCreate
(
[color=]180
,
[color=]50
);
  
[color=]$ip
=
[color=]$_SERVER
[
[color=]'REMOTE_ADDR'
];
  
[color=]ImageColorTransparent
(
[color=]$img
,
[color=]$bgcolor
);
  
[color=]$bgColor
=
[color=]ImageColorAllocate
(
[color=]$img
,
[color=]0x2c
,
[color=]0x6D
,
[color=]0xAF
);
// 背景颜色
  
[color=]$shadow
=
[color=]ImageColorAllocate
(
[color=]$img
,
[color=]250
,
[color=]0
,
[color=]0
);   
// 阴影颜色
  
[color=]$textColor
=
[color=]ImageColorAllocate
(
[color=]$img
,
[color=]oxff
,
[color=]oxff
,
[color=]oxff
);      
// 字体颜色
  
[color=]ImageTTFText
(
[color=]$img
,
[color=]10
,
[color=]0
,
[color=]78
,
[color=]30
,
[color=]$shadow
,
[color=]"d:/windows/fonts/Tahoma.ttf"
,
[color=]$ip
);
//显示背景
  
[color=]ImageTTFText
(
[color=]$img
,
[color=]10
,
[color=]0
,
[color=]25
,
[color=]28
,
[color=]$textColor
,
[color=]"d:/windows/fonts/Tahoma.ttf"
,
[color=]"your ip is"
.
[color=]$ip
);
// 显示IP
  
[color=]ImagePng
(
[color=]$img
);
  
[color=]imagecreatefrompng
(
[color=]$img
);
  
[color=]ImageDestroy
(
[color=]$img
);
[color=]?>
[B]
22:如何取得用户的真实IP
[/B]
CODE:
[Copy to clipboard]
function
[color=]iptype1
() {
if (
[color=]getenv
(
[color=]"HTTP_CLIENT_IP"
)) {
   return
[color=]getenv
(
[color=]"HTTP_CLIENT_IP"
);
}
else {
   return
[color=]"none"
;
}
}
function
[color=]iptype2
() {
if (
[color=]getenv
(
[color=]"HTTP_X_FORWARDED_FOR"
)) {
   return
[color=]getenv
(
[color=]"HTTP_X_FORWARDED_FOR"
);
}
else {
   return
[color=]"none"
;
}
}
function
[color=]iptype3
() {
if (
[color=]getenv
(
[color=]"REMOTE_ADDR"
)) {
   return
[color=]getenv
(
[color=]"REMOTE_ADDR"
);
}
else {
   return
[color=]"none"
;
}
}
function
[color=]ip
() {
[color=]$ip1
=
[color=]iptype1
();
  
[color=]$ip2
=
[color=]iptype2
();
[color=]$ip3
=
[color=]iptype3
();
if (isset(
[color=]$ip1
) &&
[color=]$ip1
!=
[color=]"none"
&&
[color=]$ip1
!=
[color=]"unknown"
) {
   return
[color=]$ip1
;
}
elseif (isset(
[color=]$ip2
) &&
[color=]$ip2
!=
[color=]"none"
&&
[color=]$ip2
!=
[color=]"unknown"
) {
   return
[color=]$ip2
;
}
elseif (isset(
[color=]$ip3
) &&
[color=]$ip3
!=
[color=]"none"
&&
[color=]$ip3
!=
[color=]"unknown"
) {
   return
[color=]$ip3
;
}   
  else {
  return
[color=]"none"
;
}
}
Echo
[color=]ip
();
[color=]?>
[B]
23:如何从数据库读取三天内的所有记录[/B]
首先表格里要有一个DATETIME字段记录时间,
格式为'2003-7-15 16:50:00'
SELECT *  FROM `xltxlm` WHERE TO_DAYS(NOW()) - TO_DAYS(`date`) [B]
24:如何远程链接Mysql数据库
[/B]
在增加用户的mysql表里有一个host字段,修改为"%",或者指定允许连接的ip地址,这样,你就可以远程调用了。
$link=mysql_connect("192.168.1.80:3306","root","");
[B]
25:正则到底怎么用
[/B]
点击这里
正则表达式中的特殊字符
[B]
26:用Apache后,主页出现乱码
[/B]
方法一:
AddDefaultCharset ISO-8859-1 改为 AddDefaultCharset off
方法二:
AddDefaultCharset
GB
2312
========================================================
tip:
大家贴代码时
GB
2312会被解释成
??????
改成这样就不会
[color=
#000000]GB
[/color
]2312
========================================================
暂时写到这里,由于贴子过于分散,不便于阅读,我集中了一下,没有对内容进行分类,希望对你有用.
以后还有问题我会跟贴,不再编辑此贴
            1[url=]2[/url][url=]下一页[/url][url=]阅读全文[/url]
            
        
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

用户反馈
客户端