动网论坛,站长建站首选,国内使用量最多的论坛软件 动网论坛官方技术讨论区 站长工具 申请属于您自己的免费论坛
首页 | 新闻资讯 | 网站运营 | 网络编程 | 数据库 | 服务器 | 网页设计 | 图像媒体 | 网络应用 | 搜索优化 | 资源下载 | 动网主机 | DVBOX
    本站内  互联网 ASP论坛  ASP.Net论坛  PHP论坛
  
   PHP → 阅读文章

 用PHP将数据导入到Foxmail

作者来源: 
阅读 1477 人次 , 2006-3-29 4:13:00 

  最近小阳做了一个php同学录,同学们自己在那里添加或修改姓名、邮箱、oicq等信息,并保存在mysql数据库里。某日小阳突然想到,如果能用php生成一个文件,供同学们下载并把这些资料导入他们的foxmail地址簿中,那该多好啊!
 
  说干就干,很快小阳便将这功能推出来了。那是如何实现的呢?这里仅以导出姓名、邮箱和oicq三项予以说明。

  要资料可以导入foxmail地址簿,当然要先了解一下导入foxmail地址簿的文件内容和格式。打开foxmail4.2一个帐户的地址簿,在其菜单栏“工具”-“导入”中可以看到,foxmail支持两种外部文件的导入:“csv文件”和“wab文件”。我们选择生成csv文件。那么可以导入foxmail的csv文件的内容和格式如何呢?让我们先从foxmail导出一个csv文件看一下。在foxmail地址簿中选择一个记录不为空的文件夹,执行“工具”-“导出”- “文本文件”,保存文件名为“temp.csv”, 在“下一步”的“请选择输出字段”中选择“姓名”、“电子邮箱地址”和“oicq”,点击“完成”后便在指定路径生成了“temp.csv”文件了。如果你装了微软office系列,会发现这是一个用excel默认打开的文件,实际上它是excel的逗号分隔值文件,双击打开后,其界面如图所示。

点击查看原图

  我们在这种情况下还是无法知道它的写入格式的。将“temp.csv”文件改为用记事本打开,便可以发现它的格式非常简单:如图,文件第一行是foxmail地址簿的字段,其它行是字段对应的值,各字段和值用英文逗号分隔。所以我们在php中按这种格式生成csv文件,别人就可以下载并导入他们的foxmail中了!

点击查看原图

  不过还有一个问题需要解决,那就是既然文件中以逗号作为分隔值,如果数据库记录中有英文逗号(注:以下符号若无特别说明皆指英文符号)怎么办?当然你可以先将数据中的逗号替换为中文逗号,但其实还有一个方法,那就是如果csv文件相应的字段两端加上双引号(“即\" \"”)作分隔值,其间的英文逗号不作为分隔值,且字段中连续两个英文双引号(即“\"\"”)也只作为一个显示,而不作为分隔值。

  有了这些认识,我们就可以编写导出csv文件的php文件了:

<?
//这一行一定要放在程序的开始地方,不能有空格或换行。因为下面的header()函数不允许在使用前向用户输出任何东西。
$dfname=\"tofoxmail.csv\"; //生成的文件名
//连接mysql数据库:
  mysql_connect(\"localhost\",\"yourname\",\"yourpassword\") or die(\"不能连接数据库!\");
  mysql_select_db(\"alumni\") or die(\"数据库发生错误!\");
if($action==\"downit\"){
  $getdata=mysql_query(\"select name,email,oicq from classdata\"); //选择数据表中指定记录
//如果没有资料,则:
  if(@mysql_num_rows($getdata)==0){
  echo \"对不起,还没有任何资料!\";
  exit;
  }
  //以下生成一个文件供下载:
  header(\"content-disposition: filename=$dfname\");
  header(\"content-type: unknown/unknown\");
  echo \"姓名,电子邮件地址,oicq,foxaddrid\"; //输出第一行,foxmail地址簿的字段
  $i=1;
  while($row=mysql_fetch_array($getdata)){ //取得数据类型的值
  //将数据中每一个双引号替换为两个:
  $row[name]=str_replace(\"\\"\",\"\\"\\"\",$row[name]);
  $row[email]=str_replace(\"\\"\",\"\\"\\"\",$row[email]);
  $row[oicq]=str_replace(\"\\"\",\"\\"\\"\",$row[oicq]);
  //输出相应字段对应的值的行,每个值用双引号和逗号作分隔符:
  echo base64_decode(\"dqo=\").\"\\"$row[name]\\",\\"$row[email]\\",\\"$row[oicq]\\",$i\";
  /*上式中“base64_decode(\"dqo=\")”是换行符,之所以不用“\n”,是因为两者不完全相同,
  用后者将可能导致foxmail导入失败。
  */
  $i++;
  }
  exit;
  }
  ? >
  < !--如果不是点击了下载的链接,则显示以下html内容-- >
  < html>
  < head>
  < meta http-equiv=\"content-type\" content=\"text/html; charset=gb2312\">
  < title>导出资料到foxmail地址簿< /title>< /head>
  < body> 点击< a href=\'javascript:this.location=this.location+\"?action=downit\"\'>这里< /a>下载文件,保存并导入到您的foxmail地址簿中。< br>
  < b>操作方法< /b>< br>
  ……
  < /body>
  < /html>

  在服务器上运行上述php文件,下载回来的“tofoxmail.csv”文件用记事本打开如图所示。

  在foxmail地址簿中点击“工具”-“导入”-“csv文件”……,数据库中一大堆的资料一下子就全被导入了,这个主意还不错吧!

点击查看原图

(以上程序在apache+php4+mysql和iis+php4+mysql中皆测试通过。)

 
 收藏本文  打印本文  论坛讨论  关闭窗口
· 上一篇:PHP-Web应用程序开发:使用模板
· 下一篇:PHP应用程序的性能优化
· 用PHP开发C/S结构
· PHP与JavaScript对多项选择的处理
· class.rFastTemplate.php
· 一个把字符串按php代码高亮显示的函数
· 分页显示详解


关于本站 | 联系我们 | 业务合作 | 客户案例 | 诚聘英才 | 广告合作 | 收藏本站
海口动网先锋网络科技有限公司版权所有
Copyright © 2000 - 2006 Cndw.Com
中华人民共和国电信与信息服务业务经营许可证编号 琼 ICP 020077