栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > PHP

php安装程序的原理

PHP 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

php安装程序的原理

        当我们写了一个网站程序想分享给别人一起使用时,通常我们都会把数据库表的结构、表的初始化数据导出来,以方便他人导入数据库。但为何我们不写个安装程序,只要填写了主机,连接数据库的用户名跟密码、要创建的数据库名,程序就会帮我们创建数据库、表、初始化表的数据。所以写安装程序主要出于两个目的:第一个是方便自己移植自己的网站,第二个就是方便别人使用你的程序。下面就简单介绍一下php安装程序的基本原理。


简单步骤如下:
1、写一个form表单供用户填写主机名$host,连接数据库的用户名$user跟密码$password,要创建的数据库名$dbname。
2、将获得表单的数据写入一个配置文件config.php,以方便其它文件来调用数据库的信息。
3、调用配置文件include_once("config.php"),写程序进行数据库的连接,创建数据库、创建表、初始化表的数据。



ok,首先开始第一步

 


[xhtml] view plaincopyprint?

  1.   

  2. 填写主机:本地主机为localhost  

  3. 连接数据库的用户名:  

  4. 连接数据库的密码:  

  5. 要创建的数据库名:  

  6.   

  7.   


 

2、将获得表单的数据写入一个配置文件config.php,以方便其它文件来调用数据库的信息。

 


[php] view plaincopyprint?

  1. header("Content-type:text/html;charset=gb2312") //看你用的是什么编码,要保持一致。  

  2. $files="config.php"; //要写入的配置文件。  

  3. if(!is_writable($files)){    //判断是否有可写的权限,linux操作系统要注意这一点,windows不必注意。  

  4.     echo "文件不可写";  

  5.       exit();  

  6. }  

  7. if($_POST['install']){  //获取用户提交的数据。  

  8. $host=$_POST['host'];  

  9. $user=$_POST['user'];  

  10. $password=$_POST['password'];  

  11. $dbname=$_POST['dbname'];  

  12.    

  13. $config="

  14. $config.="/n";            //   /n是用来换行的。  

  15. $config.="/$host='".$host."';";  

  16. $config.="/n";    

  17. $config.="/$user='".$user."';";  

  18. $config.="/n";    

  19. $config.="/$password='".$password."';";  

  20. $config.="/n";    

  21. $config.="/$dbname='".$dbname."';";  

  22. $config.="/n";    

  23. $config.="?>";  

  24.    

  25. $file = fopen($files, "w");   //以写入的方式打开config.php这个文件。  

  26. fwrite($file,$config);  //将配置信息写入config.php文件。  

  27. fclose($file);  

  28. }  

  29. ?>  

文件不可写";      exit();}if($_POST['install']){  //获取用户提交的数据。$host=$_POST['host'];$user=$_POST['user'];$password=$_POST['password'];$dbname=$_POST['dbname']; $config=""; $file = fopen($files, "w");   //以写入的方式打开config.php这个文件。fwrite($file,$config);  //将配置信息写入config.php文件。fclose($file);}?>


 

 

3、调用配置文件include_once("config.php"),写程序进行数据库的连接,创建数据库、创建表、初始化表的数据。

 

 

 

