用ASP实现对MP3曲目信息的操作

先简单说一下MP3的ID3 标记,因为主要是操作这个玩意

MP3最开始的时候没有我们今天看到的那样,有歌手、年代,专集等等信息

只有一些简单的参数如yes/no来表示是不是privated或者copyrighted等信息,这样对MP3的相关工作带来了很多不便,1996年的时候有个老外提出来在每个MP3后面追加一段数据,用以存放上述的那些信息,后来就发展成为id3 v1 据我所知的现在已经到1.1了,具体的还是自己去查一下吧

还是老习惯,用metadata来引入DLL,我以前有文章贴过的,不知道的请自己去查

看代码

<!--METADATA TYPE="typelib"

UUID="00000205-0000-0010-8000-00AA006D2EA4"

NAME="ADODB Type Library"

-->

<%

Function ConvertBin(Binary)

'This function converts a binary byte into an ASCII byte.

for i = 1 to LenB(Binary)

strChar = chr(AscB(MidB(Binary,i,1)))

ConvertBin = ConvertBin & strChar

Next

End Function

dim objStream

dim strTag, strSongName, strArtist, strAlbum, strYear, _

strComment, strGenre, strFile

'Specify the folder to iterate through, displaying all the MP3s

Const folder = "C:\mp3s\"

'Grab the folder information

Dim objFSO, objFolder, objFile

Set objFSO = Server.CreateObject("Scripting.FileSYstemObject")

Set objFolder = objFSO.GetFolder(folder)

'Create the Stream object

set objStream = Server.CreateObject("ADODB.Stream")

objStream.Type = adTypeBinary

'Loop through the files in the folder

For Each objFile in objFolder.Files

'Open the stream

objStream.Open

objStream.LoadFromFile objFile.Path

'Read the last 128 bytes

objStream.Position = objStream.size - 128

'Read the ID3 v1 tag info

strTag = ConvertBin(objStream.Read(3))

if ucase(strTag) = "TAG" then

strSongName = ConvertBin(objStream.Read(30))

strArtist = ConvertBin(objStream.Read(30))

strAlbum = ConvertBin(objStream.Read(30))

strYear = ConvertBin(objStream.Read(4))

strComment = ConvertBin(objStream.Read(30))

end if

'Display the results

response.write "<table><tr><td colspan=2><h3>" & _

"ID3 Tag info for:</td></tr><tr>" & _

"<td colspan=2>" & objFile.Name & "</td></tr>"

response.write "<tr><td><b>Artist: </b></td>" & _

"<td>" & strArtist & "</td></tr>"

response.write "<tr><td><b>Track: </b></td>" & _

"<td>" & strSongName & "</td></tr>"

response.write "<tr><td><b>Album: </b></td>" & _

<td>" & strAlbum & "</td></tr>"

response.write "<tr><td><b>Year: </b></td>" & _

"<td>" & strYear & "</td></tr>"

response.write "<tr><td><b>Comment: </b>" & _

"</td><td>" & strComment & "</td></tr>"

response.write "</table>"

objStream.Close

Response.Write "<p><hr><p>"

Next

Set objStream = Nothing 'Clean up...

%>

自己试试吧

希望能对你有所帮助

http://www.sanchat.com

(0)

