首先来说说大文件上传,用的WEB服务,代码如下。
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Diagnostics;
using System.Web;
using System.Web.Services;
using System.IO;

namespace WebNews
{
 /// <summary>
 /// FileService 的摘要说明。
 /// </summary>
 public class FileService : System.Web.Services.WebService
 {
  public FileService()
  {
   //CODEGEN: 该调用是 ASP.NET Web 服务设计器所必需的
   InitializeComponent();
  }

#region 组件设计器生成的代码
  
  //Web 服务设计器所必需的
  private IContainer components = null;
    
  /// <summary>
  /// 设计器支持所需的方法 - 不要使用代码编辑器修改
  /// 此方法的内容。
  /// </summary>
  private void InitializeComponent()
  {
  }

/// <summary>
  /// 清理所有正在使用的资源。
  /// </summary>
  protected override void Dispose( bool disposing )
  {
   if(disposing && components != null)
   {
    components.Dispose();
   }
   base.Dispose(disposing);  
  }
  
  #endregion

// WEB 服务示例
  // HelloWorld() 示例服务返回字符串 Hello World
  // 若要生成,请取消注释下列行,然后保存并生成项目
  // 若要测试此 Web 服务,请按 F5 键

[WebMethod]
  public ArrayList GetMp3()
        {
            ArrayList mp3List =new ArrayList();
            string mp3path = Server.MapPath("mp3");
            try
            {
                DirectoryInfo di = new DirectoryInfo(mp3path);
                FileInfo[] fi = di.GetFiles();
                foreach (FileInfo fiTemp in fi)
                {
                    if(fiTemp.Extension.ToLower() == ".mp3"||fiTemp.Extension.ToLower() == ".wma")
                    {
                        mp3List.Add(fiTemp.Name);
                    }
                }           
            }
            catch (Exception e)
            {
                Console.WriteLine("The process failed: {0}", e.ToString());
            }
            return mp3List;
        }

}
}
还需要一个页面来指定上传的文件,和调用WEB服务.aspx页代码。
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
<HTML>
 <HEAD>
  <title>Upload</title>
  <meta name="GENERATOR" Content="Microsoft Visual Studio .NET 7.1">
  <meta name="CODE_LANGUAGE" Content="C#">
  <meta name="vs_defaultClientScript" content="JavaScript">
  <meta name="vs_targetSchema" content="http://schemas.microsoft.com/intellisense/ie5">
 </HEAD>
 <body>
  <form id="Form1" method="post" runat="server" enctype="multipart/form-data">
   <INPUT id="MyFile" type="file" runat="server" NAME="MyFile">
   <br>
   <br>
   <asp:Button id="Button1" runat="server" Text="上载文件"></asp:Button>
  </form>
 </body>
</HTML>

CS后台代码如下。
using System;
using System.Collections;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Web;
using System.Web.SessionState;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.HtmlControls;
using System.Web.Services;
using System.IO;

namespace WebNews
{
 /// <summary>
 /// Upload1 的摘要说明。
 /// </summary>
 public class Upload1 : System.Web.UI.Page
 {
  protected System.Web.UI.WebControls.Button Button1;
  protected System.Web.UI.HtmlControls.HtmlInputFile MyFile;
 
  private void Page_Load(object sender, System.EventArgs e)
  {
   // 在此处放置用户代码以初始化页面
  }

#region Web 窗体设计器生成的代码
  override protected void OnInit(EventArgs e)
  {
   //
   // CODEGEN: 该调用是 ASP.NET Web 窗体设计器所必需的。
   //
   InitializeComponent();
   base.OnInit(e);
  }
  
  /// <summary>
  /// 设计器支持所需的方法 - 不要使用代码编辑器修改
  /// 此方法的内容。
  /// </summary>
  private void InitializeComponent()
  {   
   this.Button1.Click += new System.EventHandler(this.Button1_Click);
   this.Load += new System.EventHandler(this.Page_Load);

}
  #endregion

private void Button1_Click(object sender, System.EventArgs e)
  {
   ///首先得到上载文件信息和文件流
   if(MyFile.PostedFile != null)
   {
    System.Web.HttpFileCollection oFiles;
    oFiles = System.Web.HttpContext.Current.Request.Files;
    if(oFiles.Count < 1)
    {
     Response.Write ("请选择文件。");
     Response.End();
    }

string FilePath = oFiles[0].FileName;
    if(FilePath == "" || FilePath == null)
    {
     Response.Write ("请选择一个文件。");
     Response.End();
    }
    string FileName = FilePath.Substring(FilePath.LastIndexOf("\\")+1);
    try
    {
     ///处理上载的文件流信息。
     byte[] b = new byte[oFiles[0].ContentLength];
     System.IO.Stream fs;
     Upload o;
     o = new Upload();
     fs = (System.IO.Stream)oFiles[0].InputStream;
     fs.Read(b, 0, oFiles[0].ContentLength);
     ///调用Web Services的UploadFile方法进行上载文件。
     Response.Write(o.UploadFile(b, FileName));
     fs.Close();
    }
    catch(Exception ex)
    {
     Response.Write(ex.Message);
    }
   }
   else
   {
    Response.Write("请选择文件");
   }

}
 }
}
需要注意的是上载大文件时,可使用 元素的 maxRequestLength 属性来增加文件大小的最大允许值,例如:
<configuration>
   <system.web>
      <httpRuntime maxRequestLength="5655648" executionTimeout="3600" />
   </system.web>