[php] view plaincopyprint?

  1. include_once("config.php");   //导入配置信息.  

  2. if(!$conn=@mysql_connect($host,$user,$password)){  

  3.        echo "连接数据库失败!请返回上一页检查连接参数 javascript:history.go(-1)" mce_href="javascript:history.go(-1)">返回修改";  

  4.        exit();  

  5. }else{  

  6.   mysql_query("set names gb2312");  //设置数据库的编码,注意要与前面一致。  

  7.    if(!mysql_select_db($dbname,$conn)){   //如果数据库不存在,我们就进行创建。  

  8.          $dbsql="CREATE DATAbase `$dbname`";  

  9.          if(!mysql_query($dbsql)){  

  10.            echo "创建数据库失败,请确认是否有足够的权限!javascript:history.go(-1)" mce_href="javascript:history.go(-1)">返回修改";  

  11.            exit();  

  12.           }  

  13.    }  

  14. //下面根据你实际的表的结构跟初始化表的数据来写,这些sql语句,我们在导出时可以找到。  

  15.    //新建一个表test1  

  16.    $sql_query[] = "CREATE TABLE `test1` (     

  17.                  `id` int(4) NOT NULL auto_increment,  

  18.                  `name` varchar(20) character set gb2312 NOT NULL,  

  19.                  `major` varchar(40) character set gb2312 NOT NULL,  

  20.                   PRIMARY KEY  (`id`)  

  21.                   ) ENGINE=InnoDB  DEFAULT CHARSET=gb2312 AUTO_INCREMENT=1;";  

  22.     //新建一个表test2  

  23.     $sql_query[] = "CREATE TABLE `test2` (     

  24.                  `id` int(4) NOT NULL auto_increment,  

  25.                  `name` varchar(20) character set gb2312 NOT NULL,  

  26.                  `major` varchar(40) character set gb2312 NOT NULL,  

  27.                   PRIMARY KEY  (`id`)  

  28.                   ) ENGINE=InnoDB  DEFAULT CHARSET=gb2312 AUTO_INCREMENT=1;";  

  29.      //为test1表默认初始化一些数据。  

  30.      $sql_query[]="INSERT INTO `test1` (`name`, `major`) VALUES('张三','电子商务')";  

  31.      foreach($sql_query as $sql){  

  32.             if(!mysql_query($sql)){      //依次执行以上的sql语句,就是创建表和初始化数据。  

  33.             echo "创建表失败或者初始化数据失败";  

  34.                 exit();  

  35.            }  

  36.      }  

  37.      mysql_close();  

  38.      echo "安装成功";//可以做一个跳转到首页。  

  39.      exit();  

  40. }  

  41. ?>  

返回修改";       exit();}else{  mysql_query("set names gb2312");  //设置数据库的编码,注意要与前面一致。   if(!mysql_select_db($dbname,$conn)){   //如果数据库不存在,我们就进行创建。         $dbsql="CREATE DATAbase `$dbname`";         if(!mysql_query($dbsql)){           echo "创建数据库失败,请确认是否有足够的权限!返回修改";           exit();          }   }//下面根据你实际的表的结构跟初始化表的数据来写,这些sql语句,我们在导出时可以找到。   //新建一个表test1   $sql_query[] = "CREATE TABLE `test1` (                    `id` int(4) NOT NULL auto_increment,                 `name` varchar(20) character set gb2312 NOT NULL,                 `major` varchar(40) character set gb2312 NOT NULL,                  PRIMARY KEY  (`id`)                  ) ENGINE=InnoDB  DEFAULT CHARSET=gb2312 AUTO_INCREMENT=1;";    //新建一个表test2    $sql_query[] = "CREATE TABLE `test2` (                    `id` int(4) NOT NULL auto_increment,                 `name` varchar(20) character set gb2312 NOT NULL,                 `major` varchar(40) character set gb2312 NOT NULL,                  PRIMARY KEY  (`id`)                  ) ENGINE=InnoDB  DEFAULT CHARSET=gb2312 AUTO_INCREMENT=1;";     //为test1表默认初始化一些数据。     $sql_query[]="INSERT INTO `test1` (`name`, `major`) VALUES('张三','电子商务')";     foreach($sql_query as $sql){            if(!mysql_query($sql)){      //依次执行以上的sql语句,就是创建表和初始化数据。            echo "创建表失败或者初始化数据失败";                exit();           }     }     mysql_close();     echo "安装成功";//可以做一个跳转到首页。     exit();}?>


 

有人或许为问,直接把表单提交的数据来进行安装不就可以了,为什么还要写入配置信息文件呢,这个是因为为了方便其它要使用到数据库的文件来连接数据库。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/228721.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号