|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
学习如何将PHP与HTML结合起来完成简单动态页面 <P style="TEXT-INDENT: 2em">假如你想把二进制的数据,好比说图片文件和HTML文件,直接保留在你的MySQL数据库,那末这篇文章就是为你而写的!我将告知你如何经由过程HTML表单来贮存这些文件,如何会见和利用这些文件。 <P style="TEXT-INDENT: 2em">本文概述: <P style="TEXT-INDENT: 2em">。在mysql中创立一个新的数据库 <P style="TEXT-INDENT: 2em">。一个如何贮存文件的例子法式 <P style="TEXT-INDENT: 2em">。一个如何会见文件的例子法式 <P style="TEXT-INDENT: 2em">在mysql中创立一个新的database <P style="TEXT-INDENT: 2em">起首,你必需在你的mysql中创立一个新的数据库,咱们将会把那些二进制文件贮存在这个数据库里。在例子中我会利用以下布局,为了创立数据库, <P style="TEXT-INDENT: 2em">你必需做以下步调: <P style="TEXT-INDENT: 2em">。进入MySql掌握器 <P style="TEXT-INDENT: 2em">。输出号令"create database binary_data;" <P style="TEXT-INDENT: 2em">。输出号令"use binary_data;" <P style="TEXT-INDENT: 2em">。输出号令 <P style="TEXT-INDENT: 2em">"CREATE TABLE binary_data ( id INT(4) NOT NULL AUTO_INCREMENT PRIMARY KEY,description CHAR(50), bin_data LONGBLOB, filename CHAR(50), filesize CHAR(50), filetype CHAR(50));" (不克不及断行) <P style="TEXT-INDENT: 2em">假如没成心外,数据库 和 表 应当创立好了。 <P style="TEXT-INDENT: 2em">一个如何贮存文件的例子法式 <P style="TEXT-INDENT: 2em">用这个例子你可以经由过程Html表单将文件传输到数据库中。 <P style="TEXT-INDENT: 2em">- store.php3<?php// store.php3 - by Florian Dittmer <dittmer@gmx.net>?><HTML><HEAD><TITLE>Store binary data into SQL Database</TITLE></HEAD><BODY><?php// 假如提交了表单,代码将被履行:if ($submit) {// 毗连到数据库// (你能够需求调剂主机名,用户名和暗码)MYSQL_CONNECT( "localhost", "root", "password");mysql_select_db( "binary_data");$data = addslashes(fread(fopen($form_data, "r"), filesize($form_data)));$result=MYSQL_QUERY( "INSERT INTO binary_data (description,bin_data,filename,filesize,filetype) [接上一行:] VALUES ('$form_description','$data','$form_data_name','$form_data_size','$form_data_type')"); $id= mysql_insert_id(); print "<p>This file has the following Database ID: <b>$id</b>";MYSQL_CLOSE();} else {// 不然显示贮存新数据的表单?><form method="post" action=" <?php echo $PHP_SELF; ?>" enctype="multipart/form-data">File Description:<br><input type="text" name="form_description" size="40"><INPUT TYPE="hidden" name="MAX_FILE_SIZE" value="1000000"><br>File to upload/store in database:<br><input type="file" name="form_data" size="40"><p><input type="submit" name="submit" value="submit"></form><?php}?></BODY></HTML>
复制代码 <P style="TEXT-INDENT: 2em">假如你履行了这个法式,你将会看见一个复杂的Html表单,单击“阅读”选择一个文件,然后单击提交。 <P style="TEXT-INDENT: 2em">当文件上传至web办事器以后,法式将会告知你方才上传的文件的ID,记住这个ID,待会要用的。 <P style="TEXT-INDENT: 2em">一个如何会见文件的例子法式 <P style="TEXT-INDENT: 2em">你可以经由过程这个法式会见你方才贮存的文件 <P style="TEXT-INDENT: 2em">- <?php// getdata.php3 - by Florian Dittmer <dittmer@gmx.net>// 挪用办法: getdata.php3?id=<id>if($id) {// 你能够需求调剂主机名,用户名和暗码: @MYSQL_CONNECT( "localhost", "root", "password"); @mysql_select_db( "binary_data"); $query = "select bin_data,filetype from binary_data where id=$id"; $result = @MYSQL_QUERY($query); $data = @MYSQL_RESULT($result,0, "bin_data"); $type = @MYSQL_RESULT($result,0, "filetype");Header( "Content-type: $type");echo $data;};?>
复制代码 <P style="TEXT-INDENT: 2em">法式必需晓得要会见谁人文件, 你必需将ID作为一个参数。 <P style="TEXT-INDENT: 2em">例如: 一个文件在数据库中的ID为2. 你可以如许挪用它: <P style="TEXT-INDENT: 2em">getdata.php3?id=2 <P style="TEXT-INDENT: 2em">假如你将图片贮存在数据库里, 你可以向挪用图片一样挪用它。 <P style="TEXT-INDENT: 2em">Example: 一个图片文件在数据库中的ID为3. 你可以如许挪用它: <P style="TEXT-INDENT: 2em"><P style="TEXT-INDENT: 2em">如何贮存大于1MB的文件: <P style="TEXT-INDENT: 2em">假如你想贮存大于1MB的文件,你必需对你的法式、PHP设置、SQL设置停止很多修正,。 <P style="TEXT-INDENT: 2em">上面几条或许可以匡助你贮存小于24MB的文件: <P style="TEXT-INDENT: 2em">1、修正 store.php3 ,将 MAX_FILE_SIZE 的值改成 24000000。 <P style="TEXT-INDENT: 2em">2、修正你的PHP设置,在普通情形下,PHP只答应小于2MB的文件,你必需将max_filesize(在php.ini中)的值改成24000000 <P style="TEXT-INDENT: 2em">3、去失落MYSQL的数据包巨细限制,在普通情形下 MYSQL 小于1 MB的数据包. <P style="TEXT-INDENT: 2em">4、你必需用以下参数重启你的MYSQL <P style="TEXT-INDENT: 2em">/usr/local/bin/safe_mysqld -O key_buffer=16M -O table_cache=128 -O sort_buffer=4M -O record_buffer=1M -O max_allowed_packet=24M <P style="TEXT-INDENT: 2em">5、假如依然失足: 多是超时毛病,假如你经由过程一个很慢的毗连来贮存一个很大的文件,PHP缺省的工夫限制为30秒。你可以将max_execution_time(在php.ini中)的值改成-1
在相册系统的开发上,因为采用的是团队分工合作方式,更让我明白了在一个团队之中,团队成员之间的交流沟通的重要性,如果没有很好的沟通交流,成员之间的任务没有分配好。 |
|