燕之庐网站建设 - 优质网站设计公司

Archive for 10月 24th, 2009

php

2009/10/24

半个汉字变问号,求解决办法

Tags: ,

一句话中截取一部分,则有可能会出现半个汉字,则显示为问号.
若全是汉字,则可截取偶数字节,但有可以有标点符号,空格之类的就不好办了,求解决办法.

/**
* 截取中文部分字符串
*
* 截取指定字符串指定长度的函数,该函数可自动判定中英文,不会出现乱码
*
* @access public
* @param string    $str    要处理的字符串
* @param int       $strlen 要截取的长度默认为10
* @param string    $other  是否要加上省略号,默认会加上
* @return string
*/
function showtitle($str,$strlen=10,$other=true) {
    for($i=0;$i<$strlen;$i++)
      if(ord(substr($str,$i,1))>0xa0) $j++;
    if($j%2!=0) $strlen++;
    $rstr=substr($str,0,$strlen);
    if (strlen($str)>$strlen && $other) {$rstr.='...';}
    return $rstr;
}

我也做了一个,用于显示文件名 

$tmp_maxlen=22;
if (strlen($tmp_file)>$tmp_maxlen){
$i=0;
$ii=0;
while ($i<strlen($tmp_file)){
if (ord(substr($tmp_file,$i,1))>127){$ii++;}
if (($i>=$tmp_maxlen-3)&&($ii%2==0)){
$tmp_dispname=substr($tmp_file,0,$i-1).'...';
break;
}
$i++;
}
}else{$tmp_dispname=$tmp_file;}

我的方法:
[code:1:94c98032c6]
// 截取汉字文本串并保持汉字完整
function mysubstr($str, $N) {
if (strlen($str) <= $N) return $str; 

$i = 0;
$tmp = "";
while ($i <= $N) {
if (ord(substr($str,$i,1)) > 127) {
         $tmp .= substr($str,$i,2);
         $i = $i + 2;
         } else {
         $tmp .= substr($str,$i,1);
         $i = $i + 1;
     }
     } 

return $tmp;
}[/code:1:94c98032c6]

哈哈!!!!
开始我也打算和你们一样解决的,最后我发觉有Multi-Byte String Functions。
http://www.php.net/manual/en/ref.mbstring.php
  1. <?php
  2. $test = "这是1个用来测试的中文字符串";
  3. echo mb_substr($test, 0, 6, "EUC-JP");
  4. echo "<br><br>";
  5. echo substr($test, 0, 6);
  6. ?>
[/code:1:90dde3e5db] 

没有EUC-CN,只好EUC-JP了

php

用PHP编程开发“虚拟域名”系统

Tags: ,

转自:http://edu.mycodes.net/html/2006-04/238.shtml
如果自己的服务器也能够实现简记域名就好了。其实这并不复杂。你也可以做一个简记域名系统。

简记域名系统的关键技术在于:实现Web页面的重定向(Redirctory)。在本质上,简
记 域名系统和虚拟机系统完全不同。虚拟机的虚拟域名和IP是存在一一对应关系的。而简记域名系统不需要将域名和IP做一一映射。也就是说,它根本不需要复杂 的域名解析机制和虚拟机来完成,它所做的事情就是当你在请求yourname.somedomain时,将你的浏览器重新定向到你本来存放Html页面的 地方。

本程序运行环境是:RedHat 5.1 Linux下的Apache1.3.6 Web服务器+PHP3语言。在编写程序之前,我们首先要设置好我们的服务器。首先要让Apache服务器支持PHP3。到ftp.redhat.com下 载mod_PHP-2.0.1-9.i386.rpm,安装后,修改/etc/httpd/conf/http.conf文件,去 掉#LoadModule PHP3_module一句前面的#注释号,同样在/etc/httpd/conf/srm.conf文件里去掉#AddType application/x-httpd-PHP3 .PHP3前面的注释号,同时在DirectoryIndex一项后添加index.PHP3。重新启动Apache Server,此时服务器就支持标准的PHP3语言脚本文件了并能将index.PHP3作为默认的首页。

设置DNS服务器,使其能对 泛域名解析。一般的Unix和Linux系统的DNS解析都是由Bind守护程序完成的,Bind4和Bind8的配置文件分别/etc /named.boot和name.conf,配置时根据你的系统修改。设置Bind的配置文件/etc/named.boot,在其中加入 “primary domain.com db.domain”一句,添加一个新的域记录。在/etc/name.conf中加入:

zone “domain.com” {

type master;

file “db.domain”; };

在/var/name/中新建主域记录文件db.domain,其格式为:

N SOA dns.domain.com root.domain.com (

199811291 ;Serial

28800 ;refresh

7200 ;retry

604800 ;expire

86400) ;minimum

dns

MX 10 dns.domain.com.

dns A 202.115.135.50

www A 202.115.135.50

* A 202.115.135.50

关键是最后一句,即将整个域可能出现未做标记的所有Hostname全部指向同一IP。 执行/usr/sbin/ndc reload,重新加载域名数据库。测试一下,此时应该随便ping一个domain域内的主机(除已经标记的),都指向了指定的IP,那么DNS服务器 设置完成。

最后一步是编制PHP3脚本。我们刚才已经在图中详细的说明了整个的原理,所以写一个重新定向的程序就不是很难了。

让我们来看一个由IE5.0送出的完整HTTP头信息:

Accept: application/vnd.ms-excel, application/msword, application/vnd.ms-powerpoint,image/gif, image/x-xbitmap, image/jpeg, image/pjpeg, */*

Accept-Encoding: gzip, deflate

Accept-Language: zh-cn

Connection: Keep-Alive

Host:ww.yahoo.com

User-Agent: Mozilla/4.0 (compatible; MSIE 5.0b1; Windows 98)

我们需要在整个HTTP头信息中取出Host信息,然后将http://www.jj.jx.cn/www.xxx.xxx/default.htm形式的第一部分“www”,即HostName(也即是用户注册的name)单独取出,作为重定向检索的关键字。

检索到用户注册的URL信息后,我们给用户浏览器送一个重定向命令“Localtion:http://www.jj.jx.cn/somewhere/sample.html”,将用户重定向到指定页面。

在PHP3中,有函数GetAllHeader(),取得浏览器送出的HTTP头信息。我们主要需要使用此函数来完成整个程序。

后面附有源程序,由于只是实验性质的,所以在查询用户信息时,没有使用数据库,如果整个系统要实际应用的话,一定要和数据库挂接起来,不然查询用户信息的过程将是十分漫长,大大影响效率,而且用户数据的管理也不方便。

在源程序中,所有用户信息记录在data子目录下user.dat文件中。其格式为:

username:

http://octopus.cdit.edu.cn/~qap213/index.html

附PHP3源程序:

<?

//Get HTTP’s Header and parse it//

= getallheaders();

while (list(, ) = each()) {

if(==”Host”){= strtok(,”.”);}}

//Jump out the Banner’s Window//

echo ‘<script language=”JavaScript”>’,

‘msg=window.open(”banner.htm”,”sample”,

“toolbar=no”,”directories=no”,directories=no”,”menubar=no”);’,

‘</script>’;

// seek the user information from the recorded file//

if(!=file(”data/user.dat”)){echo “Open Data File Error!!”;}

=”http://”;

for(=0;<count();++)

if(strtok(,”:”)==){

=; }

if(==”http://”){echo“not found the uesrname of Data!”;}

else{

echo ‘<meta http-equiv=”refresh” content=”0;’,'url=’,,’”>’;}

php

PHP编程常用技巧四则

Tags: ,

PHP编程常用技巧四则:

1.配置PHP文件目录

作为服务器端解释执行的脚本语言,PHP程序放置在某个服务器可以访问的目录下,一般可以通过修改Apache的httpd.conj进行配置,例如我们在该文件中的一句:

Alias /test/ “d:brhpwebsitebrhp/” 那么在浏览器端输入:“http://localhost/test/+PHP文件名”就可以访问d:brhpwebsitebrhp/下的PHP文件 了;可见该行不过是为存放PHP文件的目录起一个别名。

其次,还可以通过指定DocumentRoot路径得到存放服务器文件的目录,在httpd.conj找到以下两行,其中的路径可以随意指定,你的PHP文件也可以放在该目录下,服务器同样可以运行它们,如“http://localhost/+PHP文件名”。

一般的,将PHP文件放在同一个地方比较好,可以方便管理,而其他文件放在另外一个地方。

DocumentRoot “C:/usr/bin/html/”

2.服务器端目录的索引文件

在httpd.conj中,有一行: DirectoryIndex index.html

该行指定目录默认打开文件为index.html,当访问某个目录时,服务器就会自动查找index.html, 若果不存在,则显示目录中的所有文件列表,默认打开文件可以改为别的,如index.php3等等,但是也许我们有很多目录,无论是存放图片,文本等资料 的,还是存放PHP文件或别的文件的目录,我们并不希望用户能看到目录中的文件列表,在httpd.conj 中指定了一个.htacess文件,该文件产生一个目录索引文件,例如我们用写字板建立一个.htacess文件:

# .htacess #

DirectoryIndex error_open.php

再建立一个错误警告文件:

# error_open.php #

其中的error_open.php为权限错误警告文件,将此2文件放在所有保护目录下,当用户企图打开目录时,自动转向执行error_open.php,显示错误警告。
3.目录删除巧实现

我们知道,PHP4 for/win32中有个rename()函数可以支持对目录/文件进行重命名,如: rename( oldpath, newpath) // oldpath为文件或目录原来路径; // newpath为新定义路径;

实现将 oldpath改名为 newpath。

PHP4中没有删除目录/文件的函数,怎么作到删除呢?我们知道,php.ini中有一行用来完成HTTP上传操作的临时文件目录配置行: upload_tmp_dir= ;

PHP4支持该临时目录的配置(PHP3不支持),当上载操作完成则自动清空临时目录,好了,用它我们可以巧妙的实现文件/目录的删除,比如设置: upload_tmp_dir=”d:brhpwebsitebrhp/tmp/” ; 要删除某个目录 path,执行: tmp=”d:brhpwebsitebrhp/tmp/;” rename( path, tmp) ?>;

那么文件或目录 path改名为 tmp后, tmp目录下的所有文件/目录自动清除,就完成了删除操作。

php

十天学会php之第十天

Tags: ,

学习目的:学会用PHP上传文件和发邮件

上传文件表单必须加上 enctype=”multipart/form-data”

<input type=”file” name=”file”>

下面看一下代码:

$f=&$HTTP_POST_FILES['file'];
$dest_dir=’uploads’;//设定上传目录
$dest=$dest_dir.’/’.date(”ymd”).”_”.$f['name'];//我这里设置文件名为日期加上文件名避免重复
$r=move_uploaded_file($f['tmp_name'],$dest);
chmod($dest, 0755);//设定上传的文件的属性

上传的文件名为date(”ymd”).”_”.$f['name'] ,可以在以后插入到数据库的时候用到,PHP实际上是把你上传的文件从临时目录移动到指定目录。move_uploaded_file($f['tmp_name'],$dest);这是关键

至于发邮件就更加简单,可以使用mail()函数

mail(”收件人地址”,”主题”,”正文”,”From:发件人\r\nReply-to:发件人的地址”);

不过mail()需要服务器的支持,在WINDOWS下还需要配置SMTP服务器,一般来说外面的LINUX空间都行。

好像上传文件和发邮件比ASP简单很多,只要调用函数就可以了。ASP还需要用到服务器的不同组件比如FSO、JMAIL什么的。

十天学会PHP说到这里了,我的三大系列文章都用《十天学会》作为名字,想告诉大家的是ASP,PHP,ASP.NET入门都可以是十天,但是精通决不是十天啊,还需要大家自己去研究。

php

十天学会php之第九天

Tags: ,

学习目的:注意事项

因为我是先学ASP的,所以再做PHP的时候会发现很多地方需要适应。

1、注意不要漏了分号
2、注意不要漏了变量前的$
3、使用SESSION的时候注意不要遗漏session_start();

如果发

生错误的时候,可以采用以下方法:
1、如果是SQL语句出错,就注释了然后输出SQL语句,注意也要注释调后续的执行SQL语句
2、如果是变量为空,大多是没有传递到位,输出变量检查一下,检查一下表单的id和name
3、如果是数据库连接出错,检查是否正确打开MY SQL和是否遗漏了连接语句
4、注意缩进,排除括号不区配的错误

在做大网站的时候,我的思路是先构建数据库,确定每一个字段的作用,和表之间的关系。然后设计后台界面,从添加数据开始做起,因为添加是否成功可以直接 到数据库里面验证,做好了添加再做显示的页面,最后才是两者的结合。一般来说后台就包括添加删除修改和显示,后台没有问题了,前台也没有什么大问题。前台 还需要注意安全性和容错还有就是输出格式。

好了,今天说到这里,明天说一下如果用PHP上传文件和发邮件。

php

十天学会php之第八天

Tags: ,

学习目的:做一个分页显示

关键就是用到了SQL语句中的limit来限定显示的记录从几到几。我们需要一个记录当前页的变量$page,还需要总共的记录数$num

对于$page如果没有我们就让它=0,如果有<0就让它也=0,如果超过了

总的页数就让他=总的页数。

$execc=”select count(*) from tablename “;
$resultc=mysql_query($execc);
$rsc=mysql_fetch_array($resultc);
$num=$rsc[0];

这样可以得到记录总数
ceil($num/10))如果一页10记录的话,这个就是总的页数

所以可以这么写
if(empty($_GET['page']))
{
$page=0;
}
else
{
$page=$_GET['page'];
if($page<0)$page=0;
if($page>=ceil($num/10))$page=ceil($num/10)-1;//因为page是从0开始的,所以要-1
}

这样$exec可以这么写 $exec=”select * from tablename limit “.($page*10).”,10″;
//一页是10记录的

最后我们需要做的就是几个连接:
<a href=”xxx.php?page=0″>FirstPage</a>
<a href=”xxx.php?page=<?=($page-1)?>”>PrevPage</a>
<a href=”xxx.php?page=<?=($page+1)?>”>NextPage</a>
<a href=”xxx.php?page=<?=ceil($num/10)-1?>”>LastPage</a>

这是一个大致的思路,大家可以想想怎么来优化?今天说到这里,明天说一下一些注意的问题。

php

十天学会php之第七天

Tags: ,

学习目的:学会SESSION的使用

SESSION的作用很多,最多用的就是站点内页面间变量传递。在页面开始我们要session_start();开启SESSION;
然 后就可以使用SESSION变量了,比如说要赋值就是:$_SESSION['item']=”item1″;要得到值就 是$item1=$_SESSION['item'];,很简单吧。这里我们可能会使用到一些函数,比如说判断是不是某SESSION变量为空,可以这么 写:empty($_SESSION['inum'])返回true or false。

下面综合一下前面所说的我们来看一个登陆程序,判断用户名密码是否正确。
登陆表单是这样:login.php
<table width=”100%” height=”100%” border=”0″ align=”center” cellpadding=”0″ cellspacing=”0″>
<tr>
<form action=”checklogin.php” method=”post”><td align=”center” valign=”middle”><table width=”400″ border=”0″ cellpadding=”5″ cellspacing=”1″>
<tr>
<td colspan=”2″><div align=”center”>Administrators Login</div></td>
</tr>
<tr>
<td><div align=”center”>Username</div></td>
<td><div align=”center”>
<input name=”username” type=”text” id=”username”>
</div></td>
</tr>
<tr>
<td><div align=”center”>Password</div></td>
<td><div align=”center”>
<input name=”password” type=”password” id=”password”>
</div></td>
</tr>
<tr>
<td colspan=”2″><div align=”center”>
<input type=”submit” name=”Submit” value=”Submit”>
<input type=”reset” name=”Submit2″ value=”Clear”>
</div></td>
</tr>
</table></td></form>
</tr>
</table>

处理文件是这样
<?
require_once(’conn.php’);
session_start();
$username=$_POST['username'];
$password=$_POST['password'];
$exec=”select * from admin where username=’”.$username.”‘”;
if($result=mysql_query($exec))
{
if($rs=mysql_fetch_object($result))
{
if($rs->password==$password)
{
$_SESSION['adminname']=$username;
header(”location:index.php”);
}
else
{
echo “<script>alert(’Password Check Error!’);location.href=’login.php’;</script>”;
}
}
else
{
echo “<script>alert(’Username Check Error!’);location.href=’login.php’;</script>”;
}
}
else
{
echo “<script>alert(’Database Connection Error!’);location.href=’login.php’;</script>”;
}

?>

conn.php是这样:
<?
$conn=mysql_connect (”127.0.0.1″, “”, “”);
mysql_select_db(”shop”);
?>

由于 $_SESSION['adminname']=$username;我们可以这样写验证是否登陆语句的文件:checkadmin.asp
<?
session_start();
if($_SESSION['adminname']==’)
{
echo “<script>alert(’Please Login First’);location.href=’login.php’;</script>”;
}
?>

呵呵,今天说到这里,明天说一下怎么弄一个分页。

php

十天学会php之第六天

Tags: ,

学习目的:学会添加删除修改数据

mysql_query($exec);

单这个语句就可以执行所有的操作了,不同的就是$exec这个sql语句

添加:

$exec=”insert into tablename (item1,item2) values (’”.$_POST['item1'].”‘,”.$_POST['item1'].”)”;

删除:$exec=”delete from tablename where…”;

修改:$exec=”update tablename set item1=’”.$_POST['item1'].”‘ where …”;

说到这里就要说一下表单和php变量传递,如果表单中的一个 <input name=”item1″ type=”text” id=”item1″>
表单以POST提交的,那么处理表单文件就可以用$_POST['item1']得到变量值,同样以GET提交的就是$_GET['item1']

是不是很简单?但是通常$exec会有问题,因为可能您的SQL语句会很长,您会遗漏.连接符,或者’来包围字符型字段。

我 们可以注释mysql_query($exec);语句用echo $exec;代替来输出$exec以检查正确性。如果您还不能察觉$exec有什么错误的话,可以复制这个sql语句到phpmyadmin中执行,看看 它的出错信息。还有需要注意的是,我们不要使用一些敏感的字符串作为字段名字,否则很可能会出现问题,比如说date什么的。变量的命名,字段的命名遵循 一点规律有的时候对自己是一种好处,初学者并不可忽视其重要性。

今天就说到这里,大家可以DOWN一个SQL语句的参考手册,再研究研究。明天继续说SESSION。

php

十天学会php之第五天

Tags: ,

学习目的:学会读取数据

先看两个函数:
1、mysql_query
送出一个 query 字符串。 语法

: int mysql_query(string query, int [link_identifier]); 返回值: 整数

本 函数送出 query 字符串供 MySQL 做相关的处理或者执行。若没有指定 link_identifier 参数,则程序会自动寻找最近打开的 ID。当 query 查询字符串是 UPDATE、INSERT 及 DELETE 时,返回的可能是 true 或者 false;查询的字符串是 SELECT 则返回新的 ID 值,当返回 false 时,并不是执行成功但无返回值,而是查询的字符串有错误。

2、mysql_fetch_object 返回类资料。 语法: object mysql_fetch_object(int result, int [result_typ]); 返回值: 类

本函数用来将查询结果 result 拆到类变量中。若 result 没有资料,则返回 false 值。

看一个简单的例子:
$exec=”select * from user”;
$result=mysql_query($exec);
while($rs=mysql_fetch_object($result))
{
echo “username:”.$rs->username.”
“;
}
?>
当然,表user中有一个username的字段,这就类似asp中的

当然先要连接数据库,一般我们 require_once(’conn.php’);而conn.php里面就是上一次说的连接数据库的代码。

小小的两条命令可以完成读取数据的工作了,今天说到这里下一次说数据的添加删除修改。

php

十天学习PHP之第四天

Tags: ,

学习目的:学会连接数据库
PHP简直就是一个函数库,丰富的函数使PHP的某些地方相当简单。建议大家down一本PHP的函数手册,总用的到。
我这里就简单说一下连接MYSQL数据库。
1、mysql_connect
打开 MySQL 服务器连接。
语法: int mysql_connect(string [hostname] [:port], string [username], string [password]); 返回值: 整数
本 函数建立与 MySQL 服务器的连接。其中所有的参数都可省略。当使用本函数却不加任何参数时,参数 hostname 的默认值为 localhost、参数 username 的默认值为 PHP 执行行程的拥有者、参数 password 则为空字符串 (即没有密码)。而参数 hostname 后面可以加冒号与端口号,代表使用哪个端口与 MySQL 连接。当然在使用数据库时,早点使用 mysql_close() 将连接关掉可以节省资源。
2、 mysql_select_db
选择一个数据库。
语法: int mysql_select_db(string database_name, int [link_identifier]); 返回值: 整数
本函数选择 MySQL 服务器中的数据库以供之后的资料查询作业 (query) 处理。成功返回 true,失败则返回 false。
最简单的例子就是:
$conn=mysql_connect (”127.0.0.1″, “”, “”);
mysql_select_db(”shop”);
连接机MY SQL数据库,打开SHOP数据库。在实际应用中应当加强点错误判断。
今天就说到这里,明天再说一下数据库的读取。