</configuration>

以上是大文件上传,下面来实现在线播放功能。ASPX页代码如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" >
<HTML>
  <HEAD>
  <TITLE>多媒体播放页面</TITLE>
  <meta content="Microsoft Visual Studio .NET 7.1" name="GENERATOR">
  <meta content="C#" name="CODE_LANGUAGE">
  <meta content="JavaScript" name="vs_defaultClientScript">
  <meta content="http://schemas.microsoft.com/intellisense/ie5" name="vs_targetSchema">
  </HEAD>
 <BODY ms_positioning="GridLayout" bottomMargin=10 topMargin=10>
  <FORM id="Form1" method="post" runat="server">  
<object id="MediaPlayer1" classid="clsid:22D6F312-B0F6-11D0-94AB-0080C74C7E95" width="620" height="460" VIEWASTEXT>              
     <param name="filename" value= "<%=PlayUrl%>">       
            <param name="AutoStart" value="1"> 
            <param name="Enabled" value="-1">  
            <param name="ShowControls" value="-1"> 
            <param name="ShowGotoBar" value="0">
            <param name="ShowStatusBar" value="-1">  
            <param name="EnableFullScreenControls" value="0">              
            <param name="EnablePositionControls" value="0">     
            <param name="Volume" value="0">      
            <param name="DisplaySize" value="4">   
            <param name="SendErrorEvents" value="0">             
            <param name="enableContextMenu" value="0">   
            <param name="EnableTracker" value="-1">      
            <param name="AudioStream" value="-1">        
            <param name="AutoSize" value="0">          
            <param name="AnimationAtStart" value="-1">       
            <param name="AllowScan" value="-1">      
            <param name="AllowChangeDisplaySize" value="-1">    
            <param name="AutoRewind" value="0"> 
            <param name="Balance" value="0">   
            <param name="BaseURL" value="">    
            <param name="BufferingTime" value="5">       
            <param name="CaptioningID" value="">              
            <param name="ClickToPlay" value="-1">      
            <param name="CursorType" value="0">       
            <param name="CurrentPosition" value="-1">        
            <param name="CurrentMarker" value="0">       
            <param name="DefaultFrame" value="">
            <param name="DisplayBackColor" value="0">   
            <param name="DisplayForeColor" value="16777215">     
            <param name="DisplayMode" value="0">
            <param name="InvokeURLs" value="-1">      
            <param name="Language" value="-1">           
            <param name="Mute" value="0">     
            <param name="PlayCount" value="1">     
            <param name="PreviewMode" value="0">              
            <param name="Rate" value="1">     
            <param name="SAMILang" value="">              
            <param name="SAMIStyle" value="">      
            <param name="SAMIFileName" value="">              
            <param name="SelectionStart" value="-1">        
            <param name="SelectionEnd" value="-1">        
            <param name="SendOpenStateChangeEvents" value="-1">    
            <param name="SendWarningEvents" value="-1">     
            <param name="SendKeyboardEvents" value="0">      
            <param name="SendMouseClickEvents" value="0">    
            <param name="SendMouseMoveEvents" value="0">     
            <param name="SendPlayStateChangeEvents" value="-1">       
            <param name="ShowCaptioning" value="0">          
            <param name="ShowAudioControls" value="-1"> 
            <param name="ShowDisplay" value="0">     
            <param name="ShowPositionControls" value="-1">    
            <param name="ShowTracker" value="-1">      
            <param name="TransparentAtStart" value="0">    
            <param name="VideoBorderWidth" value="0">      
            <param name="VideoBorderColor" value="0">   
            <param name="VideoBorder3D" value="0">     
            <param name="WindowlessVideo" value="0"> 
            </object>

</FORM>
 </BODY>
</HTML>
CS后台只需要指定一下"<%=PlayUrl%>"就可以了,代码如下:
public string PlayUrl;
  private void Page_Load(object sender, System.EventArgs e)
  {
   if(!Page.IsPostBack)
   {
      PlayUrl="UpLoadFile\\04405090.wmv";
   }
  }

在线播放的功能还不是很完善,我想用 Flash来做在线播放像新浪网站上的播放那样,等研究出来了我会粘到博客上的。