相关推荐

  • 用ASP实现对MP3曲目信息的操作

    先简单说一下MP3的ID3 标记,因为主要是操作这个玩意 MP3最开始的时候没有我们今天看到的那样,有歌手.年代,专集等等信息 只有一些简单的参数如yes/no来表示是不是privated或者copyrighted等信息,这样对MP3的相关工作带来了很多不便,1996年的时候有个老外提出来在每个MP3后面追加一段数据,用以存放上述的那些信息,后来就发展成为id3 v1 据我所知的现在已经到1.1了,具体的还是自己去查一下吧 还是老习惯,用metadata来引入DLL,我以前有文章贴过的,不知道的

  • ASP语言实现对SQL SERVER数据库的操作

    目前管理信息系统已从传统的客户机/服务器(C/S)模式转向了浏览器/服务器(B/S)模式,特别是微软公司推出它的新产品ASP语言之后,这种转变更加迅猛.管理信息系统的核心是对数据库进行包括添加.修改和查询等等操作,ASP提供的ADO数据库接口控件,使得程序员再也勿需编写复杂的CGI程序了,而只要用几句简单的语句即可实现以上操作.1.系统环境 PII 350,Ram 64M,WINNT Server 4.0, Service Pack4, IIS 4.0, SQL Server7.0. 2.系统功

  • express+mongoose实现对mongodb增删改查操作详解

    本文实例讲述了express+mongoose实现对mongodb增删改查操作.分享给大家供大家参考,具体如下: 项目地址:https://github.com/jrainlau/mongoose_crud 写在开头 本文主要分享我如何使用express+mongoose对mongodb实现增删改查操作,感谢cnode社区所有精品文章的帮助,以及@airuikun的开源项目airuikun/mongoose_crud对我的启发. 学习nodejs已经小半个月了,一直琢磨着做一些什么东西出来.由于

  • Python实现对PPT文件进行截图操作的方法

    本文实例讲述了Python实现对PPT文件进行截图操作的方法.分享给大家供大家参考.具体分析如下: 下面的代码可以为powerpoint文件ppt进行截图,可以指定要截取的幻灯片页面,需要本机安装了powerpoint,可以指定截图的大小分辨率 import os import comtypes.client def export_presentation(path_to_ppt, path_to_folder): if not (os.path.isfile(path_to_ppt) and

  • java实现对map的字典序排序操作示例

    本文实例讲述了java实现对map的字典序排序操作.分享给大家供大家参考,具体如下: java中对map的字典序排序,算法验证比对微信官网https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1421141115&token=&lang=zh_CN,搜索关键字"附录1-JS-SDK使用权限签名算法" import java.util.ArrayList; import java.util.Collectio

  • Java使用jdbc连接实现对MySQL增删改查操作的全过程

    目录 1.新建项目 2.添加jar包 3.jdbc的连接 4.简单的MySQL增删改查操作 总结 1.新建项目 新建一个项目,fileànewàproject如下图: 选择Javaà下一步,如下图:(注意如果jdk推荐使用jdk1.8版本哦,如果不是可以在project SDK中更换,Add JDK,找到自己电脑上放JDK1.8的地方,没有的话自行下载哦) 继续下一步 创建项目名字(自己起就行,注意项目名不要大写),找一个存放的地址,也自己决定就行. 2.添加jar包 一般默认位置是在如下位置:

  • 用ASP实现对ORACLE数据库的操作

    ASP(Active Server Pages)是微软公司为开发互联网应用程序所提出的工具之一,ASP与数据库的联接一般通过ADO(Activex Data Object)来实现的,就象<计算机世界>2000年3月20日的<用ASP对SQL Server数据库操作>文章介绍的一样,ADO可以完全支持Microsoft SQL Server ,但对应用更加广泛.机制更加复杂的ORACLE 数据库服务就有一些困难,如果想作一些简单的查询功能,ADO是足够的,如要想更好地发挥ORACLE

  • C/C++实现对STORM运行信息查看及控制的方法

    本文所述程序实例主要实现在后端应用服务器上实时获取STORM集群的运行信息和topology相关的提交和控制.对此,通过对STORM UI和CMD源码的分析,得出可以通过其thrift接口调用实现这些功能.先下载一个thrift库进行编码和安装.关于thrift可以参见这个地方.安装完成后,从STORM源码中将storm.thrift拷贝到thrift目录下.输入: hrift -gen cpp storm.thrift 会得到一个gen-cpp目录,里面就是thrift先关脚本的C++实现.我

  • asp 实现对SQL注入危险字符进行重编码处理的函数

    <% '****************************** '函数:CheckStr(byVal ChkStr) '参数:ChkStr,待验证的字符 '作者:阿里西西 '日期:2007/7/15 '描述:对SQL注入危险字符进行重编码处理 '示例:CheckStr("and 1=1 or select * from") '****************************** Function CheckStr(byVal ChkStr)  Dim Str:Str

  • python实现对excel进行数据剔除操作实例

    前言 学习Python的过程中,我们会遇到Excel的各种问题.下面这篇文章主要给大家介绍了关于python对excel进行数据剔除操作的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧. Python解析Excel时需要安装两个包,分别是xlrd(读excel)和xlwt(写excel),安装方法如下: pip install xlrd pip install xlwt 需求分析: 判断excel2表中的某个唯一字段是否满足条件,如果满足条件,就在excel1中进行查询

随机推荐