仓酷云

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 951|回复: 19
打印 上一主题 下一主题

[学习教程] PHP编程:详解:――若何将图片贮存在数据库里

[复制链接]
爱飞 该用户已被删除
跳转到指定楼层
楼主
发表于 2015-2-3 23:59:21 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有帐号?立即注册

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">
  1. 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">
  1. <?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
在相册系统的开发上,因为采用的是团队分工合作方式,更让我明白了在一个团队之中,团队成员之间的交流沟通的重要性,如果没有很好的沟通交流,成员之间的任务没有分配好。
第二个灵魂 该用户已被删除
沙发
发表于 2015-2-4 07:54:14 | 只看该作者
基础有没有对学习php没有太大区别,关键是兴趣。
若相依 该用户已被删除
板凳
发表于 2015-2-9 19:13:48 | 只看该作者
为了以后维护的方便最好是代码上都加上注释,“予人方便,自己方便”。此外开发文档什么的最好都弄齐全。我觉得这是程序员必备的素质。虽然会消耗点很多的时间。但是确实是非常有必要的。
莫相离 该用户已被删除
地板
发表于 2015-2-27 17:47:11 | 只看该作者
在我安装pear包的时候老是提示,缺少某某文件,才发现 那群extension 的排列是应该有一点的顺序,而我安装的版本的排序不是正常的排序。没办法我只好把那群冒号加了上去,只留下我需要使用的扩展。
因胸联盟 该用户已被删除
5#
发表于 2015-3-1 20:10:21 | 只看该作者
至于模板嘛,各位高人一直以来就是争论不休,我一只小菜鸟就不加入战团啦,咱们新手还是多学点东西的好。
小女巫 该用户已被删除
6#
发表于 2015-3-10 22:57:25 | 只看该作者
,熟悉html,能用div+css,还有javascript,优先考虑linux。我在开始学习的时候,就想把这些知识一起学习,我天真的认为同时学习能够互相呼应,因为知识是相通的。
愤怒的大鸟 该用户已被删除
7#
发表于 2015-3-17 18:08:30 | 只看该作者
首推的搜索引擎当然是Google大神,其次我比较喜欢 百度知道。不过搜出来的结果往往都是 大家copy来copy去的,运气的的概率很大。
谁可相欹 该用户已被删除
8#
发表于 2015-3-22 23:02:48 | 只看该作者
遇到出错的时候,我经常把错误信息直接复制到 google的搜索栏,一般情况都是能搜到结果的,不过有时候会搜出来一大片英文的出来,这时候就得过滤一下,吧中文的弄出来,挨着式方法。
柔情似水 该用户已被删除
9#
发表于 2015-3-27 02:12:36 | 只看该作者
其实也不算什么什么心得,在各位大侠算是小巫见大巫了吧,望大家不要见笑,若其中有错误的地方请各位大虾斧正。
老尸 该用户已被删除
10#
发表于 2015-3-31 06:45:20 | 只看该作者
爱上php,他也会爱上你。
11#
发表于 2015-4-3 18:07:21 | 只看该作者
最后祝愿,php会给你带来快乐的同时 你也会给他带来快乐。
活着的死人 该用户已被删除
12#
发表于 2015-4-4 06:30:57 | 只看该作者
首先声明:我是一个菜鸟,是一个初学者。学习了一段php后总是感觉自己没有提高,无奈。经过反思我认为我学习过程中存在很多问题,我改变了学习方法后自我感觉有了明显的进步。
再现理想 该用户已被删除
13#
发表于 2015-4-10 05:53:48 | 只看该作者
我还是推荐用firefox ,配上firebug 插件调试js能省下不受时间。谷歌的浏览器最好也不少用,因为谷歌的大侠们实在是太天才啦,把一些原来的js代码加了一些特效。
乐观 该用户已被删除
14#
发表于 2015-4-21 19:57:28 | 只看该作者
至于模板嘛,各位高人一直以来就是争论不休,我一只小菜鸟就不加入战团啦,咱们新手还是多学点东西的好。
若天明 该用户已被删除
15#
发表于 2015-4-25 15:22:28 | 只看该作者
我要在声明一下:我是个菜鸟!!我对php这门优秀的语言也是知之甚少。但是我要在这里说一下php在网站开发中最常用的几个功能:
飘灵儿 该用户已被删除
16#
发表于 2015-5-1 01:52:41 | 只看该作者
微软最近出的新字体“微软雅黑”,虽然是挺漂亮的,不过firefox  支持的不是很好,所以能少用还是少用的好。
分手快乐 该用户已被删除
17#
发表于 2015-6-12 22:34:51 | 只看该作者
首推的搜索引擎当然是Google大神,其次我比较喜欢 百度知道。不过搜出来的结果往往都是 大家copy来copy去的,运气的的概率很大。
灵魂腐蚀 该用户已被删除
18#
发表于 2015-6-19 12:46:53 | 只看该作者
没接触过框架的人,也不用害怕,其实框架就是一种命名规范及插件,学会一个框架其余的框架都很好上手的。
精灵巫婆 该用户已被删除
19#
发表于 2015-6-21 03:04:09 | 只看该作者
真正的方向了,如果将来要去开发团队,你一定要学好smarty ,phplib这样的模板引擎,
爱飞 该用户已被删除
20#
 楼主| 发表于 2015-7-6 15:40:58 | 只看该作者
Apache不是非得用80或者8080端口的,我刚开始安得时候就是80端口老占用,就用了个 81端口,结果照常,就是输localhost的时候,应该输入为 localhost:81
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

QQ|Archiver|手机版|仓酷云 鄂ICP备14007578号-2

GMT+8, 2024-11-11 20:34

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表