转载于:https://www.cnblogs.com/yanfei331/archive/2007/07/25/831135.html

大文件上传和在线播放相关推荐

  1. vue 文件及描述信息一起上传_用Vue实现一个大文件上传和断点续传

    前言 这段时间面试官都挺忙的,频频出现在博客文章标题,虽然我不是特别想蹭热度,但是实在想不到好的标题了-.-,蹭蹭就蹭蹭 :) 事实上我在面试的时候确实被问到了这个问题,而且是一道在线 coding ...

  2. 大文件上传 进度条显示(仿CSDN资源上传效果) .

    浏览-选择文件-点击 "上传 "后,效果如下: 弹出透明UI遮罩层 并显示上传这个过程 我这里设置太透明了 效果不是很立体 文件结构如图: 说明:用到"高山来客" ...

  3. 大文件上传服务器:支持超大文件HTTP断点续传的实现办法

    点击上方蓝色"方志朋",选择"设为星标"回复"666"获取独家整理的学习资料! 来源:blog.csdn.net/ababab12345/a ...

  4. nodejs文件服务器断点续传,基于Nodejs的大文件上传之断点续传

    接着<扒一扒Nodejs formidable的onPart>和<也说文件上传之兼容IE789的进度条---丢掉flash>:前面已完成兼容IE789的大文件上传:无flash ...

  5. Asp.net2.0下的大文件上传服务器控件

    最近本来准备在Alisoft上做点东西玩,做的过程中,涉及到了文件上传.刚开始,准备在网上找几个用,发现国外好用的要钱,而国内的,开源的又不好用,所以决定自己也写一个,顺便以后赚点外快.我看了一下,这 ...

  6. JAVA大文件上传断点续传解决方案

    JAVA大文件上传断点续传解决方案 参考文章: (1)JAVA大文件上传断点续传解决方案 (2)https://www.cnblogs.com/songsu/p/11834425.html (3)ht ...

  7. asp.net实现ftp上传代码(解决大文件上传问题)

    asp.net实现ftp上传代码(解决大文件上传问题) 参考文章: (1)asp.net实现ftp上传代码(解决大文件上传问题) (2)https://www.cnblogs.com/LYunF/ar ...

  8. jquery PHP大文件上传,Jquery和BigFileUpload实现大文件上传及进度条显示

    实现方法:用到了高山来客 的bigfileupload组件,用高山来客的方法,弹出一个模式窗口,然后不停刷新获取进度,始终觉得体验感不好,于是想到用jquery来实现无刷新进度显示,因为提交页面后, ...

  9. 解决PHP大文件上传问题

    PHP大文件上传问题    今天负责创业计划大赛的老师问我作品上报系统上传不了大文件,我当时纳闷了,做的时候没限制上传文件的大小阿,怎么会传不了呢,自己亲自体验了番,果然不 行,想了好一会儿才有点眉目 ...

最新文章

  1. php禁止代理ip访问_php禁止某ip或ip地址段访问的方法
  2. C#帮助类:MD5加密
  3. Xamarin.Forms开发实战基础篇大学霸内部资料
  4. C语言学习之利用指针将字符串a复制为字符串 b,然后输出字符串b
  5. 点a链接写邮件小技巧
  6. think php f方法,修改ThinkPHP3.2的F方法
  7. ROS修改pkg名和node名教程
  8. mysql 多个网卡_seriver -- 多个网卡只能认到一个网卡的解决方法
  9. html网页表单设计实验报告,Html设计实验报告.doc
  10. ios 手势返回监听方法
  11. java 物联网 云计算_传智播客Java JavaEE+物联网云计算 就业班
  12. 「LOJ#10068」「一本通 3.1 练习 3」秘密的牛奶运输(次小生成树
  13. QQ出现大规模盗号,qq被盗发布不良信息怎么办
  14. python中shelf_在python 3中使用python 2 shelf
  15. 基于深度学习的车辆信息识别(一):车辆颜色识别
  16. 【python爬虫 系列】1.理解网络爬虫
  17. 最小生成树(克鲁斯卡尔算法 普里姆算法)
  18. Python BDD 框架之lettuce
  19. Range-based for(C++20)
  20. Laya---竖向滚动列表

热门文章

  1. 心电信号的PQRST模拟matlab代码(转载+自己调研汇总)
  2. intellij2018使用2019的主题
  3. django的admin界面删除因为外键约束导致失败
  4. 使用TPU的注意事项
  5. 将某个字段改为不重复(unique)
  6. opengl glad.h和 glu.h
  7. python param_Python基于paramunittest模块实现excl参数化
  8. html iframe视频自动播放的属性,iframe通用js播放器myplayer.js加自动播放参数
  9. mybatis获取mysql源数据类型_spring集成mybatis实现mysql数据库读写分离
  10. Replacing the ESXi Host Default Certificate with a CA-Signed Certificate