PHP编程:详解:――若何将图片贮存在数据库里
学习如何将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在相册系统的开发上,因为采用的是团队分工合作方式,更让我明白了在一个团队之中,团队成员之间的交流沟通的重要性,如果没有很好的沟通交流,成员之间的任务没有分配好。 基础有没有对学习php没有太大区别,关键是兴趣。 为了以后维护的方便最好是代码上都加上注释,“予人方便,自己方便”。此外开发文档什么的最好都弄齐全。我觉得这是程序员必备的素质。虽然会消耗点很多的时间。但是确实是非常有必要的。 在我安装pear包的时候老是提示,缺少某某文件,才发现 那群extension 的排列是应该有一点的顺序,而我安装的版本的排序不是正常的排序。没办法我只好把那群冒号加了上去,只留下我需要使用的扩展。 至于模板嘛,各位高人一直以来就是争论不休,我一只小菜鸟就不加入战团啦,咱们新手还是多学点东西的好。 ,熟悉html,能用div+css,还有javascript,优先考虑linux。我在开始学习的时候,就想把这些知识一起学习,我天真的认为同时学习能够互相呼应,因为知识是相通的。 首推的搜索引擎当然是Google大神,其次我比较喜欢 百度知道。不过搜出来的结果往往都是 大家copy来copy去的,运气的的概率很大。 遇到出错的时候,我经常把错误信息直接复制到 google的搜索栏,一般情况都是能搜到结果的,不过有时候会搜出来一大片英文的出来,这时候就得过滤一下,吧中文的弄出来,挨着式方法。 其实也不算什么什么心得,在各位大侠算是小巫见大巫了吧,望大家不要见笑,若其中有错误的地方请各位大虾斧正。 爱上php,他也会爱上你。 最后祝愿,php会给你带来快乐的同时 你也会给他带来快乐。 首先声明:我是一个菜鸟,是一个初学者。学习了一段php后总是感觉自己没有提高,无奈。经过反思我认为我学习过程中存在很多问题,我改变了学习方法后自我感觉有了明显的进步。 我还是推荐用firefox ,配上firebug 插件调试js能省下不受时间。谷歌的浏览器最好也不少用,因为谷歌的大侠们实在是太天才啦,把一些原来的js代码加了一些特效。 至于模板嘛,各位高人一直以来就是争论不休,我一只小菜鸟就不加入战团啦,咱们新手还是多学点东西的好。 我要在声明一下:我是个菜鸟!!我对php这门优秀的语言也是知之甚少。但是我要在这里说一下php在网站开发中最常用的几个功能: 微软最近出的新字体“微软雅黑”,虽然是挺漂亮的,不过firefox支持的不是很好,所以能少用还是少用的好。 首推的搜索引擎当然是Google大神,其次我比较喜欢 百度知道。不过搜出来的结果往往都是 大家copy来copy去的,运气的的概率很大。 没接触过框架的人,也不用害怕,其实框架就是一种命名规范及插件,学会一个框架其余的框架都很好上手的。 真正的方向了,如果将来要去开发团队,你一定要学好smarty ,phplib这样的模板引擎, Apache不是非得用80或者8080端口的,我刚开始安得时候就是80端口老占用,就用了个 81端口,结果照常,就是输localhost的时候,应该输入为 localhost:81
页:
[1]