この記事では主にangularjsのファイルアップロード機能について説明します。angularjsでファイルをアップロードする方法を知っていますか? angularjs はフロントエンド ページです。バックエンドで何が使用されているか知っていますか?今すぐこの記事を読んでみましょう
ファイルをアップロードするには
AngularJS
を使用しますAngularJS
上传文件
前台是Angular
页面
后台使用SpringBoot/SpirngMVC
html
<p> <input id="fileUpload" type="file" /> <button ng-click="uploadFile()">上传</button></p>
js
$scope.upload = function(){ var form = new FormData(); var file = document.getElementById("fileUpload").files[0]; form.append('file', file); $http({ method: 'POST', url: '/upload', data: form, headers: {'Content-Type': undefined}, transformRequest: angular.identity }).success(function (data) { console.log('upload success'); }).error(function (data) { console.log('upload fail'); }) }
注意:
AngularJS默认的
'Content-Type'
是application/json
,通过设置'Content-Type': undefined
,这样浏览器不仅帮我们把Content-Type
设置为multipart/form-data
,还填充上当前的boundary
,如果手动设置为:
'Content-Type': multipart/form-data
,后台会抛出异常:the request was rejected because no multipart boundary was found
boundary
是随机生成的字符串,用来分隔文本的开始和结束通过设置
transformRequest: angular.identity
,anjularjs transformRequest function
将序列化我们的formdata object
,也可以不添加
后台
@RequestMapping("/upload") public void uploadFile(@RequestParam(value = "file" , required = true) MultipartFile file) { //deal with file }
注意
文件必须通过@RequestParam注解来获取,且需指定value才能获取到
这样就完成了上传文件
html
<p> <input id="fileUpload" type="file" /> <button ng-click="ok()">上传</button><br> <input ng-model="user.username" /> <input ng-model="user.password" /> </p>
js
$scope.ok = function () { var form = new FormData(); var file = document.getElementById("fileUpload").files[0]; var user =JSON.stringify($scope.user); form.append('file', file); form.append('user',user); $http({ method: 'POST', url: '/addUser', data: form, headers: {'Content-Type': undefined}, transformRequest: angular.identity }).success(function (data) { console.log('operation success'); }).error(function (data) { console.log('operation fail'); }) };
注意
需要将Object转为String后在附加到form上,否则会直接被转为字符串[Object,object]
后台(想看更多就到PHP中文网AngularJS开发手册中学习)
@RequestMapping("/upload") public Map<String, Object> upload(@RequestParam(value = "file") MultipartFile file, @RequestParam(value = "user", required = true) String user) { try (FileInputStream in = (FileInputStream) headImg.getInputStream(); FileOutputStream out = new FileOutputStream("filePathAndName")) { //将Json对象解析为UserModel对象 ObjectMapper objectMapper = new ObjectMapper(); UserModel userModel = objectMapper.readValue(user, UserModel.class); //保存文件到filePathAndName int hasRead = 0; byte[] bytes = new byte[1024]; while ((hasRead = in.read(bytes)) > 0) { out.write(bytes, 0, hasRead); } } catch (IOException e) { e.printStackTrace(); } }
注意
ObjectMapper
为com.fasterxml.jackson.databind.ObjectMapper
使用
AngularJS
html🎜🎜 🎜rrreee🎜🎜🎜js🎜🎜🎜rrreee🎜 🎜注: 🎜🎜🎜🎜 AngularJS のデフォルトのはバックグラウンドで
SpringBoot/SpirngMVC
を使用します
ファイルをアップロードする
'Content-Type'
は、 を設定することで <code>application/json
になります。 >'Content-Type': unknown 。これにより、ブラウザは Content-Type
を multipart/form-data
に設定するだけでなく、現在の boundary
、🎜🎜🎜🎜 手動で 'Content-Type': multipart/form-data
に設定すると、バックグラウンドで例外がスローされます: マルチパート境界が見つからなかったため、リクエストは拒否されました
🎜🎜 🎜🎜boundary
は、テキストの先頭と末尾を区切るために使用されるランダムに生成された文字列です🎜🎜🎜🎜 を設定することでtransformRequest: angular.identity
、anjuularjs transformRequest 関数
は formdata オブジェクト
をシリアル化します。そうしないと、 🎜🎜🎜🎜🎜🎜🎜Backend🎜🎜🎜rrreee を追加できません🎜🎜注意🎜🎜🎜🎜ファイルは @RequestParam アノテーションを介して取得する必要があり、取得するには値を指定する必要があります🎜🎜🎜🎜🎜🎜🎜これでファイルのアップロードは完了です🎜🎜🎜ObjectMapper
は com.fasterxml.jackson.databind.ObjectMapper
🎜🎜🎜🎜🎜🎜AngularJS
を使用してファイル 🎜🎜🎜をアップロードする この記事はここで終わります (さらに詳しく知りたい場合は、PHP 中国語 Web サイト 🎜AngularJS ユーザー マニュアル🎜 にアクセスして学習してください) )ご質問がございましたら、以下にメッセージを残してください。 🎜🎜🎜🎜🎜🎜🎜🎜🎜以上がAngularJS でファイルをアップロードするにはどうすればよいですか? angularjsアップロード機能の詳細な紹介の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。