Php部分常见问题总结第1/2页
程序员文章站
2022-09-20 10:30:36
若有出错地方或者你有更好的想法,欢迎跟贴. 在提问题前请先仔细查阅php手册,mysql手册 以及phpinfo里面的设置 另外希望你读一下php编程...
若有出错地方或者你有更好的想法,欢迎跟贴.
在提问题前请先仔细查阅php手册,mysql手册 以及phpinfo里面的设置
另外希望你读一下php编程标准
1:为什么我得不到变量
我在一网页向另一网页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"]等,这种方法虽然麻烦,但比较安全.
2:调试你的程序
在运行时必须知道某个变量为何值。我是这样做的,建立一文件debug.php,其内容如下:
<?php
ob_start();
session_start();
echo "<pre>";
echo "本页得到的_get变量有:";
print_r($_get);
echo "本页得到的_post变量有:";
print_r($_post);
echo "本页得到的_cookie变量有:";
print_r($_cookie);
echo "本页得到的_session变量有:";
print_r($_session);
echo "</pre>";
?>
然后在php.ini中设置:include_path = "c:/php",并将debug.php放在此文件夹,
以后就可以在每个网页里包含此文件,查看得到的变量名和值.
3:如何使用session
凡是与session有关的,之前必须调用函数session_start();
为session付值很简单,如:
<?php
session_start();
$name = "这是一个session例子";
session_register("name");//注意,不要写成:session_register("[color=red]$name[/color]");
echo $_session["name"];
//之后$_session["name"]为"这是一个session例子"
?>
在php4.2之后,可以为session直接付值:
<?php
session_start();
$_session["name"]="value";
?>
取消session可以这样:
<?php
session_start();
session_unset();
session_destroy();
?>
取消某个session变量在php4.2以上还有bug.
注意:
1:在调用session_start()之前不能有任何输出.例如下面是错误的.
==========================================
1行
2行 <?php
3行 session_start();//之前在第一行已经有输出
4行 .....
5行 ?>
==========================================
提示1:
凡是出现"........headers already sent..........",就是session_start()之前向浏览器输出信息.
去掉输出就正常,(cookie也会出现这种错误,错误原因一样)
提示2:
如果你的session_start()放在循环语句里,并且很难确定之前哪里向浏览器输出信息,可以用下面这种方法:
1行 <?php ob_start(); ?>
........这里是你的程序......
2:这是什么错误
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"
4:为什么我向另一网页传送变量时,只得到前半部分,以空格开头的则全部丢失
<?php
$var="hello php";//修改为$var=" hello php";试试得到什么结果
$post= "receive.php?name=".$var;
header("location:$post");
?>
receive.php的内容:
<?php
echo "<pre>";
echo $_get["name"];
echo "</pre>";
?>
正确的方法是:
<?php
$var="hello php";
$post= "receive.php?name=".urlencode($var);
header("location:$post");
?>
在接收页面你不需要使用urldecode(),变量会自动编码.
5:如何截取指定长度汉字而不会出现以"?>"结尾,超出部分以"..."代替
一般来说,要截取的变量来自mysql,首先要保证那个字段长度要足够长,一般为char(200),可以保持100个汉字,包括标点.
<?php
<?php
$str="这个字符好长呀,^_^";
$short_str=showshort($str,4);//截取前面4个汉字,结果为:这个字符...
echo "$short_str";
function csubstr($str,$start,$len)
{
$strlen=strlen($str);
$clen=0;
for($i=0;$i<$strlen;$i++,$clen++)
{
if ($clen>=$start+$len)
break;
if(ord(substr($str,$i,1))>0xa0)
{
if ($clen>=$start)
$tmpstr.=substr($str,$i,2);
$i++;
}
else
{
if ($clen>=$start)
$tmpstr.=substr($str,$i,1);
}
}
return $tmpstr;
}
function showshort($str,$len)
{
$tempstr = csubstr($str,0,$len);
if ($str<>$tempstr)
$tempstr .= "..."; //要以什么结尾,修改这里就可以.
return $tempstr;
}
?>
6:规范你的sql语句
在表格,字段前面加上"`",这样就不会因为误用关键字而出现错误,
当然我并不推荐你使用关键字.
例如
$sql="insert into `xltxlm` (`author`, `title`, `id`, `content`, `date`) values ('xltxlm', 'use`', 1, 'criterion your sql string ', '2003-07-11 00:00:00')"
"`"怎么输入? 在tab键上面.
7:如何使html/php格式的字符串不被解释,而是照原样显示
<?php
$str="<h1>php</h1>";
echo "被解释过的: ".$str."<br>经过处理的:";
echo htmlentities(nl2br($str));
?>
8:怎么在函数里取得函数外的变量值
<?php
$a="php";
foo();
function foo()
{
global $a;//删除这里看看是什么结果
echo "$a";
}
?>
9:我怎么知道系统默认支持什么函数
<?php
$arr = get_defined_functions();
function php() {
}
echo "<pre>";
echo "这里显示系统所支持的所有函数,和自定以函数phpn";
print_r($arr);
echo "</pre>";
?>
10:如何比较两个日期相差几天
<?php
$date_1="2003-7-15";//也可以是:$date_1="2003-6-25 23:29:14";
$date_2="1982-10-1";
$date_list_1=explode("-",$date_1);
$date_list_2=explode("-",$date_2);
$d1=mktime(0,0,0,$date_list_1[1],$date_list_1[2],$date_list_1[0]);
$d2=mktime(0,0,0,$date_list_2[1],$date_list_2[2],$date_list_2[0]);
$days=round(($d1-$d2)/3600/24);
echo "偶已经奋斗了 $days 天^_^";
?>
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文件就相当于
<?php
include "auto_prepend_file.php" ;
.......//这里是你的程序
include "auto_append_file.php";
?>
13:如何利用php上传文件
<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;
}
?>
14:如何配置gd库
下面是我的配置过程
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:运行下面程序进行测试
<?php
ob_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);
?>
点击这里查看结果
15:什么是ubb代码
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:我想知道他是通过哪个网站连接到本页
<?php
//必须通过超级连接进入才有输出
echo $_server['http_referer'];
?>
18:数据放入数据库和取出来显示在页面需要注意什么
入库时
$str=addslashes($str);
$sql="insert into `tab` (`content`) values('$str')";
出库时
$str=stripslashes($str);
显示时
$str=htmlspecialchars(nl2br($str)) ;
19:如何读取当前地址栏信息
<?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";
?>
在提问题前请先仔细查阅php手册,mysql手册 以及phpinfo里面的设置
另外希望你读一下php编程标准
1:为什么我得不到变量
我在一网页向另一网页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"]等,这种方法虽然麻烦,但比较安全.
2:调试你的程序
在运行时必须知道某个变量为何值。我是这样做的,建立一文件debug.php,其内容如下:
<?php
ob_start();
session_start();
echo "<pre>";
echo "本页得到的_get变量有:";
print_r($_get);
echo "本页得到的_post变量有:";
print_r($_post);
echo "本页得到的_cookie变量有:";
print_r($_cookie);
echo "本页得到的_session变量有:";
print_r($_session);
echo "</pre>";
?>
然后在php.ini中设置:include_path = "c:/php",并将debug.php放在此文件夹,
以后就可以在每个网页里包含此文件,查看得到的变量名和值.
3:如何使用session
凡是与session有关的,之前必须调用函数session_start();
为session付值很简单,如:
<?php
session_start();
$name = "这是一个session例子";
session_register("name");//注意,不要写成:session_register("[color=red]$name[/color]");
echo $_session["name"];
//之后$_session["name"]为"这是一个session例子"
?>
在php4.2之后,可以为session直接付值:
<?php
session_start();
$_session["name"]="value";
?>
取消session可以这样:
<?php
session_start();
session_unset();
session_destroy();
?>
取消某个session变量在php4.2以上还有bug.
注意:
1:在调用session_start()之前不能有任何输出.例如下面是错误的.
==========================================
1行
2行 <?php
3行 session_start();//之前在第一行已经有输出
4行 .....
5行 ?>
==========================================
提示1:
凡是出现"........headers already sent..........",就是session_start()之前向浏览器输出信息.
去掉输出就正常,(cookie也会出现这种错误,错误原因一样)
提示2:
如果你的session_start()放在循环语句里,并且很难确定之前哪里向浏览器输出信息,可以用下面这种方法:
1行 <?php ob_start(); ?>
........这里是你的程序......
2:这是什么错误
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"
4:为什么我向另一网页传送变量时,只得到前半部分,以空格开头的则全部丢失
<?php
$var="hello php";//修改为$var=" hello php";试试得到什么结果
$post= "receive.php?name=".$var;
header("location:$post");
?>
receive.php的内容:
<?php
echo "<pre>";
echo $_get["name"];
echo "</pre>";
?>
正确的方法是:
<?php
$var="hello php";
$post= "receive.php?name=".urlencode($var);
header("location:$post");
?>
在接收页面你不需要使用urldecode(),变量会自动编码.
5:如何截取指定长度汉字而不会出现以"?>"结尾,超出部分以"..."代替
一般来说,要截取的变量来自mysql,首先要保证那个字段长度要足够长,一般为char(200),可以保持100个汉字,包括标点.
<?php
<?php
$str="这个字符好长呀,^_^";
$short_str=showshort($str,4);//截取前面4个汉字,结果为:这个字符...
echo "$short_str";
function csubstr($str,$start,$len)
{
$strlen=strlen($str);
$clen=0;
for($i=0;$i<$strlen;$i++,$clen++)
{
if ($clen>=$start+$len)
break;
if(ord(substr($str,$i,1))>0xa0)
{
if ($clen>=$start)
$tmpstr.=substr($str,$i,2);
$i++;
}
else
{
if ($clen>=$start)
$tmpstr.=substr($str,$i,1);
}
}
return $tmpstr;
}
function showshort($str,$len)
{
$tempstr = csubstr($str,0,$len);
if ($str<>$tempstr)
$tempstr .= "..."; //要以什么结尾,修改这里就可以.
return $tempstr;
}
?>
6:规范你的sql语句
在表格,字段前面加上"`",这样就不会因为误用关键字而出现错误,
当然我并不推荐你使用关键字.
例如
$sql="insert into `xltxlm` (`author`, `title`, `id`, `content`, `date`) values ('xltxlm', 'use`', 1, 'criterion your sql string ', '2003-07-11 00:00:00')"
"`"怎么输入? 在tab键上面.
7:如何使html/php格式的字符串不被解释,而是照原样显示
<?php
$str="<h1>php</h1>";
echo "被解释过的: ".$str."<br>经过处理的:";
echo htmlentities(nl2br($str));
?>
8:怎么在函数里取得函数外的变量值
<?php
$a="php";
foo();
function foo()
{
global $a;//删除这里看看是什么结果
echo "$a";
}
?>
9:我怎么知道系统默认支持什么函数
<?php
$arr = get_defined_functions();
function php() {
}
echo "<pre>";
echo "这里显示系统所支持的所有函数,和自定以函数phpn";
print_r($arr);
echo "</pre>";
?>
10:如何比较两个日期相差几天
<?php
$date_1="2003-7-15";//也可以是:$date_1="2003-6-25 23:29:14";
$date_2="1982-10-1";
$date_list_1=explode("-",$date_1);
$date_list_2=explode("-",$date_2);
$d1=mktime(0,0,0,$date_list_1[1],$date_list_1[2],$date_list_1[0]);
$d2=mktime(0,0,0,$date_list_2[1],$date_list_2[2],$date_list_2[0]);
$days=round(($d1-$d2)/3600/24);
echo "偶已经奋斗了 $days 天^_^";
?>
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文件就相当于
<?php
include "auto_prepend_file.php" ;
.......//这里是你的程序
include "auto_append_file.php";
?>
13:如何利用php上传文件
<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;
}
?>
14:如何配置gd库
下面是我的配置过程
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:运行下面程序进行测试
<?php
ob_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);
?>
点击这里查看结果
15:什么是ubb代码
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:我想知道他是通过哪个网站连接到本页
<?php
//必须通过超级连接进入才有输出
echo $_server['http_referer'];
?>
18:数据放入数据库和取出来显示在页面需要注意什么
入库时
$str=addslashes($str);
$sql="insert into `tab` (`content`) values('$str')";
出库时
$str=stripslashes($str);
显示时
$str=htmlspecialchars(nl2br($str)) ;
19:如何读取当前地址栏信息
<?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";
?>
1
推荐阅读
-
PHP和Mysqlweb应用开发核心技术 第1部分 Php基础-3 代码组织和重用2
-
PHP和Mysqlweb应用开发核心技术-第1部分 Php基础-2 php语言介绍
-
Php部分常见问题总结
-
Php部分常见问题总结第1/2页
-
php SQLite学习笔记与常见问题分析第1/2页
-
PHP V5.2新增功能之第1部分:使用新的内存管理器_PHP教程
-
在AIX Version 5.3中使用Java和PHP技术进行开发,第1部分:设置Java环境_PHP教程
-
web开发 PHP和Mysqlweb应用开发核心技术 第1部分 Php基础-3 代码组织和重用2
-
web开发 PHP和Mysqlweb应用开发核心技术-第1部分 Php基础-2 php语言介绍
-
Windows Phone应用开发 PHP和Mysqlweb应用开发核心技术 第1部分 Php基础-1 开始了解php