AngularJs附件上傳下載

首先:angular-file-upload 是一款輕量級的 AngularJS 文件上傳工具,爲不支持瀏覽器的 FileAPI polyfill 設計,使用 HTML5 直接進行文件上傳。javascript

第一步:引用angularjs的腳本:ng-file-upload-shim.min.js 和 ng-file-upload.min.jshtml

第二步:在angularjs的controller中注入:ngFileUploadjava

           例如:angular.module('liaoyuan.controllers', ['ui.bootstrap', 'ngFileUpload', 'ng.ueditor']);angularjs

第三部:寫代碼web

1、上傳數據庫

一、前臺的html代碼  json

 1  <form>
 2         <!-- <input class="form-control update-input" ngf-select type="file" ng-model="file" name="file" readonly="readonly" /> -->
 3         <div class="content">
 4             <label class="update-label">請選擇上傳的文件位置:</label>
 5 
 6             <input class="filename" type="text" readonly="readonly" />
 7             <a href="javascript:;" class="file-a" name="file">
 8                 <input class="file" ngf-select type="file" ng-model="file" name="file" readonly="readonly" />瀏覽...
 9             </a>
10         </div>
11         <button type="button" class="btn btn-primary update-button" style="" ng-click="submit()">
12             上傳
13         </button>
14         <script type="text/javascript">
15                 var file = $('.file'),
16                     aim = $('.filename');
17                 file.on('change', function( e ){
18                     var name = e.currentTarget.files[0].name;
19                     aim.val( name );
20                 });
21         </script>
22     </form>

二、angularjs 控制器Controller中的代碼bootstrap

 1 app.controller('FileController', function ($scope, $uibModalInstance, Upload) {   
 2     //取消
 3     $scope.cancel = function () {
 4         $uibModalInstance.dismiss('cancel');
 5     };
 6     //上傳按鈕
 7     $scope.submit = function () {
 8         $scope.upload($scope.file);
 9     };
10 
11     $scope.upload = function (file) {
12         $scope.fileInfo = file;
13         Upload.upload({
14             //服務端接收
15             method: 'POST',
16             url: 'http://localhost:56897/api/serviceLogAttachments',
17             file: file
18         }).progress(function (evt) {
19             //進度條
20             var progressPercentage = parseInt(100.0 * evt.loaded / evt.total);
21             console.log('progess:' + progressPercentage + '%' + evt.config.file.name);
22         }).success(function (newAttachment) {
23             //上傳成功
24             $uibModalInstance.close(newAttachment);
25         }).error(function (data, status, headers, config) {
26             //上傳失敗
27             console.log('error status: ' + status);
28         });
29     };
30 
31 
32 
33 });

注意:Upload必定要注入api

三、後臺上傳代碼瀏覽器

 1 [HttpPost]
 2         public IHttpActionResult PostAttachment()
 3         {
 4             int logId = 1;
 5             HttpContext.Current.Response.ContentType = "application/json";
 6             HttpFileCollection files = HttpContext.Current.Request.Files;
 7             HttpRequestMessage h = new HttpRequestMessage();
 8             var file = files[0];
 9             string fileExt = Path.GetExtension(file.FileName);
10 
11             string attachmentName = file.FileName.Substring(0, file.FileName.LastIndexOf("."));
12 
13             string fileNewName = attachmentName + DateTime.Now.ToString("yyyyMMddHHmmssfff")+ fileExt;
14 
15             string strRelativeDir = "/Upload/服務管理/日誌詳情附件/";
16             
17             string fliePath = HttpContext.Current.Request.MapPath(strRelativeDir);
18             if (!Directory.Exists(fliePath))
19             {
20                 Directory.CreateDirectory(fliePath);
21             }
22             string strSavePath = Path.Combine(fliePath, fileNewName);
23             file.SaveAs(strSavePath);
24 //插入數據庫
25             ServiceLogAttachmentService.AddAttachment(attachment);
26             return CreatedAtRoute("DefaultApi", new{id = attachment.AttachmentID}, attachment);
27         }

2、下載

一、前臺下載代碼

    方法一:直接訪問後臺數據(但此方法在先後臺有受權與驗證的時候,會不方便)

1  //附件下載
2     $scope.fileDown = function (url, name) {
3         window.location.href = "http://localhost:56888/api/ServiceStateChanges?url=" + url + "&fileName=" + name;
4     }

   方法二:在請求數據時在header上加上驗證的token 

 1  //附件下載
 2     $scope.fileDown = function (url, name) {
 3         var xhr = new XMLHttpRequest();
 4         xhr.responseType = "blob";
 5 
 6         xhr.open("GET", "http://localhost:56888/api/ServiceStateChanges?url=" + url + "&filename=" + name + "", true);
 7 
 8         xhr.setRequestHeader("Authorization", 'Bearer ' + currUser.token);
 9 
10         xhr.onreadystatechange = function (e) {
11             if (this.readyState == 4) {
12                 var response = this.response;
13                 var URL = window.URL || window.webkitURL || window;
14                 var link = document.createElement('a');
15                 link.href = URL.createObjectURL(response);
16                 link.download = name;
17                 var event = document.createEvent('MouseEvents');
18                 event.initMouseEvent('click', true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null);
19                 link.dispatchEvent(event);
20             }
21         }
22         xhr.send(null);      
23     }

 

二、後臺下載代碼

 1  public HttpResponseMessage GetFile(string url,string fileName)
 2         {
 3             try
 4             {
 5                 var FilePath = System.Web.Hosting.HostingEnvironment.MapPath(@"~/"+ url);
 6                 System.IO.FileStream stream=null;
 7                 stream = new FileStream(FilePath, FileMode.Open);
 8                 HttpResponseMessage response = new HttpResponseMessage(HttpStatusCode.OK);
 9                 response.Content = new StreamContent(stream);
10                 response.Content.Headers.ContentType = new MediaTypeHeaderValue("application/octet-stream");
11                 response.Content.Headers.ContentDisposition = new ContentDispositionHeaderValue("attachment")
12                 {
13                     FileName = fileName
14                 };
15                 return response;
16             }
17             catch
18             {
19                 return new HttpResponseMessage(HttpStatusCode.NoContent);
20             }
21         }

 

注:僅我的理解及筆記,有誤的地方請各位大神指正!

相關文章
相關標籤/搜索