动态网站制作指南 [  QQ表情  ]
[ 投票调查 ]
[ 企业邮箱 ]
[ 网站空间 ]
网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
ASP源码 | .Net源码 | PHP源码 | JSP源码 | JAVA源码 | CGI源码 | VB源码 | C++源码 | Delphi源码 | PB源码 | VF源码 | 汇编 | 服务器
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
文章搜索服务
邮件订阅
输入你的邮件地址,
你将不会错过任何关于:
[ Oracle教程 ]的信息

本月文章推荐
.PLSQL单行函数和组函数详解.
.一个小技巧:工资超过5000元的员.
.多节点Oracle9i数据库的复制实现.
.VC下利用Pro*C开发Oracle接口.
.Oracle 10g中用FIRALL处理非连续.
.在DB2中如何實現Oracle的相關功能.
.在Oracle 8x中实现自动断开后再连.
.使用DBMS_METADATA包获得对象DDL.
.上传文件至Oracle数据库.
.为最佳性能而调优 Red Hat(5).
.Oracle中Instance实例和数据库的.
.应对RMAN-06026错误,使用dbms_b.
.搭建Oracle高可用数据库环境.
.Oracle性能调优过程中如何观察缓.
.如何使用Ruby脚本调用Oracle存储.
.如何创建DBA ROLE.
.Oracle中实现大量数据快速转移数.
.PL/SQL学习之oracle排序系列二(下.
.ORACLE学习笔记--性能优化二.
.ORACLE SQL性能优化系列(九).

向数据库中增加一些魔术

发表日期:2008-2-9 |



  UNIX 命令 file根据文件的内容确认一个文件类型,而不是使用文件扩展名。例如,每个 GIF 文件都以字符 GIF开始,每个 JPEG 文件都以big-endian序的值 oxffd8 开始。
  
  file命令要查询一个 ASCII 文本文件,该文件一般位于 /etc/magic 中。你可以在一台 UNIX 机器的 man 页查看 magic 来浏览其格式。在 Apache Web 服务器上也有类似的文件。它一般用来确认自己不知道的扩展名的文件,然后返回正确的 MIME 类型。Apache 的版本很简单,其处理范围只包含一些很可能出现在 Web 服务器中的文件。
  
  数据库可以使用一个相似的技术来确定一个 BLOB 列的 MIME 类型。大多数据库应用程序在存储数据的时候还会存储某种类型的标识。然而,可能对于某些人来说不能正确地标识数据。因此,通过直接分析数据来检查 BLOB 值的 magic 值然后返回一个 MIME 类型和解码信息将会很有用。
  
  将magic安装到数据库
  安装 magic 的过程使用一个 Perl 脚本产生一种可以使用 SQL*Loader 装载到数据库的标准化格式。数据然后由一个 PL/SQL 函数来扫描,该函数试图确定 BLOB 的数据。下面是建立数据的步骤,以及一个例子:
  
  第一步:创建一个 Perl 脚本将 magic 转成一个 SQL*Loader 数据文件:
  #!/usr/local/bin/perl
  # --- magicdata.pl
  
  # scan the "magic" file for file identification rules
  $filename = ($#ARGV>=0) ? $ARGV[0] : 'magic';
  open(FILE,"<$filename") die "Couldn't open file '$filename'";
  $i = 0;
  while (<FILE>)
  {
    next if /^\s*#/;  # skip comments
    next if /^\s*$/;  # skip blank lines
    s/[\r\n]*//g;    # strip trailing cr/lf
    # replace octal escape codes
    s/\\([0-9]{3})/pack('C',oct($1))/eg;
    # split on spaces, except for "\ "
    my ($offset,$dt,$cnt,$mime,$encoding) = split(/(?<!\\)\s+/);
    $cont = ($offset =~ /^>/) ? 'Y' : undef;
    $offset = substr($offset,1) if $cont;
    if ($dteq 'string')
    {
      # generate a HEXTORAW version of the string
      $data = join('',map(sprintf('%02X',$_),unpack('C*',$cnt)));
    }
    else
    {
      # handle special number formats
      if ($cnt =~ /^0x/) { $cnt = hex($cnt); }  # hex
      elsif ($cnt =~ /^0/) { $cnt = oct($cnt); } # octal
      warn "unknown number: '$cnt'" unless $cnt =~ /^([0-9][1-9][0-9]*)$/;
      if ($dteq 'belong') {
        $data = sprintf('%02X' x 4,unpack('C4',pack('N',$cnt)));
      } elsif ($dteq 'lelong') {
        $data = sprintf('%02X' x 4,unpack('C4',pack('V',$cnt)));
      } elsif ($dteq 'beshort' $dteq 'short') {
        $data = sprintf('%02X' x 2,unpack('C2',pack('n',$cnt)));
      } elsif ($dteq 'leshort') {
        $data = sprintf('%02X' x 2,unpack('C2',pack('v',$cnt)));
      } elsif ($dteq 'byte') {
        $data = sprintf('%02X',$cnt);
      } else {
        warn "data type '$dt' not implemented";
      }
    }
    $i++;
    print join(',',$i,$cont,$offset,$data,$mime,$encoding),"\n";
  }
  close(FILE);
  
  $ perl magicdata.pl $Oracle_HOME/Apache/conf/magic > magicdata.dat
  
  第二步:在 SQL*Plus 中使用下面的 SQL 脚本创建表来保存这个数据:
  create table magicdata
  (
    line    integer,
    cont    char(1),
    offset   integer,
    data    raw(24),
    mime    varchar2(24),
    encoding  varchar2(10)
  );
  
  第三步:使用 SQL*Loader 将前面产生的数据装载到数据库中:
  load data
  truncate
  into table magicdata
  fields terminated by ',' optionally enclosed by '"'
  trailing nullcols
  (
    line,
    cont,
    offset,
    data,
    mime,
    encoding
  )
  
  $ sqlldr user=scott/tiger control=magicdata.ctl data=magicdata.dat
  
  下面是一些测试数据,只有一个 BLOB 列的一个简单的表。

  
  drop table magictest;
  create table magictest (myblob blob);
  
  第四步:使用 SQL*Loader 从文件装载三个图像到这个表:
  load data
  infile *
  into table magictest
  fields terminated by ','
  (
    fname filler,
    "MYBLOB" lobfile(fname) terminated by eof
  )
  begindata
  file.bmp
  file.gif
  file.jpg
  
  $sqlldruserid=scott/tiger control=magictest.ctl
  
  下面是扫描 magic 数据表和 BLOB 以确定文件 MIME 类型的 PL/SQL 函数:
  
  create or replace function magic(lob_loc blob) return varchar2
  is
    continued boolean := false;
    bdata raw(100);
  begin
    for rec in (select * from magicdata order by line) loop
      if rec.cont = 'Y' then
        if continued then
          bdata := dbms_lob.substr
          (
            lob_loc,
            utl_raw.length(rec.data),
            rec.offset+1
          );
          if utl_raw.compare(bdata,rec.data) = 0 then
            return rec.mime;
          end if;
        end if;
      else
        bdata := dbms_lob.substr
        (
          lob_loc,
          utl_raw.length(rec.data),
          rec.offset+1
        );
        dbms_output.put_line(bdata' <=> 'rec.data);
        if utl_raw.compare(bdata,rec.data) = 0 then
          if rec.mime is null then
            continued := true;
          else
            return rec.mime;
          end if;
        end if;
      end if;
    end loop;
    return null;
  end magic;
  /
  show errors;
  
  现在为了显示它确实可以工作,我运行下面的 SQL 语句:
  
  Select magic(myblob) from testdata;
  
  得到的输出是:
  
  MAGIC(MYBLOB)
  -------------
  image/bmp
  image/gif
  image/jpeg
上一篇:创建访问非Oracle文件的外部表格 人气:406
下一篇:Oracle快速删除数据字典管理的表空间 人气:398
浏览全部Oracle教程的内容 Dreamweaver插件下载 常用网页广告代码全集
  最新网站源码 最新软件下载
2008-9-6 Movie34电影搜索引擎 v3.0
2008-9-6 wap2.0仿帝国建站喜用 v2.0
2008-9-6 免费人才招聘网 宽屏版 v3.01
2008-9-6 喜喔喔视频采集程序 v1.0 beta
2008-9-6 ASP客户管理系统
2008-9-6 主流驿站中秋祝福程序
2008-9-6 php实现msn协议的类
2008-9-5 Coppermine Photo Gallery v1.4.
2008-9-5 清松网络日记本 v2.4
2008-8-23 Mini WinMount V0.4
2008-8-23 Vista优化大师3.11正式版
2008-8-23 Wine 1.13
2008-8-23 KlipFolio 5.0 Build 5899-80
2008-8-23 Windows Sysinternals Desktops
2008-8-23 OneTap Movies1.2破解版
2008-8-23 AnnotaterPDF阅读1.1.503 破解版
2008-8-23 SoundMeter分贝测量仪 v1.0汉化破
2008-8-23 iDrum音乐节拍1.0破解版
  发表评论
姓 名: 验证码:
内 容:
站长工具:网站收录查询 | Google PR查询 | ALEXA排名查询 | CSS在线编辑器 | 广告代码 | Html转换js | js/vbs加密 | md5加密 | 进制转换
实用工具:汉字翻译拼音 | 符号对照表 | 个税计算 | 经典小工具 | 汉字简繁转换 | 普通单位换算 | 公制单位换算 | 生辰老黄历 | 国内电话区号 国家代码与域名缩写 | 文字加密解密 | 健康查询 | 万年历 | 汉字横竖排版 | 手机号码查询 | 计算器 | ip搜索
业务联系 | 广告刊登 | 频道合作 | 投稿荐稿 | 联系方式 | 加入收藏 | RSS订阅
Copyright © 2000-2008 www.knowsky.com All rights reserved | 网络实名:动态网站制作指南 | 沪ICP备05001343号